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

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

?? f34x_usb_standard_requests.c

?? 這是C8051F340的USB的程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
//-----------------------------------------------------------------------------
// F34x_USB_Standard_Requests.c
//-----------------------------------------------------------------------------
// Copyright 2005 Silicon Laboratories, Inc.
// http://www.silabs.com
//
// Program Description:
//
// This source file contains the subroutines used to handle incoming 
// setup packets. These are called by Handle_Setup in USB_ISR.c and used for 
// USB chapter 9 compliance.
//

// How To Test:    See Readme.txt
//
//
// FID:            34X000022
// Target:         C8051F34x
// Tool chain:     Keil C51 7.50 / Keil EVAL C51
//                 Silicon Laboratories IDE version 2.6
// Command Line:   See Readme.txt
// Project Name:   F34x_USB_Interrupt
//
//
// Release 1.0
//    -Initial Revision (GP)
//    -22 NOV 2005
//    -Ported from 'F320_USB_Bulk
//

//-----------------------------------------------------------------------------
// Includes
//-----------------------------------------------------------------------------

#include "c8051F340.h"#include "F34x_USB_Register.h"
#include "F34x_USB_Main.h"
#include "F34x_USB_Descriptor.h"

//-----------------------------------------------------------------------------
// Externs
//-----------------------------------------------------------------------------

// These are created in USB_DESCRIPTOR.h

extern device_descriptor DeviceDesc;            
extern configuration_descriptor ConfigDesc;
extern interface_descriptor InterfaceDesc;
extern endpoint_descriptor Endpoint1Desc;
extern endpoint_descriptor Endpoint2Desc;
extern BYTE* StringDescTable[];

extern setup_buffer Setup;             // Buffer for current device request
extern unsigned int DataSize;
extern unsigned int DataSent;
extern BYTE* DataPtr;

extern BYTE Ep_Status[];               // Contains status bytes for EP 0-2

extern BYTE USB_State;                 // Determines current usb device state

//-----------------------------------------------------------------------------
// Global Variables
//-----------------------------------------------------------------------------

// These are response packets used for communication with host
code BYTE ONES_PACKET[2] = {0x01, 0x00};        
code BYTE ZERO_PACKET[2] = {0x00, 0x00};        

//-----------------------------------------------------------------------------
// Support Subroutines
//-----------------------------------------------------------------------------

//-----------------------------------------------------------------------------
// Get_Status
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// This routine returns a two byte status packet to the host
//
//-----------------------------------------------------------------------------

