📄 usbci.h
字号:
/****************************************Copyright (c)**************************************************** Guangzhou ZHIYUAN electronics Co.,LTD.** ** http://www.zyinside.com****--------------File Info-------------------------------------------------------------------------------** File Name: USBCI.h** Last modified Date: 2006.01.09** Last Version: V1.0 ** Description: USB 设备控制器接口命令层头文件** USB Device Controller Interface command layer header file**------------------------------------------------------------------------------------------------------** Created By: MingYuan Zheng 郑明远** Created date: 2006.01.09** Version: V1.0** Descriptions: The original version 初始版本****------------------------------------------------------------------------------------------------------** Modified by:** Modified date:** Version:** Description:**********************************************************************************************************/
#ifndef __USBCI_H__
#define __USBCI_H__
//*************************************************************************
// USB definitons
//*************************************************************************
#define EP0_FIFO_OFFSET 0x1C0
/* Power Management Register */
#define DISABLE_SUSPEND 0x00
#define ENABLE_SUSPEND 0x01
#define SUSPEND_MODE 0x02
#define MCU_RESUME 0x04
#define ISO_UPDATE (1<<7)
/* MAXP Register */
#define FIFO_SIZE_0 0x00 /* 0x00 * 8 = 0 */
#define FIFO_SIZE_8 0x01 /* 0x01 * 8 = 8 */
#define FIFO_SIZE_16 0x02 /* 0x02 * 8 = 16 */
#define FIFO_SIZE_32 0x04 /* 0x04 * 8 = 32 */
#define FIFO_SIZE_64 0x08 /* 0x08 * 8 = 64 */
/* ENDPOINT0 CSR (Control Status Register) : Mapped to IN CSR1 */
#define EP0_OUT_PKT_READY 0x01 /* USB sets, MCU clears by setting SERVICED_OUT_PKT_RDY */
#define EP0_IN_PKT_READY 0x02 /* MCU sets, USB clears after sending FIFO */
#define EP0_SENT_STALL 0x04 /* USB sets */
#define EP0_DATA_END 0x08 /* MCU sets */
#define EP0_SETUP_END 0x10 /* USB sets, MCU clears by setting SERVICED_SETUP_END */
#define EP0_SEND_STALL 0x20 /* MCU sets */
#define EP0_SERVICED_OUT_PKT_RDY 0x40 /* MCU writes 1 to clear OUT_PKT_READY */
#define EP0_SERVICED_SETUP_END 0x80 /* MCU writes 1 to clear SETUP_END */
#define EP0_WR_BITS 0xc0
//EP_INT_REG / EP_INT_EN_REG
#define EP0_INT 0x01 // Endpoint 0, Control
#define EP1_INT 0x02 // Endpoint 1, (Bulk-In)
#define EP2_INT 0x04 // Endpoint 2
#define EP3_INT 0x08 // Endpoint 3, (Bulk-Out)
#define EP4_INT 0x10 // Endpoint 4
//USB_INT_REG / USB_INT_EN_REG
#define SUSPEND_INT 0x01
#define RESUME_INT 0x02
#define RESET_INT 0x04
//IN_CSR1
#define EPI_IN_PKT_READY 0x01
#define EPI_UNDER_RUN 0x04
#define EPI_FIFO_FLUSH 0x08
#define EPI_SEND_STALL 0x10
#define EPI_SENT_STALL 0x20
#define EPI_CDT 0x40
#define EPI_WR_BITS (EPI_FIFO_FLUSH|EPI_IN_PKT_READY|EPI_CDT)
//(EPI_FIFO_FLUSH) is preferred (???)
//IN_CSR2
#define EPI_IN_DMA_INT_MASK (1<<4)
#define EPI_MODE_IN (1<<5)
#define EPI_MODE_OUT (0<<5)
#define EPI_ISO (1<<6)
#define EPI_BULK (0<<6)
#define EPI_AUTO_SET (1<<7)
//OUT_CSR1
#define EPO_OUT_PKT_READY 0x01
#define EPO_OVER_RUN 0x04
#define EPO_DATA_ERROR 0x08
#define EPO_FIFO_FLUSH 0x10
#define EPO_SEND_STALL 0x20
#define EPO_SENT_STALL 0x40
#define EPO_CDT 0x80
#define EPO_WR_BITS (EPO_FIFO_FLUSH|EPO_SEND_STALL|EPO_CDT)
//(EPO_FIFO_FLUSH) is preferred (???)
//OUT_CSR2
#define EPO_OUT_DMA_INT_MASK (1<<5)
#define EPO_ISO (1<<6)
#define EPO_BULK (0<<6)
#define EPO_AUTO_CLR (1<<7)
//USB DMA control register
#define UDMA_IN_RUN_OB (1<<7)
#define UDMA_IGNORE_TTC (1<<7)
#define UDMA_DEMAND_MODE (1<<3)
#define UDMA_OUT_RUN_OB (1<<2)
#define UDMA_OUT_DMA_RUN (1<<2)
#define UDMA_IN_DMA_RUN (1<<1)
#define UDMA_DMA_MODE_EN (1<<0)
#define rEP1_DMA_TTC (rEP1_DMA_TTC_L+(rEP1_DMA_TTC_M<<8)+(rEP1_DMA_TTC_H<<16))
#define rEP2_DMA_TTC (rEP2_DMA_TTC_L+(rEP2_DMA_TTC_M<<8)+(rEP2_DMA_TTC_H<<16))
#define rEP3_DMA_TTC (rEP3_DMA_TTC_L+(rEP3_DMA_TTC_M<<8)+(rEP3_DMA_TTC_H<<16))
#define rEP4_DMA_TTC (rEP4_DMA_TTC_L+(rEP4_DMA_TTC_M<<8)+(rEP4_DMA_TTC_H<<16))
// select endpoint mask
#define USB_STALL 0x01
#define USB_SETUPPACKET 0x01
/******************************************************************
D14CI.c Function
******************************************************************/
extern void USB_SetCurEndpoint(INT8U endp);
extern void USB_ConfigMaxPaketSize(INT8U endp, INT32U packetsize);
extern void USB_ConfigEpControlStatus(INT8U endp, INT8U EpDir, INT8U EPI_Type, INT8U EPO_Type);
extern void USB_SetAddressEnable(INT8U bAddress, INT8U bEnable);
extern void USB_InterruptEnable(INT8U bEpEnable, INT8U bUSBEnalbe);
extern void USB_SetEndpointStatus(INT8U endp, INT8U bStalled);
extern void USB_ClearBuffer(INT8U endp);
extern void USB_ValidBuffer(INT8U endp);
extern void USB_ValidBufferEp0(INT8U bDataEnd);
extern INT32U USB_ReadEndpoint(INT8U endp, INT32U len, INT8U *buf);
extern INT32U USB_WriteEndpoint(INT8U endp, INT32U len, INT8U *buf);
extern INT8U USB_SelectClrIntEndpoint(INT8U endp);
extern void USB_EndSetup(void);
extern void USB_Clr_EP0_SETUP_END(void);
extern void USB_Clr_EP0_SENT_STALL(void);
extern INT8U USB_ReadINEpStatus(INT8U endp);
extern INT8U USB_ReadOUTEpStatus(INT8U endp);
#define FLUSH_EP0_FIFO() {while(rOUT_FIFO_CNT1_REG)rEP0_FIFO;}
#endif
/*******************************************************************************************************
** End Of File
********************************************************************************************************/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -