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

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

?? usb_core.c

?? STM32F10xxx USB開發者套件
?? C
?? 第 1 頁 / 共 2 頁
字號:
    goto Expect_Status_Out;
  }

  Length = pEPinfo->PacketSize;
  ControlState = (save_wLength <= Length) ? LAST_IN_DATA : IN_DATA;

  if (Length > save_wLength)
  {
    Length = save_wLength;
  }

  DataBuffer = (*pEPinfo->CopyData)(Length);

  UserToPMABufferCopy(DataBuffer, GetEPTxAddr(ENDP0), Length);

  SetEPTxCount(ENDP0, Length);

  pEPinfo->Usb_wLength -= Length;
  pEPinfo->Usb_wOffset += Length;
  vSetEPTxStatus(EP_TX_VALID);

  USB_StatusOut();/* Expect the host to abort the data IN stage */

Expect_Status_Out:
  pInformation->ControlState = ControlState;
}

/*******************************************************************************
* Function Name  : NoData_Setup0.
* Description    : Proceed the processing of setup request without data stage.
* Input          : None.
* Output         : None.
* Return         : None.
*******************************************************************************/
void NoData_Setup0(void)
{
  RESULT Result = USB_UNSUPPORT;
  u32 RequestNo = pInformation->USBbRequest;
  u32 ControlState;

  if (Type_Recipient == (STANDARD_REQUEST | DEVICE_RECIPIENT))
  {
    /* Device Request*/
    /* SET_CONFIGURATION*/
    if (RequestNo == SET_CONFIGURATION)
    {
      Result = Standard_SetConfiguration();
    }

    /*SET ADDRESS*/
    else if (RequestNo == SET_ADDRESS)
    {
      if ((pInformation->USBwValue0 > 127) || (pInformation->USBwValue1 != 0)
          || (pInformation->USBwIndex != 0)
          || (pInformation->Current_Configuration != 0))
        /* Device Address should be 127 or less*/
      {
        ControlState = STALLED;
        goto exit_NoData_Setup0;
      }
      else
      {
        Result = USB_SUCCESS;
      }
    }
    /*SET FEATURE for Device*/
    else if (RequestNo == SET_FEATURE)
    {
      if ((pInformation->USBwValue0 == DEVICE_REMOTE_WAKEUP)
          && (pInformation->USBwIndex == 0)
          && (ValBit(pInformation->Current_Feature, 5)))
      {
        Result = Standard_SetDeviceFeature();
      }
      else
      {
        Result = USB_UNSUPPORT;
      }
    }
    /*Clear FEATURE for Device */
    else if (RequestNo == CLEAR_FEATURE)
    {
      if (pInformation->USBwValue0 == DEVICE_REMOTE_WAKEUP
          && pInformation->USBwIndex == 0
          && ValBit(pInformation->Current_Feature, 5))
      {
        Result = Standard_ClearFeature();
      }
      else
      {
        Result = USB_UNSUPPORT;
      }
    }

  }

  /* Interface Request*/
  else if (Type_Recipient == (STANDARD_REQUEST | INTERFACE_RECIPIENT))
  {
    /*SET INTERFACE*/
    if (RequestNo == SET_INTERFACE)
    {
      Result = Standard_SetInterface();
    }
  }

  /* EndPoint Request*/
  else if (Type_Recipient == (STANDARD_REQUEST | ENDPOINT_RECIPIENT))
  {
    /*CLEAR FEATURE for EndPoint*/
    if (RequestNo == CLEAR_FEATURE)
    {
      Result = Standard_ClearFeature();
    }
    /* SET FEATURE for EndPoint*/
    else if (RequestNo == SET_FEATURE)
    {
      Result = Standard_SetEndPointFeature();
    }
  }
  else
  {
    Result = USB_UNSUPPORT;
  }


  if (Result != USB_SUCCESS)
  {
    Result = (*pProperty->Class_NoData_Setup)(RequestNo);
    if (Result == USB_NOT_READY)
    {
      ControlState = PAUSE;
      goto exit_NoData_Setup0;
    }
  }

  if (Result != USB_SUCCESS)
  {
    ControlState = STALLED;
    goto exit_NoData_Setup0;
  }

  ControlState = WAIT_STATUS_IN;/* After no data stage SETUP */

  USB_StatusIn();

exit_NoData_Setup0:
  pInformation->ControlState = ControlState;
  return;
}