void Get_Status(void)                  
{                                      

   if (Setup.wValue.c[MSB] || Setup.wValue.c[LSB] ||
                                                
   // If non-zero return length or data length not  equal to 2 then send a stall
   // indicating invalid request
   Setup.wLength.c[MSB]    || (Setup.wLength.c[LSB] != 2))                                               
   {                                            
      Force_Stall();
   }

   // Determine if recipient was device, interface, or EP
   switch(Setup.bmRequestType)                  
   {
      // If recipient was device
      case OUT_DEVICE:                          
         if (Setup.wIndex.c[MSB] || Setup.wIndex.c[LSB])
         {
		    // Send stall if request is invalid
            Force_Stall();             
         }
         else
         {
		    // Otherwise send 0x00, indicating bus power and no
			// remote wake-up supported
            DataPtr = (BYTE*)&ZERO_PACKET;      
            DataSize = 2;                       
         }
         break;

      // See if recipient was interface
      case OUT_INTERFACE:                       
	     // Only valid if device is configured and non-zero index
         if ((USB_State != DEV_CONFIGURED) ||
              Setup.wIndex.c[MSB] || Setup.wIndex.c[LSB])                                                
         {
		    // Otherwise send stall to host
            Force_Stall();                      
         }
         else
         {
		    // Status packet always returns 0x00
            DataPtr = (BYTE*)&ZERO_PACKET;      
            DataSize = 2;
         }
         break;

      // See if recipient was an endpoint
      case OUT_ENDPOINT:                        
	     // Make sure device is configured and index msb = 0x00
         if ((USB_State != DEV_CONFIGURED) || Setup.wIndex.c[MSB])                   
         {                                     
            Force_Stall();              // otherwise return stall to host
         }
         else
         {
            // Handle case if request is directed to EP 1
            if (Setup.wIndex.c[LSB] == IN_EP1)  
            {
               if (Ep_Status[1] == EP_HALT)
               {                                
			      // If endpoint is halted, return 0x01,0x00
                  DataPtr = (BYTE*)&ONES_PACKET;
                  DataSize = 2;
               }
               else
               {
			      // Otherwise return 0x00,0x00 to indicate endpoint active
                  DataPtr = (BYTE*)&ZERO_PACKET;
                  DataSize = 2;
               }
            }
            else
            {
			   // If request is directed to endpoint 2, send either
			   // 0x01,0x00 if endpoint halted or 0x00,0x00 if endpoint is active
               if (Setup.wIndex.c[LSB] == OUT_EP2)
                                                
               {                                
                  if (Ep_Status[2] == EP_HALT)
                  {
                     DataPtr = (BYTE*)&ONES_PACKET;
                     DataSize = 2;
                  }
                  else
                  {
                     DataPtr = (BYTE*)&ZERO_PACKET;
                     DataSize = 2;
                  }
               }
               else
               {
                  Force_Stall();       // Send stall if unexpected data
               }
            }
         }
         break;

      default:
         Force_Stall();
         break;
   }
   if (Ep_Status[0] != EP_STALL)
   {
      // Set serviced Setup Packet, Endpoint 0 intransmit mode, 
	  // and reset DataSent counter
      POLL_WRITE_BYTE(E0CSR, rbSOPRDY);        
      Ep_Status[0] = EP_TX;                     
      DataSent = 0;
   }
}

//-----------------------------------------------------------------------------
// Clear_Feature
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// This routine can clear Halt Endpoint features on endpoint 1 and 2.
//
//-----------------------------------------------------------------------------

void Clear_Feature()                            
{                                               

   if ((USB_State != DEV_CONFIGURED)          ||// Send procedural stall if device isn't configured
   (Setup.bmRequestType == IN_DEVICE)         ||// or request is made to host(remote wakeup not supported)
   (Setup.bmRequestType == IN_INTERFACE)      ||// or request is made to interface
   Setup.wValue.c[MSB]  || Setup.wIndex.c[MSB]||// or msbs of value or index set to non-zero value
   Setup.wLength.c[MSB] || Setup.wLength.c[LSB])// or data length set to non-zero.
   {
      Force_Stall();
   }

   else
   {
      if ((Setup.bmRequestType == IN_ENDPOINT)&&// Verify that packet was directed at an endpoint
      (Setup.wValue.c[LSB] == ENDPOINT_HALT)  &&// the feature selected was HALT_ENDPOINT
      ((Setup.wIndex.c[LSB] == IN_EP1) ||       // and that the request was directed at EP 1 in
      (Setup.wIndex.c[LSB] == OUT_EP2)))        // or EP 2 out
      {
         if (Setup.wIndex.c[LSB] == IN_EP1)
         {
            POLL_WRITE_BYTE (INDEX, 1);         // Clear feature endpoint 1 halt
            POLL_WRITE_BYTE (EINCSR1, rbInCLRDT);
            Ep_Status[1] = EP_IDLE;             // Set endpoint 1 status back to idle
         }
         else
         {
            POLL_WRITE_BYTE (INDEX, 2);         // Clear feature endpoint 2 halt
            POLL_WRITE_BYTE (EOUTCSR1, rbOutCLRDT);
            Ep_Status[2] = EP_IDLE;             // Set endpoint 2 status back to idle
         }
      }
      else
      {
         Force_Stall();                         // Send procedural stall
      }
   }
   POLL_WRITE_BYTE(INDEX, 0);                   // Reset Index to 0
   if (Ep_Status[0] != EP_STALL)
   {
      // Indicate setup packet has been serviced
      POLL_WRITE_BYTE(E0CSR, rbSOPRDY);
   }
}

//-----------------------------------------------------------------------------
// Set_Feature
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// This routine will set the EP Halt feature for endpoints 1 and 2
//
//-----------------------------------------------------------------------------

