亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? f34x_usb_isr.lst

?? C8051F340的USB開發
?? LST
?? 第 1 頁 / 共 2 頁
字號:
C51 COMPILER V7.06   F34X_USB_ISR                                                          06/07/2007 00:12:17 PAGE 1   


C51 COMPILER V7.06, COMPILATION OF MODULE F34X_USB_ISR
OBJECT MODULE PLACED IN F34x_USB_ISR.OBJ
COMPILER INVOKED BY: C:\Program Files\Keil C\C51\BIN\C51.EXE F34x_USB_ISR.c BROWSE DEBUG OBJECTEXTEND

stmt level    source

   1          //-----------------------------------------------------------------------------
   2          // F34x_USB_ISR.c
   3          //-----------------------------------------------------------------------------
   4          // Copyright 2005 Silicon Laboratories, Inc.
   5          // http://www.silabs.com
   6          //
   7          // Program Description:
   8          //
   9          // Source file for USB firmware. Includes top level ISR with Setup,
  10          // and Endpoint data handlers.  Also includes routine for USB suspend,
  11          // reset, and procedural stall.
  12          //
  13          //
  14          // How To Test:    See Readme.txt
  15          //
  16          //
  17          // FID:            34X000018
  18          // Target:         C8051F34x
  19          // Tool chain:     Keil C51 7.50 / Keil EVAL C51
  20          //                 Silicon Laboratories IDE version 2.6
  21          // Command Line:   See Readme.txt
  22          // Project Name:   F34x_USB_Interrupt
  23          //
  24          //
  25          // Release 1.0
  26          //    -Initial Revision (GP)
  27          //    -22 NOV 2005
  28          //    -Ported from 'F320_USB_Bulk
  29          //
  30          
  31          //-----------------------------------------------------------------------------
  32          // Includes
  33          //-----------------------------------------------------------------------------
  34          
  35          #include "c8051F340.h"
  36          #include "F34x_USB_Register.h"
  37          #include "F34x_USB_Main.h"
  38          #include "F34x_USB_Descriptor.h"
  39          
  40          //-----------------------------------------------------------------------------
  41          // Global Externs
  42          //-----------------------------------------------------------------------------
  43          
  44          extern idata BYTE OUT_PACKET[];
  45          extern idata BYTE IN_PACKET[];
  46          
  47          //-----------------------------------------------------------------------------
  48          // Global Variables
  49          //-----------------------------------------------------------------------------
  50          
  51          BYTE USB_State;                        // Holds the current USB State
  52                                                 // def. in F32x_USB_Main.h
  53          
  54          setup_buffer Setup;                    // Buffer for current device request
  55          