/*******************************************************************************
* Function Name  : Data_Setup0.
* Description    : Proceed the processing of setup request with data stage.
* Input          : None.
* Output         : None.
* Return         : None.
*******************************************************************************/
void Data_Setup0(void)
{
  u8 *(*CopyRoutine)(u16);
  RESULT Result;
  u32 Request_No = pInformation->USBbRequest;

  u32 Related_Endpoint, Reserved;
  u32 wOffset, Status;



  CopyRoutine = NULL;
  wOffset = 0;

  if (Request_No == GET_DESCRIPTOR)
  {
    if (Type_Recipient == (STANDARD_REQUEST | DEVICE_RECIPIENT))
    {
      u8 wValue1 = pInformation->USBwValue1;
      if (wValue1 == DEVICE_DESCRIPTOR)
      {
        CopyRoutine = pProperty->GetDeviceDescriptor;
      }
      else if (wValue1 == CONFIG_DESCRIPTOR)
      {
        CopyRoutine = pProperty->GetConfigDescriptor;
      }
      else if (wValue1 == STRING_DESCRIPTOR)
      {
        CopyRoutine = pProperty->GetStringDescriptor;
      }  /* End of GET_DESCRIPTOR */
    }
  }

  /*GET STATUS*/
  else if ((Request_No == GET_STATUS) && (pInformation->USBwValue == 0)
           && (pInformation->USBwLength == 0x0002)
           && (pInformation->USBwIndex1 == 0))
  {
    /* GET STATUS for Device*/
    if ((Type_Recipient == (STANDARD_REQUEST | DEVICE_RECIPIENT))
        && (pInformation->USBwIndex == 0))
    {
      CopyRoutine = Standard_GetStatus;
    }

    /* GET STATUS for Interface*/
    else if (Type_Recipient == (STANDARD_REQUEST | INTERFACE_RECIPIENT))
    {
      if (((*pProperty->Class_Get_Interface_Setting)(pInformation->USBwIndex0, 0) == USB_SUCCESS)
          && (pInformation->Current_Configuration != 0))
      {
        CopyRoutine = Standard_GetStatus;
      }
    }

    /* GET STATUS for EndPoint*/
    else if (Type_Recipient == (STANDARD_REQUEST | ENDPOINT_RECIPIENT))
    {
      Related_Endpoint = (pInformation->USBwIndex0 & 0x0f);
      Reserved = pInformation->USBwIndex0 & 0x70;

      if (ValBit(pInformation->USBwIndex0, 7))
      {
        /*Get Status of endpoint & stall the request if the related_ENdpoint
        is Disabled*/
        Status = _GetEPTxStatus(Related_Endpoint);
      }
      else
      {
        Status = _GetEPRxStatus(Related_Endpoint);
      }

      if ((Related_Endpoint < Device_Table.Total_Endpoint) && (Reserved == 0)
          && (Status != 0))
      {
        CopyRoutine = Standard_GetStatus;
      }
    }

  }

  /*GET CONFIGURATION*/
  else if (Request_No == GET_CONFIGURATION)
  {
    if (Type_Recipient == (STANDARD_REQUEST | DEVICE_RECIPIENT))
    {
      CopyRoutine = Standard_GetConfiguration;
    }
  }
  /*GET INTERFACE*/
  else if (Request_No == GET_INTERFACE)
  {
    if ((Type_Recipient == (STANDARD_REQUEST | INTERFACE_RECIPIENT))
        && (pInformation->Current_Configuration != 0) && (pInformation->USBwValue == 0)
        && (pInformation->USBwIndex1 == 0) && (pInformation->USBwLength == 0x0001)
        && ((*pProperty->Class_Get_Interface_Setting)(pInformation->USBwIndex0, 0) == USB_SUCCESS))
    {
      CopyRoutine = Standard_GetInterface;
    }

  }


  if (CopyRoutine)
  {
    pInformation->Ctrl_Info.Usb_wOffset = wOffset;
    pInformation->Ctrl_Info.CopyData = CopyRoutine;
    /* sb in the original the cast to word was directly */
    /* now the cast is made step by step */
    (*CopyRoutine)(0);
    Result = USB_SUCCESS;
  }
  else
  {
    Result = (*pProperty->Class_Data_Setup)(pInformation->USBbRequest);
    if (Result == USB_NOT_READY)
    {
      pInformation->ControlState = PAUSE;
      return;
    }
  }

  if (pInformation->Ctrl_Info.Usb_wLength == 0xFFFF)
  {
    /* Data is not ready, wait it */
    pInformation->ControlState = PAUSE;
    return;
  }
  if ((Result == USB_UNSUPPORT) || (pInformation->Ctrl_Info.Usb_wLength == 0))
  {
    /* Unsupported request */
    pInformation->ControlState = STALLED;
    return;
  }


  if (ValBit(pInformation->USBbmRequestType, 7))
  {
    /* Device ==> Host */
    u32 wLength = pInformation->USBwLength;

    /* Restrict the data length to be the one host asks */
    if (pInformation->Ctrl_Info.Usb_wLength > wLength)
    {
      pInformation->Ctrl_Info.Usb_wLength = wLength;
    }

    pInformation->Ctrl_Info.PacketSize = pProperty->MaxPacketSize;
    DataStageIn();
  }
  else
  {
    pInformation->ControlState = OUT_DATA;
    vSetEPRxStatus(EP_RX_VALID);/* enable for next data reception */
  }

  return;
}

