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

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

?? fw.lst

?? FX2-HID--KeyBoard 對于FX2系列實現HID鍵盤的控制
?? LST
?? 第 1 頁 / 共 2 頁
字號:
 208   5                          EZUSB_Susp();         // Place processor in idle mode.
 209   5                        }
 210   4                      while(!Rwuen && EZUSB_EXTWAKEUP());
 211   4                      // Must continue to go back into suspend if the host has disabled remote wakeup
 212   4                      // *and* the wakeup was caused by the external wakeup pin.
 213   4                      
 214   4                   // 8051 activity will resume here due to USB bus or Wakeup# pin activity.
 215   4                   EZUSB_Resume();   // If source is the Wakeup# pin, signal the host to Resume.      
 216   4                   TD_Resume();
 217   4                    }   
 218   3                }
 219   2            TD_Poll();
 220   2         }
 221   1      }
 222          
 223          // Device request parser
 224          void SetupCommand(void)
 225          {
 226   1         
 227   1         unsigned int i, j,ReportLength;
 228   1      
 229   1         switch(SETUPDAT[1])
 230   1         {
 231   2            case SC_GET_DESCRIPTOR:                  // *** Get Descriptor
 232   2               if(DR_GetDescriptor())
 233   2                  switch(SETUPDAT[3])         
 234   2                  {
 235   3                     case GD_DEVICE:            // Device
 236   3                        SUDPTRH = MSB(pDeviceDscr);
 237   3                        SUDPTRL = LSB(pDeviceDscr);
 238   3                        break;
 239   3                    // case GD_DEVICE_QUALIFIER:            // Device Qualifier
 240   3                    //    SUDPTRH = MSB(pDeviceQualDscr);
C51 COMPILER V7.50   FW                                                                    05/27/2006 13:40:48 PAGE 5   

 241   3                    //    SUDPTRL = LSB(pDeviceQualDscr);
 242   3                    //    break;
 243   3                     case GD_CONFIGURATION:         // Configuration
 244   3                        SUDPTRH = MSB(pConfigDscr);
 245   3                        SUDPTRL = LSB(pConfigDscr);
 246   3                        break;
 247   3        //             case GD_OTHER_SPEED_CONFIGURATION:  // Other Speed Configuration
 248   3        //                SUDPTRH = MSB(pOtherConfigDscr);
 249   3         //               SUDPTRL = LSB(pOtherConfigDscr);
 250   3       //                 break;
 251   3                     case GD_STRING:                          // String
 252   3                                              switch(SETUPDAT[2])                     // switch on wValueL
 253   3                                              {
 254   4                                                      case 0:                                 // String index 1
 255   4                                                              SUDPTRH = MSB(&StringDscr0);
 256   4                                                              SUDPTRL = LSB(&StringDscr0);
 257   4                                                      break;
 258   4                                                      case 1:                                 // String index 1
 259   4                                                              SUDPTRH = MSB(&StringDscr1);
 260   4                                                              SUDPTRL = LSB(&StringDscr1);
 261   4                                                      break;
 262   4                                                      case 2:                                 // String index 2
 263   4                                                              SUDPTRH = MSB(&StringDscr2);
 264   4                                                              SUDPTRL = LSB(&StringDscr2);
 265   4                                                      break;
 266   4      
 267   4                                                      default:                                // Invalid string index requested
 268   4                                                              EZUSB_STALL_EP0();
 269   4                                      } 
 270   3      
 271   3                                      break;
 272   3                                      case GD_HID:                                    // Get-Descriptor: HID
 273   3                                              SUDPTRH = MSB(&HIDDscr);
 274   3                                              SUDPTRL = LSB(&HIDDscr);
 275   3                                      break;
 276   3                                      case GD_REPORT:                                 // Get-Descriptor: Report
 277   3                                      
 278   3                                      //A HID report does not have a length field which the SIE can read 
 279   3                                      //to determine how many bytes to send using the Setup Data Pointer. 
 280   3                                      //Hence we need to 'manually' send the data.
 281   3          
 282   3                                      ReportLength = (WORD)&ReportDscrEnd - (WORD)&ReportDscr;        
 283   3                                      AUTOPTR1H = MSB(&ReportDscr);
 284   3                                      AUTOPTR1L = LSB(&ReportDscr);
 285   3                                      while(ReportLength)
 286   3                                      {
 287   4                                              j = min(ReportLength,64);               // smaller of ReportSize or IN0 Buffer (64 bytes)
 288   4                                              for(i=0;i<j;i++)
 289   4                                                      EP0BUF[i]=XAUTODAT1;
 290   4                                              EP0BCH = 0;
 291   4                          SYNCDELAY;
 292   4                                              EP0BCL =  j;                                    // arm the IN transfer
 293   4                          SYNCDELAY;
 294   4                                              ReportLength = ReportLength-j;
 295   4                                              while(EP0CS & bmBIT1);          // wait for it to go out and get ACK'd
 296   4                                      }
 297   3      
 298   3                                      break;
 299   3                      default:            // Invalid request
 300   3                        EZUSB_STALL_EP0();      // Stall End Point 0
 301   3                  }
 302   2               break;
C51 COMPILER V7.50   FW                                                                    05/27/2006 13:40:48 PAGE 6   

 303   2            case SC_GET_INTERFACE:                  // *** Get Interface
 304   2               DR_GetInterface();
 305   2               break;
 306   2            case SC_SET_INTERFACE:                  // *** Set Interface
 307   2               DR_SetInterface();
 308   2               break;
 309   2            case SC_SET_CONFIGURATION:               // *** Set Configuration
 310   2               DR_SetConfiguration();
 311   2               break;
 312   2            case SC_GET_CONFIGURATION:               // *** Get Configuration
 313   2               DR_GetConfiguration();
 314   2               break;
 315   2            case SC_GET_STATUS:                  // *** Get Status
 316   2               if(DR_GetStatus())
 317   2                  switch(SETUPDAT[0])
 318   2                  {
 319   3                     case GS_DEVICE:            // Device
 320   3                        EP0BUF[0] = ((BYTE)Rwuen << 1) | (BYTE)Selfpwr;
 321   3                        EP0BUF[1] = 0;
 322   3                        EP0BCH = 0;
 323   3                        EP0BCL = 2;
 324   3                        break;
 325   3                     case GS_INTERFACE:         // Interface
 326   3                        EP0BUF[0] = 0;
 327   3                        EP0BUF[1] = 0;
 328   3                        EP0BCH = 0;
 329   3                        EP0BCL = 2;
 330   3                        break;
 331   3                     case GS_ENDPOINT:         // End Point
 332   3                        EP0BUF[0] = *(BYTE xdata *) epcs(SETUPDAT[4]) & bmEPSTALL;
 333   3                        EP0BUF[1] = 0;
 334   3                        EP0BCH = 0;
 335   3                        EP0BCL = 2;
 336   3                        break;
 337   3                     default:            // Invalid Command
 338   3                        EZUSB_STALL_EP0();      // Stall End Point 0
 339   3                  }
 340   2               break;
 341   2            case SC_CLEAR_FEATURE:                  // *** Clear Feature
 342   2               if(DR_ClearFeature())
 343   2                  switch(SETUPDAT[0])
 344   2                  {
 345   3                     case FT_DEVICE:            // Device
 346   3                        if(SETUPDAT[2] == 1)
 347   3                           Rwuen = FALSE;       // Disable Remote Wakeup
 348   3                        else
 349   3                           EZUSB_STALL_EP0();   // Stall End Point 0
 350   3                        break;
 351   3                     case FT_ENDPOINT:         // End Point
 352   3                        
 353   3                                      switch (SETUPDAT[2]) 
 354   3                                              {
 355   4                                                          case 0x00:     //EP0        
 356   4                                                                       *(BYTE xdata *) epcs(SETUPDAT[4]) &= ~bmEPSTALL;
 357   4                                               EZUSB_RESET_DATA_TOGGLE( SETUPDAT[4] );
 358   4                                                                       break;
 359   4                                                          case 0x80:     //EP0 In
 360   4                                      EP0CS &= ~bmEPSTALL;
 361   4                                      break;
 362   4                                  case 0x81:     //EP1 In
 363   4                                      EP1INCS &= ~bmEPSTALL;
 364   4                                      break;
C51 COMPILER V7.50   FW                                                                    05/27/2006 13:40:48 PAGE 7   

 365   4                                                              default:
 366   4                                                                   EZUSB_STALL_EP0();   // Stall End Point 0
 367   4                                           }   
 368   3                                    break;
 369   3                  }
 370   2               break;
 371   2            case SC_SET_FEATURE:                  // *** Set Feature
 372   2               if(DR_SetFeature())
 373   2                  switch(SETUPDAT[0])
 374   2                  {
 375   3                     case FT_DEVICE:            // Device
 376   3                        if(SETUPDAT[2] == 1)
 377   3                           Rwuen = TRUE;      // Enable Remote Wakeup
 378   3                        else if(SETUPDAT[2] == 2)
 379   3                           // Set Feature Test Mode.  The core handles this request.  However, it is
 380   3                           // necessary for the firmware to complete the handshake phase of the
 381   3                           // control transfer before the chip will enter test mode.  It is also
 382   3                           // necessary for FX2 to be physically disconnected (D+ and D-)
 383   3                           // from the host before it will enter test mode.
 384   3                           break;
 385   3                        else
 386   3                           EZUSB_STALL_EP0();   // Stall End Point 0
 387   3                        break;
 388   3                     case FT_ENDPOINT:         // End Point
 389   3                        *(BYTE xdata *) epcs(SETUPDAT[4]) |= bmEPSTALL;
 390   3                        break;
 391   3                  }
 392   2               break;
 393   2            default:                     // *** Invalid Command
 394   2               if(DR_VendorCmnd())
 395   2                  EZUSB_STALL_EP0();            // Stall End Point 0
 396   2         }
 397   1      
 398   1         // Acknowledge handshake phase of device request
 399   1         EP0CS |= bmHSNAK;
 400   1      }
 401          
 402          // Wake-up interrupt handler
 403          void resume_isr(void) interrupt WKUP_VECT
 404          {
 405   1         EZUSB_CLEAR_RSMIRQ();
 406   1      }
 407          
 408          