void Set_Feature(void)                          
{                                             

   if ((USB_State != DEV_CONFIGURED)          ||// Make sure device is configured, setup data
   (Setup.bmRequestType == IN_DEVICE)         ||// is all valid and that request is directed at
   (Setup.bmRequestType == IN_INTERFACE)      ||// an endpoint
   Setup.wValue.c[MSB]  || Setup.wIndex.c[MSB]||
   Setup.wLength.c[MSB] || Setup.wLength.c[LSB])
   {
      Force_Stall();                            // Otherwise send stall to host
   }

   else
   {
      if ((Setup.bmRequestType == IN_ENDPOINT)&&// Make sure endpoint exists and that halt
      (Setup.wValue.c[LSB] == ENDPOINT_HALT)  &&// endpoint feature is selected
      ((Setup.wIndex.c[LSB] == IN_EP1)        ||
      (Setup.wIndex.c[LSB] == OUT_EP2)))
      {
         if (Setup.wIndex.c[LSB] == IN_EP1)
         {
            POLL_WRITE_BYTE (INDEX, 1);         // Set feature endpoint 1 halt
            POLL_WRITE_BYTE (EINCSR1, rbInSDSTL);
            Ep_Status[1] = EP_HALT;
         }
         else
         {
            POLL_WRITE_BYTE (INDEX, 2);         // Set feature Ep2 halt
            POLL_WRITE_BYTE (EOUTCSR1, rbOutSDSTL);
            Ep_Status[2] = EP_HALT;
         }
      }
      else

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区日韩欧美| 91福利小视频| 久久久久久久综合色一本| 久久机这里只有精品| 日韩欧美不卡在线观看视频| 奇米影视7777精品一区二区| 精品美女被调教视频大全网站| 国精产品一区一区三区mba视频| 欧美精品一区二区在线观看| 国产成人免费xxxxxxxx| 亚洲欧洲国产专区| 欧美写真视频网站| 蜜臀av在线播放一区二区三区 | 性久久久久久久久| 欧美老人xxxx18| 精品一区二区三区免费视频| 国产午夜三级一区二区三| 成人国产一区二区三区精品| 亚洲一区二区三区激情| 欧美一区二区黄| 国产成人在线视频免费播放| 一个色综合网站| 精品日韩在线一区| 色婷婷综合久久久久中文一区二区 | 国产精品综合av一区二区国产馆| 欧美韩国日本不卡| 欧美日韩一级片在线观看| 国产资源在线一区| 亚洲乱码国产乱码精品精的特点 | 亚洲欧洲精品一区二区三区不卡| 欧美三级电影在线观看| 国产在线观看一区二区| 亚洲色图在线视频| 日韩免费一区二区三区在线播放| 波多野结衣中文一区| 亚洲va国产天堂va久久en| 久久精品亚洲麻豆av一区二区 | 首页国产丝袜综合| 国产人妖乱国产精品人妖| 欧美视频一区在线| 大陆成人av片| 男人的天堂久久精品| 成人免费在线视频| 久久影院视频免费| 欧美丝袜丝nylons| av中文一区二区三区| 久久99久久久久| 亚洲成人精品一区二区| 国产精品久久99| 久久蜜桃av一区二区天堂| 666欧美在线视频| 色欧美片视频在线观看| 国产精品中文有码| 麻豆国产欧美日韩综合精品二区 | 午夜久久久久久| 中文字幕欧美一区| 亚洲国产精品成人综合色在线婷婷| 91精品国产91综合久久蜜臀| 一本大道av伊人久久综合| 国产乱淫av一区二区三区| 捆绑调教一区二区三区| 性久久久久久久| 亚洲制服欧美中文字幕中文字幕| 日本一区二区三区视频视频| 精品国产青草久久久久福利| 精品视频在线视频| 在线观看亚洲专区| 色婷婷综合久久久久中文| 成人免费不卡视频| 国产成人精品影视| 狠狠色狠狠色综合系列| 蜜桃一区二区三区在线| 丝袜脚交一区二区| 肉丝袜脚交视频一区二区| 午夜天堂影视香蕉久久| 亚洲成人高清在线| 日韩专区在线视频| 午夜精品福利视频网站| 亚洲韩国精品一区| 亚洲成人一区二区在线观看| 一级特黄大欧美久久久| 亚洲一级片在线观看| 亚洲一区二区不卡免费| 五月天激情综合| 免费在线观看一区| 久久99精品国产91久久来源| 久久国产乱子精品免费女| 久久99最新地址| 国产成人丝袜美腿| 99精品视频在线观看免费| 91麻豆免费看| 欧洲亚洲精品在线| 欧美乱妇20p| 欧美成人性战久久| 久久精品亚洲乱码伦伦中文| 国产精品久久久久久久浪潮网站| 国产精品免费av| 一区二区三区精品在线| 香蕉久久夜色精品国产使用方法 | 日韩欧美资源站| 日韩精品一区二区三区四区| 久久久久久久综合色一本| 国产精品私人影院| 亚洲国产欧美在线人成| 麻豆成人免费电影| 成人黄色免费短视频| 欧美日韩在线三级| 精品剧情在线观看| 综合久久给合久久狠狠狠97色 | 一区二区三区日韩欧美精品| 日韩中文字幕区一区有砖一区 | 精品国产乱码久久久久久久| 久久综合久久综合久久| 中文字幕在线免费不卡| 亚洲国产视频a| 狠狠久久亚洲欧美| 91麻豆免费视频| 日韩限制级电影在线观看| 欧美激情自拍偷拍| 亚洲国产wwwccc36天堂| 国产精品一区二区久久不卡| 色婷婷精品大视频在线蜜桃视频| 91麻豆精品国产91久久久久久| 中文一区二区在线观看| 亚欧色一区w666天堂| 成人免费福利片| 日韩欧美区一区二| 亚洲精品免费一二三区| 国产一区欧美二区| 欧美精品v日韩精品v韩国精品v| 国产亚洲一区二区三区| 五月天激情综合| 色综合一区二区| 久久久影视传媒| 午夜av区久久| 色综合久久天天| 久久久久久亚洲综合影院红桃| 亚洲电影激情视频网站| av影院午夜一区| 久久久久久久久久看片| 午夜一区二区三区视频| 成人av手机在线观看| 日韩精品一区二区三区在线观看| 一区二区三区中文字幕电影| 国产精品白丝av| 精品日韩一区二区| 日产国产欧美视频一区精品| 色诱视频网站一区| 国产精品国产三级国产普通话99| 精品在线免费观看| 日韩三级精品电影久久久| 亚洲国产精品自拍| 在线精品视频免费播放| 亚洲人成亚洲人成在线观看图片| 国产一区二区电影| 26uuuu精品一区二区| 美腿丝袜在线亚洲一区 | 色94色欧美sute亚洲线路一久| 久久精品视频免费观看| 久色婷婷小香蕉久久| 欧美日韩国产中文| 午夜电影网亚洲视频| 欧美日韩亚洲综合| 亚洲国产精品精华液网站| 99re热这里只有精品视频| 国产精品免费免费| 成人教育av在线| 亚洲欧美日韩系列| 色琪琪一区二区三区亚洲区| 国产精品国产三级国产aⅴ中文| 大尺度一区二区| 国产精品免费视频观看| av中文字幕亚洲| 亚洲欧美一区二区三区国产精品| 色噜噜狠狠色综合中国| 亚洲欧美日韩国产成人精品影院| 色一情一伦一子一伦一区| 一片黄亚洲嫩模| 91精品一区二区三区在线观看| 美腿丝袜一区二区三区| 久久青草欧美一区二区三区| 粉嫩绯色av一区二区在线观看| 欧美高清在线精品一区| k8久久久一区二区三区 | 男女激情视频一区| 欧美成人一区二区三区| 国产成人一区二区精品非洲| 国产精品国产三级国产普通话三级| 91麻豆精品一区二区三区| 一区二区三区在线观看动漫| 欧美日韩一区二区电影| 美女性感视频久久| 久久九九久久九九| 91在线国内视频| 性感美女极品91精品| www一区二区| 色欲综合视频天天天| 青青草97国产精品免费观看无弹窗版| 欧美α欧美αv大片| av一区二区久久|