/*******************************************************************************
* Function Name  : Setup0_Process
* Description    : Get the device request data and dispatch to individual process.
* Input          : None.
* Output         : None.
* Return         : Post0_Process.
*******************************************************************************/
u8 Setup0_Process(void)
{

  union
  {
    u8* b;
    u16* w;
  } pBuf;

  pBuf.b = PMAAddr + (u8 *)(_GetEPRxAddr(ENDP0) * 2); /* *2 for 32 bits addr */

  if (pInformation->ControlState != PAUSE)
  {
    pInformation->USBbmRequestType = *pBuf.b++; /* bmRequestType */
    pInformation->USBbRequest = *pBuf.b++; /* bRequest */
    pBuf.w++;  /* word not accessed because of 32 bits addressing */
    pInformation->USBwValue = ByteSwap(*pBuf.w++); /* wValue */
    pBuf.w++;  /* word not accessed because of 32 bits addressing */
    pInformation->USBwIndex  = ByteSwap(*pBuf.w++); /* wIndex */
    pBuf.w++;  /* word not accessed because of 32 bits addressing */
    pInformation->USBwLength = *pBuf.w; /* wLength */
  }

  pInformation->ControlState = SETTING_UP;
  if (pInformation->USBwLength == 0)
  {
    /* Setup with no data stage */
    NoData_Setup0();
  }
  else
  {
    /* Setup with data stage */
    Data_Setup0();
  }
  return Post0_Process();
}

/*******************************************************************************
* Function Name  : In0_Process
* Description    : Process the IN token on all default endpoint.
* Input          : None.
* Output         : None.
* Return         : Post0_Process.
*******************************************************************************/
u8 In0_Process(void)
{
  u32 ControlState = pInformation->ControlState;

  if ((ControlState == IN_DATA) || (ControlState == LAST_IN_DATA))
  {
    DataStageIn();
    /* ControlState may be changed outside the function */
    ControlState = pInformation->ControlState;
  }

  else if (ControlState == WAIT_STATUS_IN)
  {
    if ((pInformation->USBbRequest == SET_ADDRESS) &&
        (Type_Recipient == (STANDARD_REQUEST | DEVICE_RECIPIENT)))
    {
      SetDeviceAddress(pInformation->USBwValue0);
      pUser_Standard_Requests->User_SetDeviceAddress();
    }
    (*pProperty->Process_Status_IN)();
    ControlState = STALLED;
  }

  else
  {
    ControlState = STALLED;
  }

  pInformation->ControlState = ControlState;

  return Post0_Process();
}

/*******************************************************************************
* Function Name  : Out0_Process
* Description    : Process the OUT token on all default endpoint.
* Input          : None.
* Output         : None.
* Return         : Post0_Process.
*******************************************************************************/
u8 Out0_Process(void)
{
  u32 ControlState = pInformation->ControlState;

  if ((ControlState == OUT_DATA) || (ControlState == LAST_OUT_DATA))
  {
    DataStageOut();
    ControlState = pInformation->ControlState; /* may be changed outside the function */
  }

  else if (ControlState == WAIT_STATUS_OUT)
  {
    (*pProperty->Process_Status_OUT)();
    ControlState = STALLED;
  }

  else if ((ControlState == IN_DATA) || (ControlState == LAST_IN_DATA))
  {
    /* host aborts the transfer before finish */
    ControlState = STALLED;
  }

  /* Unexpect state, STALL the endpoint */
  else
  {
    ControlState = STALLED;
  }

  pInformation->ControlState = ControlState;

  return Post0_Process();
}