MODULE INFORMATION:   STATIC OVERLAYABLE
   CODE SIZE        =   1091    ----
   CONSTANT SIZE    =     10    ----
   XDATA SIZE       =   ----    ----
   PDATA SIZE       =   ----    ----
   DATA SIZE        =      6      18
   IDATA SIZE       =   ----    ----
   BIT SIZE         =      4    ----
END OF MODULE INFORMATION.


C51 COMPILATION COMPLETE.  0 WARNING(S),  0 ERROR(S)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色老汉一区二区三区| 国产精品你懂的在线欣赏| 精品国产乱码久久久久久牛牛| 久久久久久电影| 亚洲3atv精品一区二区三区| 国产精品一区二区三区99| 欧美性欧美巨大黑白大战| 国产日韩欧美综合在线| 日本在线观看不卡视频| 在线视频一区二区免费| 国产精品久久久久久久第一福利| 天天av天天翘天天综合网| 不卡的电视剧免费网站有什么| 欧美一区二区三区播放老司机| 亚洲视频免费在线| 国产呦萝稀缺另类资源| 在线不卡a资源高清| 一区二区三区四区中文字幕| 国产69精品久久久久毛片| 日韩精品一区二区三区在线播放 | 亚洲第一在线综合网站| 国产精品一区免费在线观看| 日韩一级片网址| 丝袜美腿成人在线| 欧美视频中文一区二区三区在线观看| 国产精品久久久久精k8| 国产精品一区2区| 欧美精品一区二区三| 免费在线成人网| 欧美一区二区三区爱爱| 日本欧美大码aⅴ在线播放| 欧美另类久久久品| 亚洲午夜免费视频| 在线观看视频一区二区欧美日韩| 国产精品久久久久四虎| 99视频在线观看一区三区| 欧美高清在线一区| 成人的网站免费观看| 国产精品素人视频| 99精品欧美一区二区三区综合在线| 欧美国产日韩a欧美在线观看 | 欧美一区二区视频在线观看2022| 一区二区三区日本| 在线亚洲人成电影网站色www| 亚洲人被黑人高潮完整版| 99精品国产热久久91蜜凸| 国产精品久久毛片av大全日韩| a美女胸又www黄视频久久| **性色生活片久久毛片| 色婷婷久久久亚洲一区二区三区| 亚洲免费在线电影| 欧美日韩一区二区三区高清| 亚洲国产视频直播| 91麻豆精品国产91久久久久久久久| 天堂影院一区二区| 久久综合色综合88| 91丝袜呻吟高潮美腿白嫩在线观看| 亚洲日本一区二区三区| 欧美三级资源在线| 精品亚洲国内自在自线福利| 久久综合九色综合欧美就去吻| 国产激情91久久精品导航| 中文字幕一区二区在线观看| 欧美性猛交xxxxxx富婆| 麻豆精品一区二区综合av| 久久综合狠狠综合久久激情| www.99精品| 首页亚洲欧美制服丝腿| 国产亚洲欧美一区在线观看| 色综合一个色综合亚洲| 日韩在线卡一卡二| 国产精品污污网站在线观看| 欧美中文字幕一区| 久久99精品久久久| 亚洲男同性恋视频| 日韩久久免费av| 色综合久久综合中文综合网| 男人的j进女人的j一区| 1024精品合集| 精品免费一区二区三区| 在线观看精品一区| 国产精品中文字幕日韩精品| 亚洲综合激情另类小说区| 亚洲精品一区二区三区蜜桃下载| 日本高清不卡在线观看| 国产一区二区福利视频| 亚欧色一区w666天堂| 欧美极品少妇xxxxⅹ高跟鞋| 91麻豆精品国产91久久久久久久久 | 国产精品看片你懂得| 91麻豆精品国产无毒不卡在线观看| 国产精品18久久久久久久久久久久 | 99久久国产综合精品女不卡| 免费高清在线视频一区·| 中文字幕一区二区三区不卡在线| 欧美一区二区视频在线观看2022| 色婷婷久久久综合中文字幕| 懂色av噜噜一区二区三区av| 免费成人av资源网| 亚洲高清三级视频| 亚洲欧洲色图综合| 国产日产欧美一区二区视频| 91精品国产色综合久久ai换脸| 一本久久精品一区二区| 成人h动漫精品| 国产传媒欧美日韩成人| 美国三级日本三级久久99| 亚洲成人精品影院| 一区二区免费在线| 亚洲精品美国一| 亚洲日本韩国一区| 亚洲天堂免费看| 国产精品成人免费在线| 中文在线资源观看网站视频免费不卡| 日韩精品专区在线影院观看| 6080日韩午夜伦伦午夜伦| 欧美精品一二三区| 欧美另类z0zxhd电影| 欧美精品在线视频| 69久久夜色精品国产69蝌蚪网| 日韩三级视频在线观看| 欧美精品久久久久久久多人混战| 欧美午夜精品电影| 欧美精三区欧美精三区| 337p亚洲精品色噜噜| 欧美一级淫片007| 欧美一二三区在线观看| 日韩一级片在线播放| 2欧美一区二区三区在线观看视频| 日韩欧美国产午夜精品| 精品国产一区二区三区不卡| 精品国产青草久久久久福利| 久久久久久亚洲综合影院红桃| 久久久美女毛片 | 欧美一区二区人人喊爽| 欧美一区二区三区精品| 欧美精品一区二区三区四区 | 亚洲欧美一区二区久久| 亚洲老妇xxxxxx| 亚洲第一综合色| 精品在线一区二区| 国产成人av在线影院| 日本乱码高清不卡字幕| 欧美日韩视频专区在线播放| 日韩一区二区三区四区五区六区 | 欧美高清一级片在线| 91精品久久久久久久91蜜桃| 精品久久久久av影院| 国产精品久久二区二区| 亚洲综合激情另类小说区| 精品在线你懂的| 成人激情校园春色| 欧美日韩国产小视频| 精品盗摄一区二区三区| |精品福利一区二区三区| 日日夜夜一区二区| 国产91清纯白嫩初高中在线观看| 色婷婷狠狠综合| 日韩免费视频线观看| 中文字幕中文字幕在线一区 | 欧美一二三区在线观看| 国产欧美一区二区在线观看| 亚洲欧美电影一区二区| 久久99国产精品免费| 91片黄在线观看| 精品免费国产二区三区| 亚洲男人的天堂在线aⅴ视频| 蜜臀av性久久久久蜜臀aⅴ四虎 | 亚洲欧洲99久久| 日韩国产精品91| 99re亚洲国产精品| 精品久久免费看| 五月天视频一区| 99re6这里只有精品视频在线观看| 91精品国产全国免费观看 | 精品国产免费一区二区三区香蕉| 亚洲欧美在线视频观看| 激情文学综合丁香| 欧美亚洲高清一区| 国产精品色哟哟| 国产一区美女在线| 欧美一区二区三区在线| 亚洲女性喷水在线观看一区| 国产福利精品导航| 日韩欧美一级在线播放| 亚洲福利电影网| 色综合亚洲欧洲| 亚洲日本乱码在线观看| 成人网男人的天堂| 日本一二三不卡| 国产美女久久久久| 日韩欧美视频一区| 日韩av不卡在线观看| 欧美亚洲国产怡红院影院| 国产免费久久精品| 国产麻豆精品一区二区| 日韩欧美一区二区免费| 人人精品人人爱| 欧美一区永久视频免费观看| 亚洲不卡av一区二区三区|