C51 COMPILER V7.06   F34X_USB_ISR                                                          06/07/2007 00:12:17 PAGE 2   

  56          unsigned int DataSize;                 // Size of data to return
  57          unsigned int DataSent;                 // Amount of data sent so far
  58          BYTE* DataPtr;                         // Pointer to data to return
  59          
  60          // Holds the status for each endpoint
  61          BYTE Ep_Status[3] = {EP_IDLE, EP_IDLE, EP_IDLE};
  62          
  63          
  64          //-----------------------------------------------------------------------------
  65          // Interrupt Service Routines
  66          //-----------------------------------------------------------------------------
  67          
  68          //-----------------------------------------------------------------------------
  69          // USB0_ISR
  70          //-----------------------------------------------------------------------------
  71          //
  72          // Called after any USB type interrupt, this handler determines which type
  73          // of interrupt occurred, and calls the specific routine to handle it.
  74          //
  75          //-----------------------------------------------------------------------------
  76          void USB0_ISR(void) interrupt 8        // Top-level USB ISR
  77          {
  78   1         BYTE bCommon, bIn, bOut;
  79   1         POLL_READ_BYTE(CMINT, bCommon);     // Read all interrupt registers
  80   1         POLL_READ_BYTE(IN1INT, bIn);        // this read also clears the register
  81   1         POLL_READ_BYTE(OUT1INT, bOut);
  82   1         {
  83   2            if (bCommon & rbRSUINT)          // Handle Resume interrupt
  84   2            {
  85   3               Usb_Resume();
  86   3            }
  87   2            if (bCommon & rbRSTINT)          // Handle Reset interrupt
  88   2            {
  89   3               Usb_Reset();
  90   3            }
  91   2            if (bIn & rbEP0)                 // Handle Setup packet received
  92   2            {                                // or packet transmitted if Endpoint 0
  93   3               Handle_Setup();               // is transmit mode
  94   3            }
  95   2            if (bIn & rbIN1)                 // Handle In Packet sent, put new data
  96   2            {                                // on endpoint 1 fifo
  97   3               Handle_In1();
  98   3            }
  99   2            if (bOut & rbOUT2)               // Handle Out packet received, take data
 100   2            {                                // off endpoint 2 fifo
 101   3               Handle_Out2();
 102   3            }
 103   2            if (bCommon & rbSUSINT)          // Handle Suspend interrupt
 104   2            {
 105   3               Usb_Suspend();
 106   3            }
 107   2         }
 108   1      }
 109          
 110          //-----------------------------------------------------------------------------
 111          // Support Routines for ISR
 112          //-----------------------------------------------------------------------------
 113          
 114          //-----------------------------------------------------------------------------
 115          // Usb_Reset
 116          //-----------------------------------------------------------------------------
 117          //
