⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 2410usb.h

📁 arm_bootloader _flash writter &USB
💻 H
字号:
#ifndef __24XUSB_H__
#define __24XUSB_H__

#include "2410addr.h"

/*------------------------------------------------------------------------------------------*/
/*                                Macro definitons on USB                                   */
/*------------------------------------------------------------------------------------------*/

// 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                 (EP0_SERVICED_OUT_PKT_RDY | EP0_SERVICED_SETUP_END)

// 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)

// 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)

// 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)

//If you change the packet size, the source code should be changed!!!
#define BULK_PKT_SIZE               (64)
#define EP0_PKT_SIZE                (8)
#define EP1_PKT_SIZE                (BULK_PKT_SIZE)
#define EP3_PKT_SIZE                (BULK_PKT_SIZE)

#endif  //__24XUSB_H__


/* 
// 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))

#define ADDR_EP0_FIFO			(0x520001c0)				//Endpoint 0 FIFO
#define ADDR_EP1_FIFO			(0x520001c4)				//Endpoint 1 FIFO
#define ADDR_EP2_FIFO			(0x520001c8)				//Endpoint 2 FIFO
#define ADDR_EP3_FIFO			(0x520001cc)				//Endpoint 3 FIFO
#define ADDR_EP4_FIFO			(0x520001d0)				//Endpoint 4 FIFO
*/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -