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

📄 fw.lst

📁 usb hid 设备 来自国外网站上的
💻 LST
📖 第 1 页 / 共 2 页
字号:
C51 COMPILER V7.06   FW                                                                    03/16/2004 14:49:39 PAGE 1   


C51 COMPILER V7.06, COMPILATION OF MODULE FW
OBJECT MODULE PLACED IN fw.OBJ
COMPILER INVOKED BY: C:\Keil2\C51\BIN\C51.EXE fw.c DEBUG OBJECTEXTEND

stmt level    source

   1          //-----------------------------------------------------------------------------
   2          //   File:      fw.c
   3          //   Contents:   Firmware frameworks task dispatcher and device request parser
   4          //            source.
   5          //
   6          // indent 3.  NO TABS!
   7          //
   8          // $Revision: 1 $
   9          // $Date: 10/03/03 3:01p $
  10          //
  11          //   Copyright (c) 1997 AnchorChips, Inc. All rights reserved
  12          //-----------------------------------------------------------------------------
  13          #include "fx2.h"
  14          #include "fx2regs.h"
  15          
  16          //-----------------------------------------------------------------------------
  17          // Constants
  18          //-----------------------------------------------------------------------------
  19          #define DELAY_COUNT   0x9248*8L  // Delay for 8 sec at 24Mhz, 4 sec at 48
  20          #define _IFREQ  48000            // IFCLK constant for Synchronization Delay
  21          #define _CFREQ  48000            // CLKOUT constant for Synchronization Delay
  22          
  23          //-----------------------------------------------------------------------------
  24          // Random Macros
  25          //-----------------------------------------------------------------------------
  26          #define   min(a,b) (((a)<(b))?(a):(b))
  27          #define   max(a,b) (((a)>(b))?(a):(b))
  28          
  29            // Registers which require a synchronization delay, see section 15.14
  30            // FIFORESET        FIFOPINPOLAR
  31            // INPKTEND         OUTPKTEND
  32            // EPxBCH:L         REVCTL
  33            // GPIFTCB3         GPIFTCB2
  34            // GPIFTCB1         GPIFTCB0
  35            // EPxFIFOPFH:L     EPxAUTOINLENH:L
  36            // EPxFIFOCFG       EPxGPIFFLGSEL
  37            // PINFLAGSxx       EPxFIFOIRQ
  38            // EPxFIFOIE        GPIFIRQ
  39            // GPIFIE           GPIFADRH:L
  40            // UDMACRCH:L       EPxGPIFTRIG
  41            // GPIFTRIG
  42            
  43            // Note: The pre-REVE EPxGPIFTCH/L register are affected, as well...
  44            //      ...these have been replaced by GPIFTC[B3:B0] registers
  45            
  46          #include "fx2sdly.h"             // Define _IFREQ and _CFREQ above this #include
  47          
  48          //-----------------------------------------------------------------------------
  49          // Global Variables
  50          //-----------------------------------------------------------------------------
  51          volatile BOOL   GotSUD;
  52          BOOL      Rwuen;
  53          BOOL      Selfpwr;
  54          volatile BOOL   Sleep;                  // Sleep mode enable flag
  55          