C51 COMPILER V7.06   F34X_USB_ISR                                                          06/07/2007 00:12:17 PAGE 3   

 118          // Return Value : None
 119          // Parameters   : None
 120          //
 121          // - Set state to default
 122          // - Clear Usb Inhibit bit
 123          //
 124          //-----------------------------------------------------------------------------
 125          
 126          void Usb_Reset(void)
 127          {
 128   1         USB_State = DEV_DEFAULT;            // Set device state to default
 129   1      
 130   1         POLL_WRITE_BYTE(POWER, 0x01);       // Clear usb inhibit bit to enable USB
 131   1                                             // suspend detection
 132   1      
 133   1         Ep_Status[0] = EP_IDLE;             // Set default Endpoint Status
 134   1         Ep_Status[1] = EP_HALT;
 135   1         Ep_Status[2] = EP_HALT;
 136   1      }
 137          
 138          //-----------------------------------------------------------------------------
 139          // Handle_Setup
 140          //-----------------------------------------------------------------------------
 141          //
 142          // Return Value : None
 143          // Parameters   : None
 144          //
 145          // - Decode Incoming Setup requests
 146          // - Load data packets on fifo while in transmit mode
 147          //
 148          //-----------------------------------------------------------------------------
 149          
 150          void Handle_Setup(void)
 151          {
 152   1         BYTE ControlReg,TempReg;            // Temporary storage for EP control
 153   1                                             // register
 154   1      
 155   1         POLL_WRITE_BYTE(INDEX, 0);          // Set Index to Endpoint Zero
 156   1         POLL_READ_BYTE(E0CSR, ControlReg);  // Read control register
 157   1      
 158   1         if (Ep_Status[0] == EP_ADDRESS)     // Handle Status Phase of Set Address
 159   1                                             // command
 160   1         {
 161   2            POLL_WRITE_BYTE(FADDR, Setup.wValue.c[LSB]);
 162   2            Ep_Status[0] = EP_IDLE;
 163   2         }
 164   1      
 165   1         if (ControlReg & rbSTSTL)           // If last packet was a sent stall, reset
 166   1         {                                   // STSTL bit and return EP0 to idle state
 167   2            POLL_WRITE_BYTE(E0CSR, 0);
 168   2            Ep_Status[0] = EP_IDLE;
 169   2            return;
 170   2         }
 171   1      
 172   1         if (ControlReg & rbSUEND)           // If last setup transaction was ended
 173   1         {                                   // prematurely then set
 174   2            POLL_WRITE_BYTE(E0CSR, rbDATAEND);
 175   2            POLL_WRITE_BYTE(E0CSR, rbSSUEND); // Serviced Setup End bit and return EP0
 176   2            Ep_Status[0] = EP_IDLE;          // to idle state
 177   2         }
 178   1      
 179   1         if (Ep_Status[0] == EP_IDLE)        // If Endpoint 0 is in idle mode
C51 COMPILER V7.06   F34X_USB_ISR                                                          06/07/2007 00:12:17 PAGE 4   

 180   1         {
 181   2            if (ControlReg & rbOPRDY)        // Make sure that EP 0 has an Out Packet ready from host
 182   2            {                                // although if EP0 is idle, this should always be the case
 183   3               Fifo_Read(FIFO_EP0, 8, (BYTE *)&Setup);
 184   3                                              // Get Setup Packet off of Fifo, it is currently Big-Endian
 185   3      
 186   3                                             // Compiler Specific - these next three statements swap the
 187   3                                             // bytes of the setup packet words to Big Endian so they
 188   3                                             // can be compared to other 16-bit values elsewhere properly
 189   3               Setup.wValue.i = Setup.wValue.c[MSB] + 256*Setup.wValue.c[LSB];
 190   3               Setup.wIndex.i = Setup.wIndex.c[MSB] + 256*Setup.wIndex.c[LSB];
 191   3               Setup.wLength.i = Setup.wLength.c[MSB] + 256*Setup.wLength.c[LSB];
 192   3      
 193   3      
 194   3               switch(Setup.bRequest)        // Call correct subroutine to handle each kind of
 195   3               {                             // standard request
 196   4                  case GET_STATUS:
 197   4                     Get_Status();
 198   4                     break;
 199   4                  case CLEAR_FEATURE:
 200   4                     Clear_Feature();
 201   4                     break;
 202   4                  case SET_FEATURE:
 203   4                     Set_Feature();
 204   4                     break;
 205   4                  case SET_ADDRESS:
 206   4                     Set_Address();
 207   4                     break;
 208   4                  case GET_DESCRIPTOR:
 209   4                     Get_Descriptor();
 210   4                     break;
 211   4                  case GET_CONFIGURATION:
 212   4                     Get_Configuration();
 213   4                     break;
 214   4                  case SET_CONFIGURATION:
 215   4                     Set_Configuration();
 216   4                     break;
 217   4                  case GET_INTERFACE:
 218   4                     Get_Interface();
 219   4                     break;
 220   4                  case SET_INTERFACE:
 221   4                     Set_Interface();
 222   4                     break;
 223   4                  default:
 224   4                     Force_Stall();          // Send stall to host if invalid request
 225   4                     break;
 226   4               }
 227   3            }
 228   2         }
 229   1      
 230   1         if (Ep_Status[0] == EP_TX)          // See if the endpoint has data to transmit to host
 231   1         {
 232   2            if (!(ControlReg & rbINPRDY))    // Make sure you don't overwrite last packet
 233   2            {
 234   3                                             // Endpoint 0 transmit mode
 235   3               
 236   3               POLL_READ_BYTE(E0CSR, ControlReg);
 237   3                                             // Read control register
 238   3      
 239   3               if ((!(ControlReg & rbSUEND)) || (!(ControlReg & rbOPRDY)))
 240   3                                             // Check to see if Setup End or Out Packet received, if so
 241   3                                             // do not put any new data on FIFO
C51 COMPILER V7.06   F34X_USB_ISR                                                          06/07/2007 00:12:17 PAGE 5   

 242   3               {
 243   4                  TempReg = rbINPRDY;        // Add In Packet ready flag to E0CSR bitmask
 244   4      
 245   4                                             // Break Data into multiple packets if larger than Max Packet
 246   4                  if (DataSize >= EP0_PACKET_SIZE)
 247   4                  {
 248   5                     Fifo_Write(FIFO_EP0, EP0_PACKET_SIZE, (BYTE *)DataPtr);// Put Data on Fifo
 249   5                     DataPtr  += EP0_PACKET_SIZE;                           // Advance data pointer
 250   5                     DataSize -= EP0_PACKET_SIZE;                           // Decrement data size
 251   5                     DataSent += EP0_PACKET_SIZE;                           // Increment data sent counter
 252   5                  }
 253   4                  else                       // If data is less than Max Packet size or zero
 254   4                  {
 255   5                     Fifo_Write(FIFO_EP0, DataSize, (BYTE *)DataPtr);       // Put Data on Fifo
 256   5                     TempReg |= rbDATAEND;                                  // Add Data End bit to bitmask
 257   5                     Ep_Status[0] = EP_IDLE;                                // Return EP 0 to idle state
 258   5                  }
 259   4                  if (DataSent == Setup.wLength.i)
 260   4                                              // This case exists when the host requests an even multiple of
 261   4                                              // your endpoint zero max packet size, and you need to exit
 262   4                                              // transmit mode without sending a zero length packet

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产99久久久国产精品潘金网站| 在线观看日韩精品| 91视频免费观看| 日韩欧美中文一区二区| 综合在线观看色| 麻豆高清免费国产一区| 色伊人久久综合中文字幕| 日韩精品中文字幕在线一区| 亚洲另类在线视频| 国产一区二区三区四| 欧美日韩一卡二卡| 中文字幕一区在线观看| 黄色日韩网站视频| 69av一区二区三区| 国产精品麻豆欧美日韩ww| 九九视频精品免费| 欧美亚洲综合网| 亚洲免费高清视频在线| 国产凹凸在线观看一区二区| 日韩美女视频在线| 天天av天天翘天天综合网| 91国偷自产一区二区使用方法| 久久精品日产第一区二区三区高清版| 美腿丝袜亚洲色图| 欧美精品在线观看一区二区| 亚洲国产精品欧美一二99| 91色porny蝌蚪| 中文字幕亚洲综合久久菠萝蜜| 国产精品亚洲一区二区三区在线 | 亚洲欧美日韩国产手机在线 | 午夜精品久久久久久久99樱桃| 成人av免费在线| 欧美国产日韩精品免费观看| 成人午夜精品一区二区三区| 国产午夜精品久久久久久免费视| 国模套图日韩精品一区二区 | 狠狠色丁香婷综合久久| 精品91自产拍在线观看一区| 免费欧美在线视频| 欧美videossexotv100| 久久精品国产精品亚洲综合| 7777精品伊人久久久大香线蕉 | 成人午夜电影小说| 中文字幕一区在线观看| 一本久久精品一区二区| 亚洲激情综合网| 欧美日韩精品一区二区三区蜜桃 | 久久精品视频一区| 高清日韩电视剧大全免费| 中文字幕色av一区二区三区| 色婷婷激情久久| 午夜影视日本亚洲欧洲精品| 日韩三级高清在线| 精品一二三四区| 国产欧美精品一区二区色综合朱莉| 国产成人免费在线观看| 国产精品欧美综合在线| 色诱视频网站一区| 日韩国产欧美在线观看| 精品动漫一区二区三区在线观看| 国产福利一区二区三区视频| 亚洲免费观看高清完整版在线观看| 欧美亚洲一区二区在线| 久久国产尿小便嘘嘘| 久久久av毛片精品| 91精品1区2区| 久久精品国产亚洲5555| 亚洲欧洲精品一区二区三区 | 亚洲影院久久精品| 欧美zozozo| 99精品桃花视频在线观看| 五月天网站亚洲| 久久久久久久久久久久电影| 一本色道久久综合亚洲aⅴ蜜桃| 日韩福利视频导航| 中文字幕一区二区在线播放 | 久久尤物电影视频在线观看| 99re热视频这里只精品| 日韩二区三区在线观看| 亚洲欧洲日韩在线| 日韩午夜小视频| 91丨九色丨蝌蚪富婆spa| 免费在线观看视频一区| 综合色中文字幕| 91精品国产综合久久久久久久| 国产成人av一区二区三区在线| 亚洲妇熟xx妇色黄| 欧美国产精品中文字幕| 欧美一级专区免费大片| 色噜噜狠狠成人中文综合| 国产精品一区在线| 日韩成人伦理电影在线观看| 亚洲精品自拍动漫在线| 国产欧美一区二区在线观看| 7777精品久久久大香线蕉| 在线观看视频欧美| 成人精品一区二区三区四区| 久久激情五月激情| 天堂久久久久va久久久久| 亚洲综合色网站| 国产精品国产馆在线真实露脸| 精品电影一区二区| 日韩欧美中文字幕精品| 在线播放中文字幕一区| 欧美午夜精品久久久久久孕妇| 播五月开心婷婷综合| 国产原创一区二区三区| 久久99蜜桃精品| 久久99精品久久只有精品| 视频一区二区三区中文字幕| 午夜日韩在线观看| 亚洲v日本v欧美v久久精品| 亚洲欧美激情插| 中文字幕在线观看不卡视频| 中文字幕免费不卡在线| 国产精品欧美久久久久无广告| 国产亚洲成av人在线观看导航| 精品欧美一区二区在线观看| 欧美一区二区三区视频在线| 91精品国产福利| 日韩一卡二卡三卡国产欧美| 精品少妇一区二区三区视频免付费| 欧美乱熟臀69xxxxxx| 欧美久久久久中文字幕| 日韩一区二区三区在线视频| 日韩欧美国产综合一区| 日韩欧美综合在线| 欧美不卡视频一区| 国产欧美日韩亚州综合| 国产精品的网站| 一区二区三区在线视频免费| 亚洲欧美另类综合偷拍| 亚洲国产精品久久人人爱| 日本最新不卡在线| 国产麻豆视频一区| 成人av电影免费观看| 色婷婷狠狠综合| 欧美美女激情18p| 精品日韩欧美在线| 中文无字幕一区二区三区 | 日本久久精品电影| 欧美人伦禁忌dvd放荡欲情| 欧美大黄免费观看| 亚洲欧洲在线观看av| 亚洲午夜精品一区二区三区他趣| 日韩国产一区二| 成人激情综合网站| 欧美天堂一区二区三区| 精品久久人人做人人爽| 亚洲欧洲精品一区二区三区 | 亚洲一区二区偷拍精品| 麻豆精品一二三| 99re66热这里只有精品3直播 | 日韩女优视频免费观看| 国产精品毛片无遮挡高清| 午夜av电影一区| 成人久久久精品乱码一区二区三区| 欧美亚洲综合一区| 国产情人综合久久777777| 亚洲综合自拍偷拍| 国产一区二区三区日韩| 91久久精品一区二区三| 久久久亚洲高清| 五月婷婷欧美视频| av亚洲产国偷v产偷v自拍| 日韩免费观看高清完整版| 亚洲视频一区二区在线| 精品亚洲成a人| 欧美亚洲图片小说| 国产精品色在线| 日本网站在线观看一区二区三区| 99久久99久久综合| 久久先锋影音av| 日韩精品1区2区3区| 色综合色狠狠综合色| 国产无人区一区二区三区| 琪琪一区二区三区| 在线视频观看一区| 欧美高清在线精品一区| 久久99久久久欧美国产| 欧美日韩在线播放三区| 18成人在线视频| 成人h动漫精品一区二区| 精品美女一区二区| 日韩国产在线观看一区| 欧美在线观看一区二区| 国产精品成人一区二区艾草 | 婷婷丁香久久五月婷婷| a在线欧美一区| 中文字幕乱码一区二区免费| 精品写真视频在线观看| 7878成人国产在线观看| 亚洲在线观看免费| 色综合久久88色综合天天6| 国产精品九色蝌蚪自拍| voyeur盗摄精品| 国产精品私房写真福利视频| 国产不卡在线一区| 久久久久久99精品| 岛国精品一区二区|