BOOTLOADER
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros
2440usb.h
Go to the documentation of this file.
1 /*********************************************
2  NAME: 2440usb.h
3  DESC:
4  HISTORY:
5  03.23.2002:purnnamu: first release for 2410
6  *********************************************/
7 #ifndef __24XUSB_H__
8 #define __24XUSB_H__
9 
10 #include "2440addr.h"
11 
12 
13 //*************************************************************************
14 // USB definitons
15 //*************************************************************************
16 
17 /* Power Management Register */
18 #define DISABLE_SUSPEND 0x00
19 #define ENABLE_SUSPEND 0x01
20 #define SUSPEND_MODE 0x02
21 #define MCU_RESUME 0x04
22 #define ISO_UPDATE (1<<7)
23 
24 /* MAXP Register */
25 #define FIFO_SIZE_0 0x00 /* 0x00 * 8 = 0 */
26 #define FIFO_SIZE_8 0x01 /* 0x01 * 8 = 8 */
27 #define FIFO_SIZE_16 0x02 /* 0x02 * 8 = 16 */
28 #define FIFO_SIZE_32 0x04 /* 0x04 * 8 = 32 */
29 #define FIFO_SIZE_64 0x08 /* 0x08 * 8 = 64 */
30 
31 /* ENDPOINT0 CSR (Control Status Register) : Mapped to IN CSR1 */
32 #define EP0_OUT_PKT_READY 0x01 /* USB sets, MCU clears by setting SERVICED_OUT_PKT_RDY */
33 #define EP0_IN_PKT_READY 0x02 /* MCU sets, USB clears after sending FIFO */
34 #define EP0_SENT_STALL 0x04 /* USB sets */
35 #define EP0_DATA_END 0x08 /* MCU sets */
36 #define EP0_SETUP_END 0x10 /* USB sets, MCU clears by setting SERVICED_SETUP_END */
37 #define EP0_SEND_STALL 0x20 /* MCU sets */
38 #define EP0_SERVICED_OUT_PKT_RDY 0x40 /* MCU writes 1 to clear OUT_PKT_READY */
39 #define EP0_SERVICED_SETUP_END 0x80 /* MCU writes 1 to clear SETUP_END */
40 
41 #define EP0_WR_BITS 0xc0
42 
43 //EP_INT_REG / EP_INT_EN_REG
44 #define EP0_INT 0x01 // Endpoint 0, Control
45 #define EP1_INT 0x02 // Endpoint 1, (Bulk-In)
46 #define EP2_INT 0x04 // Endpoint 2
47 #define EP3_INT 0x08 // Endpoint 3, (Bulk-Out)
48 #define EP4_INT 0x10 // Endpoint 4
49 
50 //USB_INT_REG / USB_INT_EN_REG
51 #define SUSPEND_INT 0x01
52 #define RESUME_INT 0x02
53 #define RESET_INT 0x04
54 
55 //IN_CSR1
56 #define EPI_IN_PKT_READY 0x01
57 #define EPI_UNDER_RUN 0x04
58 #define EPI_FIFO_FLUSH 0x08
59 #define EPI_SEND_STALL 0x10
60 #define EPI_SENT_STALL 0x20
61 #define EPI_CDT 0x40
62 #define EPI_WR_BITS (EPI_FIFO_FLUSH|EPI_IN_PKT_READY|EPI_CDT)
63  //(EPI_FIFO_FLUSH) is preferred (???)
64 //IN_CSR2
65 #define EPI_IN_DMA_INT_MASK (1<<4)
66 #define EPI_MODE_IN (1<<5)
67 #define EPI_MODE_OUT (0<<5)
68 #define EPI_ISO (1<<6)
69 #define EPI_BULK (0<<6)
70 #define EPI_AUTO_SET (1<<7)
71 
72 //OUT_CSR1
73 #define EPO_OUT_PKT_READY 0x01
74 #define EPO_OVER_RUN 0x04
75 #define EPO_DATA_ERROR 0x08
76 #define EPO_FIFO_FLUSH 0x10
77 #define EPO_SEND_STALL 0x20
78 #define EPO_SENT_STALL 0x40
79 #define EPO_CDT 0x80
80 #define EPO_WR_BITS (EPO_FIFO_FLUSH|EPO_SEND_STALL|EPO_CDT)
81  //(EPO_FIFO_FLUSH) is preferred (???)
82 
83 //OUT_CSR2
84 #define EPO_OUT_DMA_INT_MASK (1<<5)
85 #define EPO_ISO (1<<6)
86 #define EPO_BULK (0<<6)
87 #define EPO_AUTO_CLR (1<<7)
88 
89 //USB DMA control register
90 #define UDMA_IN_RUN_OB (1<<7)
91 #define UDMA_IGNORE_TTC (1<<7)
92 #define UDMA_DEMAND_MODE (1<<3)
93 #define UDMA_OUT_RUN_OB (1<<2)
94 #define UDMA_OUT_DMA_RUN (1<<2)
95 #define UDMA_IN_DMA_RUN (1<<1)
96 #define UDMA_DMA_MODE_EN (1<<0)
97 
98 #define rEP1_DMA_TTC (rEP1_DMA_TTC_L+(rEP1_DMA_TTC_M<<8)+(rEP1_DMA_TTC_H<<16))
99 #define rEP2_DMA_TTC (rEP2_DMA_TTC_L+(rEP2_DMA_TTC_M<<8)+(rEP2_DMA_TTC_H<<16))
100 #define rEP3_DMA_TTC (rEP3_DMA_TTC_L+(rEP3_DMA_TTC_M<<8)+(rEP3_DMA_TTC_H<<16))
101 #define rEP4_DMA_TTC (rEP4_DMA_TTC_L+(rEP4_DMA_TTC_M<<8)+(rEP4_DMA_TTC_H<<16))
102 
103 #define ADDR_EP0_FIFO (0x520001c0) //Endpoint 0 FIFO
104 #define ADDR_EP1_FIFO (0x520001c4) //Endpoint 1 FIFO
105 #define ADDR_EP2_FIFO (0x520001c8) //Endpoint 2 FIFO
106 #define ADDR_EP3_FIFO (0x520001cc) //Endpoint 3 FIFO
107 #define ADDR_EP4_FIFO (0x520001d0) //Endpoint 4 FIFO
108 
109 //If you chane the packet size, the source code should be changed!!!
110 #define EP0_PKT_SIZE 8
111 #define EP1_PKT_SIZE BULK_PKT_SIZE
112 #define EP3_PKT_SIZE BULK_PKT_SIZE
113 
114 #endif //__24XUSB_H__