C51 COMPILER V7.06   FW                                                                    03/16/2004 14:49:39 PAGE 2   

  56          WORD   pDeviceDscr;   // Pointer to Device Descriptor; Descriptors may be moved
  57          WORD   pDeviceQualDscr;
  58          WORD   pHighSpeedConfigDscr;
  59          WORD   pFullSpeedConfigDscr;   
  60          WORD   pConfigDscr;
  61          WORD   pOtherConfigDscr;   
  62          WORD   pStringDscr;   
  63          
  64          extern code HIDDscr;
  65          extern code REPORTDSCR ReportDscr; 
  66          extern code ReportDscrEnd;
  67          extern code StringDscr1,StringDscr2,StringDscr0;
  68          //-----------------------------------------------------------------------------
  69          // Prototypes
  70          //-----------------------------------------------------------------------------
  71          void SetupCommand(void);
  72          void TD_Init(void);
  73          void TD_Poll(void);
  74          BOOL TD_Suspend(void);
  75          BOOL TD_Resume(void);
  76          
  77          BOOL DR_GetDescriptor(void);
  78          BOOL DR_SetConfiguration(void);
  79          BOOL DR_GetConfiguration(void);
  80          BOOL DR_SetInterface(void);
  81          BOOL DR_GetInterface(void);
  82          BOOL DR_GetStatus(void);
  83          BOOL DR_ClearFeature(void);
  84          BOOL DR_SetFeature(void);
  85          BOOL DR_VendorCmnd(void);
  86          
  87          // this table is used by the epcs macro 
  88          const char code  EPCS_Offset_Lookup_Table[] =
  89          {
  90             0,    // EP1OUT
  91             1,    // EP1IN
  92             2,    // EP2OUT
  93             2,    // EP2IN
  94             3,    // EP4OUT
  95             3,    // EP4IN
  96             4,    // EP6OUT
  97             4,    // EP6IN
  98             5,    // EP8OUT
  99             5,    // EP8IN
 100          };
 101          
 102          // macro for generating the address of an endpoint's control and status register (EPnCS)
 103          #define epcs(EP) (EPCS_Offset_Lookup_Table[(EP & 0x7E) | (EP > 128)] + 0xE6A1)
 104          
 105          //-----------------------------------------------------------------------------
 106          // Code
 107          //-----------------------------------------------------------------------------
 108          
 109          // Task dispatcher
 110          void main(void)
 111          {
 112   1         DWORD   i;
 113   1         WORD   offset;
 114   1         DWORD   DevDescrLen;
 115   1         DWORD   j=0;
 116   1         WORD   IntDescrAddr;
 117   1         WORD   ExtDescrAddr;
C51 COMPILER V7.06   FW                                                                    03/16/2004 14:49:39 PAGE 3   

 118   1      
 119   1         // Initialize Global States
 120   1         Sleep = FALSE;               // Disable sleep mode
 121   1         Rwuen = FALSE;               // Disable remote wakeup
 122   1         Selfpwr = FALSE;            // Disable self powered
 123   1         GotSUD = FALSE;               // Clear "Got setup data" flag
 124   1      
 125   1         // Initialize user device
 126   1         TD_Init();
 127   1      
 128   1         // The following section of code is used to relocate the descriptor table. 
 129   1         // Since the SUDPTRH and SUDPTRL are assigned the address of the descriptor 
 130   1         // table, the descriptor table must be located in on-part memory.
 131   1         // The 4K demo tools locate all code sections in external memory.
 132   1         // The descriptor table is relocated by the frameworks ONLY if it is found 
 133   1         // to be located in external memory.
 134   1         pDeviceDscr = (WORD)&DeviceDscr;
 135   1         pDeviceQualDscr = (WORD)&DeviceQualDscr;
 136   1         pHighSpeedConfigDscr = (WORD)&HighSpeedConfigDscr;
 137   1         pFullSpeedConfigDscr = (WORD)&FullSpeedConfigDscr;
 138   1         pStringDscr = (WORD)&StringDscr;
 139   1      
 140   1         if ((WORD)&DeviceDscr & 0xe000)
 141   1         {
 142   2            IntDescrAddr = INTERNAL_DSCR_ADDR;
 143   2            ExtDescrAddr = (WORD)&DeviceDscr;
 144   2            DevDescrLen = (WORD)&UserDscr - (WORD)&DeviceDscr + 2;
 145   2            for (i = 0; i < DevDescrLen; i++)
 146   2               *((BYTE xdata *)IntDescrAddr+i) = 0xCD;
 147   2            for (i = 0; i < DevDescrLen; i++)
 148   2               *((BYTE xdata *)IntDescrAddr+i) = *((BYTE xdata *)ExtDescrAddr+i);
 149   2            pDeviceDscr = IntDescrAddr;
 150   2            offset = (WORD)&DeviceDscr - INTERNAL_DSCR_ADDR;
 151   2            pDeviceQualDscr -= offset;
 152   2            pConfigDscr -= offset;
 153   2            pOtherConfigDscr -= offset;
 154   2            pHighSpeedConfigDscr -= offset;
 155   2            pFullSpeedConfigDscr -= offset;
 156   2            pStringDscr -= offset;
 157   2         }
 158   1      
 159   1         EZUSB_IRQ_ENABLE();            // Enable USB interrupt (INT2)
 160   1         EZUSB_ENABLE_RSMIRQ();            // Wake-up interrupt
 161   1      
 162   1         INTSETUP |= (bmAV2EN | bmAV4EN);     // Enable INT 2 & 4 autovectoring
 163   1      
 164   1         USBIE |= bmSUDAV | bmSUTOK | bmSUSP | bmURES | bmHSGRANT;   // Enable selected interrupts
 165   1         EA = 1;                  // Enable 8051 interrupts
 166   1      
 167   1      #ifndef NO_RENUM
 168   1         // Renumerate if necessary.  Do this by checking the renum bit.  If it
 169   1         // is already set, there is no need to renumerate.  The renum bit will
 170   1         // already be set if this firmware was loaded from an eeprom.
 171   1         if(!(USBCS & bmRENUM))
 172   1         {
 173   2             EZUSB_Discon(TRUE);   // renumerate
 174   2         }
 175   1      #endif
 176   1      
 177   1         // unconditionally re-connect.  If we loaded from eeprom we are
 178   1         // disconnected and need to connect.  If we just renumerated this
 179   1         // is not necessary but doesn't hurt anything
C51 COMPILER V7.06   FW                                                                    03/16/2004 14:49:39 PAGE 4   

 180   1         USBCS &=~bmDISCON;
 181   1      
 182   1         CKCON = (CKCON&(~bmSTRETCH)) | FW_STRETCH_VALUE; // Set stretch to 0 (after renumeration)
 183   1      
 184   1         // clear the Sleep flag.
 185   1         Sleep = FALSE;
 186   1      
 187   1         // Task Dispatcher
 188   1         while(TRUE)               // Main Loop
 189   1         {
 190   2            if(GotSUD)            // Wait for SUDAV
 191   2            {
 192   3               SetupCommand();          // Implement setup command
 193   3                 GotSUD = FALSE;            // Clear SUDAV flag
 194   3            }
 195   2      
 196   2            // Poll User Device
 197   2            // NOTE: Idle mode stops the processor clock.  There are only two
 198   2            // ways out of idle mode, the WAKEUP pin, and detection of the USB
 199   2            // resume state on the USB bus.  The timers will stop and the
 200   2            // processor will not wake up on any other interrupts.
 201   2            if (Sleep)
 202   2                {
 203   3                if(TD_Suspend())
 204   3                    { 
 205   4                    Sleep = FALSE;            // Clear the "go to sleep" flag.  Do it here to prevent any race c
             -ondition between wakeup and the next sleep.
 206   4                    do
 207   4                        {

⌨️ 快捷键说明

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