/*******************************************************************************
* Function Name  : Post0_Process
* Description    : Stall the Endpoint 0 in case of error.
* Input          : None.
* Output         : None.
* Return         : - 0 if the control State is in PAUSE
*                  - 1 if not.
*******************************************************************************/
u8 Post0_Process(void)
{
  SetEPRxCount(ENDP0, Device_Property.MaxPacketSize);

  if (pInformation->ControlState == STALLED)
  {
    vSetEPRxStatus(EP_RX_STALL);
    vSetEPTxStatus(EP_TX_STALL);
  }

  return (pInformation->ControlState == PAUSE);
}

/*******************************************************************************
* Function Name  : SetDeviceAddress.
* Description    : Set the device and all the used Endpoints addresses.
* Input          : - Val: device adress.
* Output         : None.
* Return         : None.
*******************************************************************************/
void SetDeviceAddress(u8 Val)
{
  u32 i;
  u32 nEP = Device_Table.Total_Endpoint;

  /* set address in every used endpoint */
  for (i = 0; i < nEP; i++)
  {
    _SetEPAddress((u8)i, (u8)i);
  } /* for */
  _SetDADDR(Val | DADDR_EF); /* set device address and enable function */
}

/*******************************************************************************
* Function Name  : NOP_Process
* Description    : No operation function.
* Input          : None.
* Output         : None.
* Return         : None.
*******************************************************************************/
void NOP_Process(void)
{
}

