|
|
@@ -0,0 +1,450 @@
|
|
|
+#pragma once
|
|
|
+
|
|
|
+/**********************************/
|
|
|
+/*********USB high speed**********/
|
|
|
+/**********************************/
|
|
|
+typedef volatile unsigned short *PUINT16V;
|
|
|
+typedef volatile unsigned long *PUINT32V;
|
|
|
+typedef volatile unsigned char *PUINT8V;
|
|
|
+
|
|
|
+/* USB high speed device register */
|
|
|
+#define R8_USB2_CTRL (*((PUINT8V)0x40009000)) // RW, USB_high_speed control register
|
|
|
+#define USBHS_UD_LPM_EN 0x80 // RW, enable LPM
|
|
|
+#define USBHS_UD_DEV_EN 0x20 // RW, enable USB equipment
|
|
|
+#define USBHS_UD_DMA_EN 0x10 // RW, enable DMA transmit
|
|
|
+#define USBHS_UD_PHY_SUSPENDM 0x08 // RW, suspeng USB PHY
|
|
|
+#define USBHS_UD_CLR_ALL 0x04 // RW, clear all interupt flag
|
|
|
+#define USBHS_UD_RST_SIE 0x02 // RW, reset USB protocol processor,including end point register
|
|
|
+#define USBHS_UD_RST_LINK 0x01 // RW, enable LNK layer reset
|
|
|
+#define R8_USB2_BASE_MODE (*((PUINT8V)0x40009001)) // RW, USB_high_speed mode control register
|
|
|
+#define USBHS_UD_SPEED_FULL 0x00
|
|
|
+#define USBHS_UD_SPEED_HIGH 0x01
|
|
|
+#define USBHS_UD_SPEED_LOW 0x02
|
|
|
+#define USBHS_UD_SPEED_TYPE 0x03 // RW, speed mode excpeted by the equipment,00:full speed, 01:high speed, 10:low speed
|
|
|
+#define R8_USB2_INT_EN (*((PUINT8V)0x40009002)) // RW, USB_high_speed intreurpt enable register
|
|
|
+#define USBHS_UDIE_FIFO_OVER 0x80 // RW, enable fifo overflow interupt
|
|
|
+#define USBHS_UDIE_LINK_RDY 0x40 // RW, enable USB conect interupt
|
|
|
+#define USBHS_UDIE_SOF_ACT 0x20 // RW, enable SOF package received interupt
|
|
|
+#define USBHS_UDIE_TRANSFER 0x10 // RW, enable USB transmit end interupt
|
|
|
+#define USBHS_UDIE_LPM_ACT 0x08 // RW, enable lpm transmit end interupt
|
|
|
+#define USBHS_UDIE_BUS_SLEEP 0x04 // RW, enable usb bus sleep interupt
|
|
|
+#define USBHS_UDIE_SUSPEND 0x02 // RW, enable usb bus suspend interupt
|
|
|
+#define USBHS_UDIE_BUS_RST 0x01 // RW, enable usb bus reset interupt
|
|
|
+#define R8_USB2_DEV_AD (*((PUINT8V)0x40009003)) // RW, USB_high_speed device adress register
|
|
|
+#define USBHS_UD_DEV_ADDR 0x7F // RW, adress of usb equipment
|
|
|
+#define R8_USB2_WAKE_CTRL (*((PUINT8V)0x40009004)) // RW, USB_high_speed wake up remotely register
|
|
|
+#define USBHS_UD_UD_REMOTE_WKUP 0x01 // RW1, wake up remotely and auto reset hardware
|
|
|
+#define R8_USB2_TEST_MODE (*((PUINT8V)0x40009005)) // RW, USB_high_speed test mode register
|
|
|
+#define USBHS_UD_TEST_EN 0x80 // RW, enable test mode
|
|
|
+#define USBHS_UD_TEST_SE0NAK 0x08 // RW, output SE0 when in test mode
|
|
|
+#define USBHS_UD_TEST_PKT 0x04 // RW, output one package(including DATA0,data and length of end pont4) when in test mode,not work on virtual equipment
|
|
|
+#define USBHS_UD_TEST_K 0x02 // RW, output K when in test mode
|
|
|
+#define USBHS_UD_TEST_J 0x01 // RW, output J when in test mode
|
|
|
+#define R16_USB2_LPM_DATA (*((PUINT16V)0x40009006)) // RW, USB_high_speed power control register
|
|
|
+#define USBHS_UD_LPM_BUSY 0x8000 // RW, power control busy
|
|
|
+#define USBHS_UD_LPM_DATA 0x07FF // RO, power control data
|
|
|
+#define R8_USB2_INT_FG (*((PUINT8V)0x40009008)) // RW, USB_high_speed interupt flag register
|
|
|
+#define USBHS_UDIF_FIFO_OV 0x80 // RW1, clear fifo overflow interupt flag
|
|
|
+#define USBHS_UDIF_LINK_RDY 0x40 // RW1, clear USB conect interupt flag
|
|
|
+#define USBHS_UDIF_RX_SOF 0x20 // RW1, clear SOF package received interupt flag
|
|
|
+#define USBHS_UDIF_TRANSFER 0x10 // RO, USB transmit end interupt flag,cleared by USBHS_UDMS_HS_MOD
|
|
|
+#define USBHS_UDIF_LPM_ACT 0x08 // RW1, clear lpm transmit end interupt flag
|
|
|
+#define USBHS_UDIF_BUS_SLEEP 0x04 // RW1, clear usb bus sleep interupt flag
|
|
|
+#define USBHS_UDIF_SUSPEND 0x02 // RW1, clear usb bus suspend interupt flag
|
|
|
+#define USBHS_UDIF_BUS_RST 0x01 // RW1, clear usb bus reset interupt flag
|
|
|
+#define R8_USB2_INT_ST (*((PUINT8V)0x40009009)) // RW, USB_high_speed interupt status register
|
|
|
+#define USBHS_UDIS_EP_DIR 0x10 // RO, end point tranfer diector of data
|
|
|
+#define USBHS_UDIS_EP_ID_MASK 0x07 // RO, number of end point which data transmission occured
|
|
|
+#define R8_USB2_MIS_ST (*((PUINT8V)0x4000900A)) // RW, USB_high_speed miscellaneous register
|
|
|
+#define USBHS_UDMS_HS_MOD 0x80 // RO, host with high speed
|
|
|
+#define USBHS_UDMS_SUSP_REQ 0x10 // RO, requirment of suspending USB
|
|
|
+#define USBHS_UDMS_SIE_FREE 0x08 // RO, USB free state
|
|
|
+#define USBHS_UDMS_SLEEP 0x04 // RO, USB sleep state
|
|
|
+#define USBHS_UDMS_SUSPEND 0x02 // RO, USB in suspend state
|
|
|
+#define USBHS_UDMS_READY 0x01 // RO, USB in connected state
|
|
|
+#define R16_USB2_FRAME_NO (*((PUINT16V)0x4000900C)) // RW, USB_high_speed frame number register
|
|
|
+#define USBHS_UD_MFRAME_NO 0xE000
|
|
|
+#define USBHS_UD_FRAME_NO 0x07FF
|
|
|
+#define R16_USB2_BUS (*((PUINT16V)0x4000900E)) // RW, USB_high_speed bus status register
|
|
|
+#define USBHS_USB_DM_ST 0x08
|
|
|
+#define USBHS_USB_DP_ST 0x04
|
|
|
+#define USB_WAKEUP 0x01
|
|
|
+#define R16_U2EP_TX_EN (*((PUINT16V)0x40009010)) // RW, USB_high_speed end point transmit enable register
|
|
|
+/* Bit definition for R16_U2EP_TX_EN & R16_U2EP_RX_EN register */
|
|
|
+#define RB_EP0_EN 0x0001
|
|
|
+#define RB_EP1_EN 0x0002
|
|
|
+#define RB_EP2_EN 0x0004
|
|
|
+#define RB_EP3_EN 0x0008
|
|
|
+#define RB_EP4_EN 0x0010
|
|
|
+#define RB_EP5_EN 0x0020
|
|
|
+#define RB_EP6_EN 0x0040
|
|
|
+#define RB_EP7_EN 0x0080
|
|
|
+#define RB_EP8_EN 0x0100
|
|
|
+#define RB_EP9_EN 0x0200
|
|
|
+#define RB_EP10_EN 0x0400
|
|
|
+#define RB_EP11_EN 0x0800
|
|
|
+#define RB_EP12_EN 0x1000
|
|
|
+#define RB_EP13_EN 0x2000
|
|
|
+#define RB_EP14_EN 0x4000
|
|
|
+#define RB_EP15_EN 0x8000
|
|
|
+
|
|
|
+#define R16_U2EP_RX_EN (*((PUINT16V)0x40009012)) // RW, USB_high_speed end point receive enableregister
|
|
|
+#define USBHS_UEP_RX_EN 0xFFFF
|
|
|
+#define R16_U2EP_T_TOG_AUTO (*((PUINT16V)0x40009014)) // RW, USB_high_speed end point transmit auto toggle enable register
|
|
|
+#define USBHS_UEP_T_TOG_AUTO 0xFF
|
|
|
+#define R16_U2EP_R_TOG_AUTO (*((PUINT16V)0x40009016)) // RW, USB_high_speed end point receive auto toggle enable register
|
|
|
+#define USBHS_UEP_R_TOG_AUTO 0xFF
|
|
|
+#define R8_U2EP_T_BURST (*((PUINT8V)0x40009018)) // RW, USB_high_speed end point transmit burst register
|
|
|
+#define USBHS_UEP_T_BURST_EN 0xFF
|
|
|
+#define R8_U2EP_T_BURST_MODE (*((PUINT8V)0x40009019)) // RW, USB_high_speed end point transmit burst mode register
|
|
|
+#define USBHS_UEP_T_BURST_MODE 0xFF
|
|
|
+#define R8_U2EP_R_BURST (*((PUINT8V)0x4000901A)) // RW, USB_high_speed end point receive burst register
|
|
|
+#define USBHS_UEP_R_BURST_EN 0xFF
|
|
|
+#define R8_U2EP_R_RES_MODE (*((PUINT8V)0x4000901B)) // RW, USB_high_speed end point transmit reply mode register
|
|
|
+#define USBHS_UEP_R_RES_MODE 0xFF
|
|
|
+#define R32_U2EP_AF_MODE (*((PUINT32V)0x4000901C)) // RW, USB_high_speed end point multiplexing register
|
|
|
+#define USBHS_UEP_T_AF 0xFE
|
|
|
+#define R32_U2EP0_DMA (*((PUINT32V)0x40009020)) // RW, USB_high_speed end point0 begin adress of DMA buffer register
|
|
|
+#define UEPn_DMA 0x01FFFF
|
|
|
+#define R32_U2EP1_RX_DMA (*((PUINT32V)0x40009024)) // RW, USB_high_speed end point1 begin adress of DMA receive buffer register
|
|
|
+#define R32_U2EP2_RX_DMA (*((PUINT32V)0x40009028)) // RW, USB_high_speed end point2 begin adress of DMA receive buffer register
|
|
|
+#define R32_U2EP3_RX_DMA (*((PUINT32V)0x4000902C)) // RW, USB_high_speed end point3 begin adress of DMA receive buffer register
|
|
|
+#define R32_U2EP4_RX_DMA (*((PUINT32V)0x40009030)) // RW, USB_high_speed end point4 begin adress of DMA receive buffer register
|
|
|
+#define R32_U2EP5_RX_DMA (*((PUINT32V)0x40009034)) // RW, USB_high_speed end point5 begin adress of DMA receive buffer register
|
|
|
+#define R32_U2EP6_RX_DMA (*((PUINT32V)0x40009038)) // RW, USB_high_speed end point6 begin adress of DMA receive buffer register
|
|
|
+#define R32_U2EP7_RX_DMA (*((PUINT32V)0x4000903C)) // RW, USB_high_speed end point7 begin adress of DMA receive buffer register
|
|
|
+#define UEPn_RX_DMA 0x01FFFF
|
|
|
+#define R32_U2EP1_TX_DMA (*((PUINT32V)0x40009040)) // RW, USB_high_speed end point1 begin adress of DMA transmit buffer register
|
|
|
+#define R32_U2EP2_TX_DMA (*((PUINT32V)0x40009044)) // RW, USB_high_speed end point2 begin adress of DMA transmit buffer register
|
|
|
+#define R32_U2EP3_TX_DMA (*((PUINT32V)0x40009048)) // RW, USB_high_speed end point3 begin adress of DMA transmit buffer register
|
|
|
+#define R32_U2EP4_TX_DMA (*((PUINT32V)0x4000904C)) // RW, USB_high_speed end point4 begin adress of DMA transmit buffer register
|
|
|
+#define R32_U2EP5_TX_DMA (*((PUINT32V)0x40009050)) // RW, USB_high_speed end point5 begin adress of DMA transmit buffer register
|
|
|
+#define R32_U2EP6_TX_DMA (*((PUINT32V)0x40009054)) // RW, USB_high_speed end point6 begin adress of DMA transmit buffer register
|
|
|
+#define R32_U2EP7_TX_DMA (*((PUINT32V)0x40009058)) // RW, USB_high_speed end point7 begin adress of DMA transmit buffer register
|
|
|
+#define UEPn_TX_DMA 0x01FFFF
|
|
|
+#define R32_U2EP0_MAX_LEN (*((PUINT32V)0x4000905C)) // RW, USB_high_speed end point0 max length package register
|
|
|
+#define R32_U2EP1_MAX_LEN (*((PUINT32V)0x40009060)) // RW, USB_high_speed end point1 max length package register
|
|
|
+#define R32_U2EP2_MAX_LEN (*((PUINT32V)0x40009064)) // RW, USB_high_speed end point2 max length package register
|
|
|
+#define R32_U2EP3_MAX_LEN (*((PUINT32V)0x40009068)) // RW, USB_high_speed end point3 max length package register
|
|
|
+#define R32_U2EP4_MAX_LEN (*((PUINT32V)0x4000906C)) // RW, USB_high_speed end point4 max length package register
|
|
|
+#define R32_U2EP5_MAX_LEN (*((PUINT32V)0x40009070)) // RW, USB_high_speed end point5 max length package register
|
|
|
+#define R32_U2EP6_MAX_LEN (*((PUINT32V)0x40009074)) // RW, USB_high_speed end point6 max length package register
|
|
|
+#define R32_U2EP7_MAX_LEN (*((PUINT32V)0x40009078)) // RW, USB_high_speed end point7 max length package register
|
|
|
+#define UEPn_MAX_LEN 0x007F
|
|
|
+#define R16_U2EP0_RX_LEN (*((PUINT16V)0x4000907C)) // RW, USB_high_speed end point0 length of receive register
|
|
|
+#define UEP0_RX_LEN 0x007F
|
|
|
+#define R16_U2EP1_RX_LEN (*((PUINT16V)0x40009080)) // RW, USB_high_speed end point1 single received length register
|
|
|
+#define R16_U2EP1_R_SIZE (*((PUINT16V)0x40009082)) // RW, USB_high_speed end point1 total received length register
|
|
|
+#define R16_U2EP2_RX_LEN (*((PUINT16V)0x40009084)) // RW, USB_high_speed end point2 single received length register
|
|
|
+#define R16_U2EP2_R_SIZE (*((PUINT16V)0x40009086)) // RW, USB_high_speed end point2 total received length register
|
|
|
+#define R16_U2EP3_RX_LEN (*((PUINT16V)0x40009088)) // RW, USB_high_speed end point3 single received length register
|
|
|
+#define R16_U2EP3_R_SIZE (*((PUINT16V)0x4000908A)) // RW, USB_high_speed end point3 total received length register
|
|
|
+#define R16_U2EP4_RX_LEN (*((PUINT16V)0x4000908C)) // RW, USB_high_speed end point4 single received length register
|
|
|
+#define R16_U2EP4_R_SIZE (*((PUINT16V)0x4000908E)) // RW, USB_high_speed end point4 total received length register
|
|
|
+#define R16_U2EP5_RX_LEN (*((PUINT16V)0x40009090)) // RW, USB_high_speed end point5 single received length register
|
|
|
+#define R16_U2EP5_R_SIZE (*((PUINT16V)0x40009092)) // RW, USB_high_speed end point5 total received length register
|
|
|
+#define R16_U2EP6_RX_LEN (*((PUINT16V)0x40009094)) // RW, USB_high_speed end point6 single received length register
|
|
|
+#define R16_U2EP6_R_SIZE (*((PUINT16V)0x40009096)) // RW, USB_high_speed end point6 total received length register
|
|
|
+#define R16_U2EP7_RX_LEN (*((PUINT16V)0x40009098)) // RW, USB_high_speed end point7 single received length register
|
|
|
+#define R16_U2EP7_R_SIZE (*((PUINT16V)0x4000909A)) // RW, USB_high_speed end point7 total received length register
|
|
|
+#define UEPn_RX_LEN 0xFFFF
|
|
|
+#define UEPn_R_SIZE 0xFFFF
|
|
|
+#define R16_U2EP0_T_LEN (*((PUINT16V)0x4000909C)) // RW, USB_high_speed end point0 length of transmission register
|
|
|
+#define UEP0_T_LEN 0x7F
|
|
|
+#define R8_U2EP0_TX_CTRL (*((PUINT8V)0x4000909E)) // RW, USB_high_speed end point0 transmit control register
|
|
|
+#define R8_U2EP0_RX_CTRL (*((PUINT8V)0x4000909F)) // RW, USB_high_speed end point0 receive control register
|
|
|
+#define R16_U2EP1_T_LEN (*((PUINT16V)0x400090A0)) // RW, USB_high_speed end point1 length of transmission register
|
|
|
+#define R8_U2EP1_TX_CTRL (*((PUINT8V)0x400090A2)) // RW, USB_high_speed end point1 transmit control register
|
|
|
+#define R8_U2EP1_RX_CTRL (*((PUINT8V)0x400090A3)) // RW, USB_high_speed end point1 receive control register
|
|
|
+#define R16_U2EP2_T_LEN (*((PUINT16V)0x400090A4)) // RW, USB_high_speed end point2 length of transmission register
|
|
|
+#define R8_U2EP2_TX_CTRL (*((PUINT8V)0x400090A6)) // RW, USB_high_speed end point2 transmit control register
|
|
|
+#define R8_U2EP2_RX_CTRL (*((PUINT8V)0x400090A7)) // RW, USB_high_speed end point2 receive control register
|
|
|
+#define R16_U2EP3_T_LEN (*((PUINT16V)0x400090A8)) // RW, USB_high_speed end point3 length of transmission register
|
|
|
+#define R8_U2EP3_TX_CTRL (*((PUINT8V)0x400090AA)) // RW, USB_high_speed end point3 transmit control register
|
|
|
+#define R8_U2EP3_RX_CTRL (*((PUINT8V)0x400090AB)) // RW, USB_high_speed end point3 receive control register
|
|
|
+#define R16_U2EP4_T_LEN (*((PUINT16V)0x400090AC)) // RW, USB_high_speed end point4 length of transmission register
|
|
|
+#define R8_U2EP4_TX_CTRL (*((PUINT8V)0x400090AE)) // RW, USB_high_speed end point4 transmit control register
|
|
|
+#define R8_U2EP4_RX_CTRL (*((PUINT8V)0x400090AF)) // RW, USB_high_speed end point4 receive control register
|
|
|
+#define R16_U2EP5_T_LEN (*((PUINT16V)0x400090B0)) // RW, USB_high_speed end point5 length of transmission register
|
|
|
+#define R8_U2EP5_TX_CTRL (*((PUINT8V)0x400090B2)) // RW, USB_high_speed end point5 transmit control register
|
|
|
+#define R8_U2EP5_RX_CTRL (*((PUINT8V)0x400090B3)) // RW, USB_high_speed end point5 receive control register
|
|
|
+#define R16_U2EP6_T_LEN (*((PUINT16V)0x400090B4)) // RW, USB_high_speed end point6 length of transmission register
|
|
|
+#define R8_U2EP6_TX_CTRL (*((PUINT8V)0x400090B6)) // RW, USB_high_speed end point6 transmit control register
|
|
|
+#define R8_U2EP6_RX_CTRL (*((PUINT8V)0x400090B7)) // RW, USB_high_speed end point6 receive control register
|
|
|
+#define R16_U2EP7_T_LEN (*((PUINT16V)0x400090B8)) // RW, USB_high_speed end point7 length of transmission register
|
|
|
+#define R8_U2EP7_TX_CTRL (*((PUINT8V)0x400090BA)) // RW, USB_high_speed end point7 transmit control register
|
|
|
+#define R8_U2EP7_RX_CTRL (*((PUINT8V)0x400090BB)) // RW, USB_high_speed end point7 receive control register
|
|
|
+/**R16_UEPn_T_LEN**/
|
|
|
+#define UEPn_T_LEN 0xFFFF
|
|
|
+/**R8_UEPn_TX_CTRL**/
|
|
|
+#define USBHS_UEP_T_DONE 0x80
|
|
|
+#define USBHS_UEP_T_NAK_ACT 0x40
|
|
|
+#define USBHS_UEP_T_TOG_MASK 0x0C
|
|
|
+#define USBHS_UEP_T_TOG_MDATA 0x0C
|
|
|
+#define USBHS_UEP_T_TOG_DATA2 0x08
|
|
|
+#define USBHS_UEP_T_TOG_DATA1 0x04
|
|
|
+#define USBHS_UEP_T_TOG_DATA0 0x00
|
|
|
+#define USBHS_UEP_T_RES_MASK 0x03
|
|
|
+#define USBHS_UEP_T_RES_ACK 0x02
|
|
|
+#define USBHS_UEP_T_RES_STALL 0x01
|
|
|
+#define USBHS_UEP_T_RES_NAK 0x00
|
|
|
+
|
|
|
+/**R8_UEPn_RX_CTRL**/
|
|
|
+#define USBHS_UEP_R_DONE 0x80
|
|
|
+#define USBHS_UEP_R_NAK_ACT 0x40
|
|
|
+#define USBHS_UEP_R_NAK_TOG 0x20
|
|
|
+#define USBHS_UEP_R_TOG_MATCH 0x10
|
|
|
+#define USBHS_UEP_R_SETUP_IS 0x08
|
|
|
+#define USBHS_UEP_R_TOG_MASK 0x0C
|
|
|
+#define USBHS_UEP_R_TOG_MDATA 0x0C
|
|
|
+#define USBHS_UEP_R_TOG_DATA2 0x08
|
|
|
+#define USBHS_UEP_R_TOG_DATA1 0x04
|
|
|
+#define USBHS_UEP_R_TOG_DATA0 0x00
|
|
|
+#define USBHS_UEP_R_RES_MASK 0x03
|
|
|
+#define USBHS_UEP_R_RES_ACK 0x02
|
|
|
+#define USBHS_UEP_R_RES_STALL 0x01
|
|
|
+#define USBHS_UEP_R_RES_NAK 0x00
|
|
|
+
|
|
|
+#define R16_U2EP_T_ISO (*((PUINT16V)0x400090BC)) // RW, USB_high_speed end point transmit sync mode register
|
|
|
+#define USBHS_UEP1_T_ISO_EN 0x02
|
|
|
+#define USBHS_UEP2_T_ISO_EN 0x04
|
|
|
+#define USBHS_UEP3_T_ISO_EN 0x08
|
|
|
+#define USBHS_UEP4_T_ISO_EN 0x10
|
|
|
+#define USBHS_UEP5_T_ISO_EN 0x20
|
|
|
+#define USBHS_UEP6_T_ISO_EN 0x40
|
|
|
+#define USBHS_UEP7_T_ISO_EN 0x80
|
|
|
+#define R16_U2EP_R_ISO (*((PUINT16V)0x400090BE)) // RW, USB_high_speed end point receive sync mode register
|
|
|
+#define USBHS_UEP1_R_ISO_EN 0x02
|
|
|
+#define USBHS_UEP2_R_ISO_EN 0x04
|
|
|
+#define USBHS_UEP3_R_ISO_EN 0x08
|
|
|
+#define USBHS_UEP4_R_ISO_EN 0x10
|
|
|
+#define USBHS_UEP5_R_ISO_EN 0x20
|
|
|
+#define USBHS_UEP6_R_ISO_EN 0x40
|
|
|
+#define USBHS_UEP7_R_ISO_EN 0x80
|
|
|
+
|
|
|
+/* USB high speed host register */
|
|
|
+#define R8_U2H_CFG (*((PUINT8V)0x40009100)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_LPM_EN 0x80
|
|
|
+#define USBHS_UH_FORCE_FS 0x40
|
|
|
+#define USBHS_UH_SOF_EN 0x20
|
|
|
+#define USBHS_UH_DMA_EN 0x10
|
|
|
+#define USBHS_UH_PHY_SUSPENDM 0x08
|
|
|
+#define USBHS_UH_CLR_ALL 0x04
|
|
|
+#define USBHS_RST_SIE 0x02
|
|
|
+#define USBHS_RST_LINK 0x01
|
|
|
+#define R8_U2H_INT_EN (*((PUINT8V)0x40009102)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UHIE_FIFO_OVER 0x80
|
|
|
+#define USBHS_UHIE_TX_HALT 0x40
|
|
|
+#define USBHS_UHIE_SOF_ACT 0x20
|
|
|
+#define USBHS_UHIE_TRANSFER 0x10
|
|
|
+#define USBHS_UHIE_RESUME_ACT 0x08
|
|
|
+#define USBHS_UHIE_WKUP_ACT 0x04
|
|
|
+#define R8_U2H_DEV_AD (*((PUINT8V)0x40009103)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_DEV_ADDR 0xFF
|
|
|
+#define R32_U2H_CONTROL (*((PUINT32V)0x40009104)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_RX_NO_RES 0x800000
|
|
|
+#define USBHS_UH_TX_NO_RES 0x400000
|
|
|
+#define USBHS_UH_RX_NO_DATA 0x200000
|
|
|
+#define USBHS_UH_TX_NO_DATA 0x100000
|
|
|
+#define USBHS_UH_PRE_PID_EN 0x080000
|
|
|
+#define USBHS_UH_SPLIT_VALID 0x040000
|
|
|
+#define USBHS_UH_LPM_VALID 0x020000
|
|
|
+#define USBHS_UH_HOST_ACTION 0x010000
|
|
|
+#define USBHS_UH_BUF_MODE 0x0400
|
|
|
+#define USBHS_UH_T_TOG_MASK 0x0300
|
|
|
+#define USBHS_UH_T_TOG_MDATA 0x0300
|
|
|
+#define USBHS_UH_T_TOG_DATA2 0x0200
|
|
|
+#define USBHS_UH_T_TOG_DATA1 0x0100
|
|
|
+#define USBHS_UH_T_TOG_DATA0 0x0000
|
|
|
+#define USBHS_UH_T_ENDP_MASK 0xF0
|
|
|
+#define USBHS_UH_T_TOKEN_MASK 0x0F
|
|
|
+
|
|
|
+#define R8_U2H_INT_FLAG (*((PUINT8V)0x40009108)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UHIF_FIFO_OVER 0x80
|
|
|
+#define USBHS_UHIF_TX_HALT 0x40
|
|
|
+#define USBHS_UHIF_SOF_ACT 0x20
|
|
|
+#define USBHS_UHIF_TRANSFER 0x10
|
|
|
+#define USBHS_UHIF_RESUME_ACT 0x08
|
|
|
+#define USBHS_UHIF_WKUP_ACT 0x04
|
|
|
+#define R8_U2H_INT_ST (*((PUINT8V)0x40009109)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UHIF_PORT_RX_RESUME 0x10
|
|
|
+#define USBHS_UH_R_TOKEN_MASK 0x0F
|
|
|
+#define R8_U2H_MIS_ST (*((PUINT8V)0x4000910A)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UHMS_BUS_SE0 0x80
|
|
|
+#define USBHS_UHMS_BUS_J 0x40
|
|
|
+#define USBHS_UHMS_LINESTATE 0x30
|
|
|
+#define USBHS_UHMS_USB_WAKEUP 0x08
|
|
|
+#define USBHS_UHMS_SOF_ACT 0x04
|
|
|
+#define USBHS_UHMS_SOF_PRE 0x02
|
|
|
+#define USBHS_UHMS_SOF_FREE 0x01
|
|
|
+#define R32_U2H_LPM_DATA (*((PUINT32V)0x4000910C)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_LPM_DATA 0x07FF
|
|
|
+#define R32_U2H_SPLIT_DATA (*((PUINT32V)0x40009110)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_SPLIT_DATA 0x07FFFF
|
|
|
+#define R32_U2H_FRAME (*((PUINT32V)0x40009114)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_SOF_CNT_CLR 0x02000000
|
|
|
+#define USBHS_UH_SOF_CNT_EN 0x01000000
|
|
|
+#define USBHS_UH_MFRAME_NO 0x070000
|
|
|
+#define USBHS_UH_FRAME_NO 0x07FF
|
|
|
+#define R32_U2H_TX_LEN (*((PUINT32V)0x40009118)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_TX_LEN 0x07FF
|
|
|
+#define R32_U2H_RX_LEN (*((PUINT32V)0x4000911C)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_RX_LEN 0x07FF
|
|
|
+#define R32_U2H_RX_MAX_LEN (*((PUINT32V)0x40009120)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_RX_MAX_LEN 0x07FF
|
|
|
+#define R32_U2H_RX_DMA (*((PUINT32V)0x40009124)) // RW, USB_high_speed register
|
|
|
+#define USBHS_R32_UH_RX_DMA 0x01FFFF
|
|
|
+#define R32_U2H_TX_DMA (*((PUINT32V)0x40009128)) // RW, USB_high_speed register
|
|
|
+#define USBHS_R32_UH_TX_DMA 0x01FFFF
|
|
|
+#define R32_U2H_PORT_CTRL (*((PUINT32V)0x4000912C)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_BUS_RST_LONG 0x010000
|
|
|
+#define USBHS_UH_PORT_SLEEP_BESL 0xF000
|
|
|
+#define USBHS_UH_CLR_PORT_SLEEP 0x0100
|
|
|
+#define USBHS_UH_CLR_PORT_CONNECT 0x20
|
|
|
+#define USBHS_UH_CLR_PORT_EN 0x10
|
|
|
+#define USBHS_UH_SET_PORT_SLEEP 0x08
|
|
|
+#define USBHS_UH_CLR_PORT_SUSP 0x04
|
|
|
+#define USBHS_UH_SET_PORT_SUSP 0x02
|
|
|
+#define USBHS_UH_SET_PORT_RESET 0x01
|
|
|
+#define R8_U2H_PORT_CFG (*((PUINT8V)0x40009130)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_PD_EN 0x80
|
|
|
+#define USBHS_UH_HOST_EN 0x01
|
|
|
+#define R8_U2H_PORT_INT_EN (*((PUINT8V)0x40009132)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UHIE_PORT_SLP 0x20
|
|
|
+#define USBHS_UHIE_PORT_RESET 0x10
|
|
|
+#define USBHS_UHIE_PORT_SUSP 0x04
|
|
|
+#define USBHS_UHIE_PORT_EN 0x02
|
|
|
+#define USBHS_UHIE_PORT_CONNECT 0x01
|
|
|
+#define R8_U2H_PORT_TEST_CT (*((PUINT8V)0x40009133)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UH_TEST_FORCE_EN 0x04
|
|
|
+#define USBHS_UH_TEST_K 0x02
|
|
|
+#define USBHS_UH_TEST_J 0x01
|
|
|
+#define R16_U2H_PORT_ST (*((PUINT16V)0x40009134)) // RW, USB_high_speed register
|
|
|
+#define USBHS_UHIS_PORT_TEST 0x0800
|
|
|
+#define USBHS_UHIS_PORT_SPEED_MASK 0x0600
|
|
|
+#define USBHS_UHIS_PORT_HS 0x0400
|
|
|
+#define USBHS_UHIS_PORT_LS 0x0200
|
|
|
+#define USBHS_UHIS_PORT_FS 0x0000
|
|
|
+#define USBHS_UHIS_PORT_SLP 0x20
|
|
|
+#define USBHS_UHIS_PORT_RST 0x10
|
|
|
+#define USBHS_UHIS_PORT_SUSP 0x04
|
|
|
+#define USBHS_UHIS_PORT_EN 0x02
|
|
|
+#define USBHS_UHIS_PORT_CONNECT 0x01
|
|
|
+#define R8_U2H_PORT_CHG (*((PUINT8V)0x40009136))
|
|
|
+#define USBHS_UHIF_PORT_SLP 0x20
|
|
|
+#define USBHS_UHIF_PORT_RESET 0x10
|
|
|
+#define USBHS_UHIF_PORT_SUSP 0x04
|
|
|
+#define USBHS_UHIF_PORT_EN 0x02
|
|
|
+#define USBHS_UHIF_PORT_CONNECT 0x01
|
|
|
+#define R32_U2H_BC_CTRL (*((PUINT32V)0x4000913C))
|
|
|
+#define UDM_VSRC_ACT 0x0400
|
|
|
+#define UDM_BC_VSRC 0x0200
|
|
|
+#define UDP_BC_VSRC 0x0100
|
|
|
+#define BC_AUTO_MODE 0x40
|
|
|
+#define UDM_BC_CMPE 0x20
|
|
|
+#define UDP_BC_CMPE 0x10
|
|
|
+#define UDM_BC_CMPO 0x02
|
|
|
+#define UDP_BC_CMPO 0x01
|
|
|
+#define R8_USBHS_PLL_CTRL (*((PUINT8V)0x40009200))
|
|
|
+#define USBHS_PLL_EN 0x04
|
|
|
+#define USBHS_PLL_LOWPOW 0x02
|
|
|
+#define USBHS_PLL_CKSEL 0x01
|
|
|
+
|
|
|
+#define __IO volatile /* defines 'read / write' permissions */
|
|
|
+
|
|
|
+typedef struct
|
|
|
+{
|
|
|
+ __IO uint8_t CONTROL; /* 0x40009000 */
|
|
|
+ __IO uint8_t BASE_MODE; /* 0x40009001 */
|
|
|
+ __IO uint8_t INT_EN; /* 0x40009002 */
|
|
|
+ __IO uint8_t DEV_AD; /* 0x40009003 */
|
|
|
+ __IO uint8_t WAKE_CTRL; /* 0x40009004 远程唤醒寄存器 */
|
|
|
+ __IO uint8_t TEST_MODE; /* 0x40009005 测试模式寄存器 */
|
|
|
+ __IO uint16_t LPM_DATA; /* 0x40009006 */
|
|
|
+ __IO uint8_t INT_FG; /* 0x40009008 */
|
|
|
+ __IO uint8_t INT_ST; /* 0x40009009 */
|
|
|
+ __IO uint8_t MIS_ST; /* 0x4000900a */
|
|
|
+ __IO uint8_t RESERVE0; /* 0x4000900b */
|
|
|
+ __IO uint16_t FRAME_NO; /* 0x4000900c */
|
|
|
+ __IO uint16_t USB_BUS; /* 0x4000900e */
|
|
|
+ __IO uint16_t UEP_TX_EN; /* 0x40009010 */
|
|
|
+ __IO uint16_t UEP_RX_EN; /* 0x40009012 */
|
|
|
+
|
|
|
+ __IO uint16_t UEP_T_TOG_AUTO; /* 0x40009014 */
|
|
|
+ __IO uint16_t UEP_R_TOG_AUTO; /* 0x40009016 */
|
|
|
+ __IO uint8_t UEP_T_BURST; /* 0x40009018 */
|
|
|
+ __IO uint8_t UEP_T_BURST_MODE; /* 0x40009019 */
|
|
|
+ __IO uint8_t UEP_R_BURST; /* 0x4000901a */
|
|
|
+ __IO uint8_t UEP_R_RES_MODE; /* 0x4000901b */
|
|
|
+ __IO uint32_t UEP_AF_MODE; /* 0x4000901c */
|
|
|
+
|
|
|
+ __IO uint32_t UEP0_DMA; /* 0x40009020 */
|
|
|
+ __IO uint32_t UEP1_RX_DMA; /* 0x40009024 */
|
|
|
+ __IO uint32_t UEP2_RX_DMA; /* 0x40009028 */
|
|
|
+ __IO uint32_t UEP3_RX_DMA; /* 0x4000902c */
|
|
|
+ __IO uint32_t UEP4_RX_DMA; /* 0x40009030 */
|
|
|
+ __IO uint32_t UEP5_RX_DMA; /* 0x40009034 */
|
|
|
+ __IO uint32_t UEP6_RX_DMA; /* 0x40009038 */
|
|
|
+ __IO uint32_t UEP7_RX_DMA; /* 0x4000903c */
|
|
|
+
|
|
|
+ __IO uint32_t UEP1_TX_DMA; /* 0x40009040 */
|
|
|
+ __IO uint32_t UEP2_TX_DMA; /* 0x40009044 */
|
|
|
+ __IO uint32_t UEP3_TX_DMA; /* 0x40009048 */
|
|
|
+ __IO uint32_t UEP4_TX_DMA; /* 0x4000904c */
|
|
|
+ __IO uint32_t UEP5_TX_DMA; /* 0x40009050 */
|
|
|
+ __IO uint32_t UEP6_TX_DMA; /* 0x40009054 */
|
|
|
+ __IO uint32_t UEP7_TX_DMA; /* 0x40009058 */
|
|
|
+
|
|
|
+ __IO uint32_t UEP0_MAX_LEN; /* 0x4000905c */
|
|
|
+ __IO uint32_t UEP1_MAX_LEN; /* 0x40009060 */
|
|
|
+ __IO uint32_t UEP2_MAX_LEN; /* 0x40009064 */
|
|
|
+ __IO uint32_t UEP3_MAX_LEN; /* 0x40009068 */
|
|
|
+ __IO uint32_t UEP4_MAX_LEN; /* 0x4000906c */
|
|
|
+ __IO uint32_t UEP5_MAX_LEN; /* 0x40009070 */
|
|
|
+ __IO uint32_t UEP6_MAX_LEN; /* 0x40009074 */
|
|
|
+ __IO uint32_t UEP7_MAX_LEN; /* 0x40009078 */
|
|
|
+
|
|
|
+ __IO uint16_t USB_EP0_RX_LEN; /* 0x4000907c */
|
|
|
+ __IO uint16_t RESERVE1; /* 0x4000907e */
|
|
|
+ __IO uint16_t UEP1_RX_LEN; /* 0x40009080 */
|
|
|
+ __IO uint16_t UEP1_R_SIZE; /* 0x40009082 */
|
|
|
+ __IO uint16_t UEP2_RX_LEN; /* 0x40009084 */
|
|
|
+ __IO uint16_t UEP2_R_SIZE; /* 0x40009086 */
|
|
|
+ __IO uint16_t UEP3_RX_LEN; /* 0x40009088 */
|
|
|
+ __IO uint16_t UEP3_R_SIZE; /* 0x4000908a */
|
|
|
+ __IO uint16_t UEP4_RX_LEN; /* 0x4000908c */
|
|
|
+ __IO uint16_t UEP4_R_SIZE; /* 0x4000908e */
|
|
|
+ __IO uint16_t UEP5_RX_LEN; /* 0x40009090 */
|
|
|
+ __IO uint16_t UEP5_R_SIZE; /* 0x40009092 */
|
|
|
+ __IO uint16_t UEP6_RX_LEN; /* 0x40009094 */
|
|
|
+ __IO uint16_t UEP6_R_SIZE; /* 0x40009096 */
|
|
|
+ __IO uint16_t UEP7_RX_LEN; /* 0x40009098 */
|
|
|
+ __IO uint16_t UEP7_R_SIZE; /* 0x4000909a */
|
|
|
+
|
|
|
+ __IO uint16_t UEP0_TX_LEN; /* 0x4000909c */
|
|
|
+ __IO uint8_t UEP0_TX_CTRL; /* 0x4000909e */
|
|
|
+ __IO uint8_t UEP0_RX_CTRL; /* 0x4000909f */
|
|
|
+ __IO uint16_t UEP1_TX_LEN; /* 0x400090a0 */
|
|
|
+ __IO uint8_t UEP1_TX_CTRL; /* 0x400090a2 */
|
|
|
+ __IO uint8_t UEP1_RX_CTRL; /* 0x400090a3 */
|
|
|
+ __IO uint16_t UEP2_TX_LEN; /* 0x400090a4 */
|
|
|
+ __IO uint8_t UEP2_TX_CTRL; /* 0x400090a6 */
|
|
|
+ __IO uint8_t UEP2_RX_CTRL; /* 0x400090a7 */
|
|
|
+ __IO uint16_t UEP3_TX_LEN; /* 0x400090a8 */
|
|
|
+ __IO uint8_t UEP3_TX_CTRL; /* 0x400090aa */
|
|
|
+ __IO uint8_t UEP3_RX_CTRL; /* 0x400090ab */
|
|
|
+ __IO uint16_t UEP4_TX_LEN; /* 0x400090ac */
|
|
|
+ __IO uint8_t UEP4_TX_CTRL; /* 0x400090ae */
|
|
|
+ __IO uint8_t UEP4_RX_CTRL; /* 0x400090af */
|
|
|
+ __IO uint16_t UEP5_TX_LEN; /* 0x400090b0 */
|
|
|
+ __IO uint8_t UEP5_TX_CTRL; /* 0x400090b2 */
|
|
|
+ __IO uint8_t UEP5_RX_CTRL; /* 0x400090b3 */
|
|
|
+ __IO uint16_t UEP6_TX_LEN; /* 0x400090b4 */
|
|
|
+ __IO uint8_t UEP6_TX_CTRL; /* 0x400090b6 */
|
|
|
+ __IO uint8_t UEP6_RX_CTRL; /* 0x400090b7 */
|
|
|
+ __IO uint16_t UEP7_TX_LEN; /* 0x400090b8 */
|
|
|
+ __IO uint8_t UEP7_TX_CTRL; /* 0x400090ba */
|
|
|
+ __IO uint8_t UEP7_RX_CTRL; /* 0x400090bb */
|
|
|
+ __IO uint16_t UEP_TX_ISO; /* 0x400090bc */
|
|
|
+ __IO uint16_t UEP_RX_ISO; /* 0x400090be */
|
|
|
+} USBHSD_TypeDef;
|