aboutsummaryrefslogtreecommitdiff
path: root/AT91SAM7S256/Source/d_usb.r
blob: 6c7a0c387b18dc78f4ae683bd541cab06978cc3d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
//
// Programmer
//
// Date init       14.12.2004
//
// Reviser         $Author:: Dkandlun                                        $
//
// Revision date   $Date:: 14-11-07 12:40                                    $
//
// Filename        $Workfile:: d_usb.r                                       $
//
// Version         $Revision:: 1                                             $
//
// Archive         $Archive:: /LMS2006/Sys01/Main_V02/Firmware/Source/d_usb. $
//
// Platform        C
//

#ifdef    SAM7S256

#ifdef    PROTOTYPE_PCB_3
#define   ENABLEUsbPU   *AT91C_PIOA_PER   = AT91C_PIO_PA16;     /* PIO allowed to control bit 16 */\
                        *AT91C_PIOA_OER   = AT91C_PIO_PA16;     /* Output pin 16 enabled */\
                        *AT91C_PIOA_SODR  = AT91C_PIO_PA16      /* Pin 16 set = enable USB pull-up */
#endif

#ifdef    PROTOTYPE_PCB_4
#define   ENABLEUsbPU   *AT91C_PIOA_PER   = AT91C_PIO_PA16;     /* PIO allowed to control bit 16 */\
                        *AT91C_PIOA_OER   = AT91C_PIO_PA16;     /* Output pin 16 enabled */\
                        *AT91C_PIOA_CODR  = AT91C_PIO_PA16      /* Pin 16 clear = enable USB pull-up */

#define   DISABLEUsbPU  *AT91C_PIOA_PER   = AT91C_PIO_PA16;     /* PIO allowed to control bit 16 */\
                        *AT91C_PIOA_OER   = AT91C_PIO_PA16;     /* Output pin 16 enabled */\
                        *AT91C_PIOA_SODR  = AT91C_PIO_PA16      /* Pin 16 set = disable USB pull-up */
#endif


#define   USBHwInit     *AT91C_CKGR_PLLR |= AT91C_CKGR_USBDIV_1;    /* Set the PLL USB Divider (96MHz/2) */\
                        *AT91C_PMC_SCER = AT91C_PMC_UDP;            /* WRITE-ONLY REG! Enables the 48MHz USB clock UDPCK (SysClk) */\
                        *AT91C_PMC_PCER = (1 << AT91C_ID_UDP);      /* WRITE-ONLY REG! Enable USB clock (Peripheral Clock) */\
                        \
                        /* Enable UDP PullUp (USB_DP_PUP) : enable & Clear of the corresponding PIO */  \
                        \
                        /* Removed 22022006 14:20 pc ENABLEUsbPU BlueCore delay , No pull up before OK serial-no rec. from B.C.*/


static    ULONG         USBTimeOut;

#define   USBTimedOut   (USB_TIMEOUT < ((((*AT91C_PITC_PIIR) & AT91C_PITC_CPIV) - USBTimeOut) & AT91C_PITC_CPIV))

#define   USBGetActualTime  USBTimeOut = ((*AT91C_PITC_PIIR) & AT91C_PITC_CPIV)

#define   USBReadADCValue(ADValue)  *ADValue = *AT91C_ADC_CDR4	

#define   USBExit

#define   USBDisconnect   DISABLEUsbPU

#define   USBConnect      ENABLEUsbPU

#endif

#ifdef    PCWIN

#endif