/******************* (C) COPYRIGHT 2007 STMicroelectronics *****END OF FILE****/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区四| 久久精品av麻豆的观看方式| 亚洲成在人线在线播放| 美女看a上一区| 色综合久久久网| 国产欧美va欧美不卡在线| 日韩1区2区日韩1区2区| 91丨国产丨九色丨pron| 久久久久久久久99精品| 午夜免费欧美电影| 91丝袜国产在线播放| 久久午夜电影网| 蜜臀va亚洲va欧美va天堂| 99久久99久久精品免费看蜜桃| 日韩免费高清av| 性做久久久久久| 色诱视频网站一区| 欧美激情在线免费观看| 久久se这里有精品| 欧美丰满少妇xxxbbb| 亚洲欧美一区二区不卡| 国产mv日韩mv欧美| 久久久不卡网国产精品一区| 麻豆91在线播放免费| 欧美精选一区二区| 亚洲成在人线在线播放| 欧美中文字幕一二三区视频| 亚洲欧美二区三区| 日本道精品一区二区三区 | 亚洲色图视频网| 亚洲精品欧美在线| 91片在线免费观看| 亚洲色图视频免费播放| 国产成人精品亚洲777人妖| 日韩一区二区三区观看| 欧美a级理论片| 欧美日产在线观看| 视频在线观看一区二区三区| 欧美日韩国产首页| 丝袜美腿成人在线| 欧美一区二区三区影视| 青青草原综合久久大伊人精品| 欧美日韩你懂得| 丝袜美腿亚洲综合| 亚洲少妇最新在线视频| 色综合天天综合狠狠| 亚洲老妇xxxxxx| 欧美三级日韩三级国产三级| 亚洲丶国产丶欧美一区二区三区| 欧美日韩精品免费| 久久疯狂做爰流白浆xx| 久久久91精品国产一区二区精品 | 在线视频亚洲一区| 亚洲永久免费av| 欧美伦理视频网站| 久久超级碰视频| 久久久久久电影| 色呦呦日韩精品| 亚洲国产中文字幕| 日韩午夜电影在线观看| 国产一区 二区 三区一级| 国产偷国产偷亚洲高清人白洁| 成人黄色在线网站| 午夜精品久久久久久久蜜桃app| 一区二区三区在线免费| 亚洲愉拍自拍另类高清精品| 激情偷乱视频一区二区三区| 免费xxxx性欧美18vr| 国产成人综合在线观看| 欧美伊人久久大香线蕉综合69 | 亚洲第一电影网| 麻豆精品新av中文字幕| 欧美在线观看禁18| 国内精品写真在线观看| 国产精品久久久久久久第一福利 | 日韩欧美中文字幕一区| 精品一区二区三区免费观看 | 国产东北露脸精品视频| 亚洲精品视频观看| 久久综合九色综合欧美98| 色综合色狠狠天天综合色| 免费在线观看一区| 久久91精品久久久久久秒播| 国产精品毛片a∨一区二区三区| 欧美色图片你懂的| 成人综合激情网| 日韩中文字幕麻豆| 亚洲三级免费电影| 国产午夜精品一区二区三区嫩草| 欧美午夜精品久久久| 国产91在线观看丝袜| 日产精品久久久久久久性色| 亚洲品质自拍视频网站| 国产亚洲女人久久久久毛片| 欧美精品久久一区| 日本韩国欧美在线| 成人高清伦理免费影院在线观看| 日韩成人精品在线观看| 亚洲激情校园春色| 国产精品美女久久久久久久| 精品国产自在久精品国产| 精品视频在线免费| 色综合久久久网| 99视频在线观看一区三区| 国产一区二区三区四区五区入口| 全部av―极品视觉盛宴亚洲| 亚洲黄一区二区三区| 国产精品亲子伦对白| 久久久久久久久久久久久久久99| 日韩精品专区在线影院重磅| 欧美日韩高清一区二区三区| 在线观看国产91| 日本韩国精品在线| 色一情一乱一乱一91av| 不卡视频在线看| 成人91在线观看| 99在线热播精品免费| av网站一区二区三区| 成a人片国产精品| www.欧美亚洲| 99久久精品国产一区| 99久久99久久精品免费观看| 成人av电影在线网| 色综合久久综合中文综合网| 91原创在线视频| 国产亚洲欧美激情| 亚洲国产高清aⅴ视频| 亚洲国产精品t66y| 亚洲码国产岛国毛片在线| 亚洲欧美日韩成人高清在线一区| 亚洲美女精品一区| 亚洲成人精品在线观看| 蜜桃视频在线观看一区二区| 久久国产精品72免费观看| 国产呦精品一区二区三区网站| 韩国精品主播一区二区在线观看| 国产美女在线精品| 99re视频精品| 欧美性猛交xxxx乱大交退制版| 欧美精品 国产精品| 日韩一级片在线播放| 久久久久久一级片| 亚洲人吸女人奶水| 日韩精品乱码免费| 国产一区二区精品久久| 99re这里都是精品| 911精品国产一区二区在线| 亚洲精品一线二线三线| 国产精品情趣视频| 五月婷婷色综合| 国产精品中文欧美| 欧美中文一区二区三区| 欧美一卡二卡三卡| 中文字幕一区二区三中文字幕| 午夜欧美视频在线观看| 国产剧情一区二区| 在线观看亚洲精品| 久久亚洲精品小早川怜子| 亚洲美女一区二区三区| 理论片日本一区| 一本久久综合亚洲鲁鲁五月天| 欧美一区二区私人影院日本| 日本一区二区成人| 青青草97国产精品免费观看无弹窗版| 国产精品99久久久久久有的能看| 91久久精品网| 日韩高清不卡一区二区| www.爱久久.com| 日韩欧美另类在线| 亚洲最快最全在线视频| 国产成人在线电影| 日韩欧美一级二级| 一区二区三区四区精品在线视频| 狠狠狠色丁香婷婷综合久久五月| 在线观看视频一区二区| 日本一区二区三区四区| 欧美aaa在线| 欧美亚洲动漫精品| 国产精品高清亚洲| 国产精品一区二区在线观看网站| 欧美日韩精品一二三区| 亚洲人成在线播放网站岛国| 国产一区二区中文字幕| 日韩一区二区三区免费看| 一级特黄大欧美久久久| 成人av中文字幕| 国产色婷婷亚洲99精品小说| 蜜臀久久久久久久| 欧美精品乱码久久久久久 | 国产精品一区二区在线观看不卡 | 国内不卡的二区三区中文字幕| 欧美亚洲愉拍一区二区| 亚洲丝袜自拍清纯另类| 国产成人午夜视频| 久久久亚洲午夜电影| 国内精品免费**视频| 精品国产网站在线观看| 美女精品自拍一二三四| 日韩三级伦理片妻子的秘密按摩| 日韩二区在线观看|