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

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

?? usb_core.c

?? 萬利開發板上的lcd例程
?? 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一区二区三区| 欧美日韩精品电影| 樱花草国产18久久久久| 成人h动漫精品| 国产精品麻豆99久久久久久| 久久激情五月激情| 欧美一区2区视频在线观看| 一区二区三区日本| 在线视频一区二区三区| 中文字幕在线视频一区| 成人免费高清在线观看| 久久久久久99久久久精品网站| 水野朝阳av一区二区三区| 欧美日韩一本到| 一区二区理论电影在线观看| 91福利在线看| 亚洲激情校园春色| 色菇凉天天综合网| 综合av第一页| 色综合视频一区二区三区高清| 国产精品久久久久aaaa樱花| 国产成人精品亚洲777人妖| 2019国产精品| 国产精品一区二区黑丝| 国产日韩精品视频一区| 丰满白嫩尤物一区二区| 中文字幕五月欧美| 色悠悠亚洲一区二区| 亚洲一区二区四区蜜桃| 欧美日韩夫妻久久| 日本午夜精品一区二区三区电影| 91精品国产一区二区三区 | 欧美人xxxx| 亚洲国产成人av| 91麻豆视频网站| 日韩免费一区二区三区在线播放| 免费在线看一区| 精品处破学生在线二十三| 国产一区999| 久久久99免费| 成人av综合一区| 亚洲精品免费在线播放| jvid福利写真一区二区三区| 亚洲你懂的在线视频| 欧美色欧美亚洲另类二区| 蜜臀久久久99精品久久久久久| 精品第一国产综合精品aⅴ| av综合在线播放| 偷窥少妇高潮呻吟av久久免费| 91精品国产全国免费观看| 国产一区999| 亚洲一二三四区| 精品少妇一区二区三区免费观看| 国产成人在线视频网站| 亚洲午夜羞羞片| www激情久久| 欧美性大战久久久久久久蜜臀| 3d动漫精品啪啪1区2区免费| 成人午夜又粗又硬又大| 亚洲免费在线播放| 在线电影一区二区三区| 春色校园综合激情亚洲| 亚洲国产乱码最新视频| 国产亚洲人成网站| 欧美无乱码久久久免费午夜一区| 九色综合狠狠综合久久| 一区二区三区四区激情| 精品1区2区在线观看| 91福利在线导航| 国产成人久久精品77777最新版本| 亚洲午夜久久久久中文字幕久| 精品乱码亚洲一区二区不卡| 在线观看免费视频综合| 国产精品 日产精品 欧美精品| 亚洲一级二级在线| 欧美激情一区二区三区全黄| 91精品国产高清一区二区三区| 99re这里只有精品首页| 亚洲精品免费一二三区| 狠狠色丁香久久婷婷综合丁香| 国产精品久久久久久亚洲伦| 91精品一区二区三区在线观看| 久久er99热精品一区二区| 亚洲黄网站在线观看| 国产丝袜欧美中文另类| 欧美久久一二区| 91激情五月电影| 91小视频免费看| 国产不卡视频一区| 国产麻豆一精品一av一免费 | 日韩一级精品视频在线观看| 97精品电影院| 成人免费黄色在线| 国产成人一级电影| 国产一区二区剧情av在线| 91福利国产成人精品照片| 亚洲美女在线国产| 国产精品国产自产拍高清av| 欧美xxxx在线观看| 3d成人动漫网站| 欧美日韩国产免费| 欧美日韩一区中文字幕| 欧洲av在线精品| 在线观看日韩高清av| 在线观看免费成人| 欧美丝袜自拍制服另类| 欧美久久久久久蜜桃| 欧美午夜电影一区| 91精品婷婷国产综合久久竹菊| 欧美日韩在线精品一区二区三区激情| 欧美自拍偷拍午夜视频| 欧美人与禽zozo性伦| 欧美片在线播放| 欧美一级高清大全免费观看| 欧美一级片在线看| 日韩精品影音先锋| 国产午夜精品美女毛片视频| 国产视频一区不卡| 亚洲欧美日韩在线播放| 亚洲国产电影在线观看| 久久精品这里都是精品| 国产精品素人一区二区| 亚洲视频免费观看| 亚洲国产精品尤物yw在线观看| 亚洲二区在线视频| 久久精品国产精品亚洲精品| 国产一区二区电影| av中文一区二区三区| 欧美色图第一页| 日韩色视频在线观看| 亚洲国产精品ⅴa在线观看| 亚洲欧美精品午睡沙发| 五月天丁香久久| 国产乱码精品一区二区三区av | 天天操天天色综合| 精久久久久久久久久久| av在线播放一区二区三区| 91高清视频免费看| 久久久亚洲欧洲日产国码αv| 亚洲婷婷在线视频| 美女视频免费一区| 国产精品自产自拍| 国产传媒欧美日韩成人| 日本久久一区二区| 欧美大尺度电影在线| 一色屋精品亚洲香蕉网站| 日本不卡视频在线| 成人午夜碰碰视频| 欧美久久久久中文字幕| 国产精品丝袜91| 美国av一区二区| 欧美在线视频你懂得| 国产亚洲精品精华液| 亚洲一区二区三区四区中文字幕| 精品一区二区三区在线观看国产| 成年人网站91| 精品国产伦一区二区三区免费| 亚洲男同1069视频| 国产一区二区三区四区五区入口 | 日韩美女一区二区三区四区| 国产精品欧美综合在线| 蜜臀精品一区二区三区在线观看| 色妹子一区二区| 国产亚洲综合色| 国产精品视频免费| 亚洲精品视频一区二区| 国产成a人无v码亚洲福利| 欧美一区二区三级| 一区二区欧美视频| 99久久婷婷国产综合精品| 精品国产一区二区精华| 免费的国产精品| 欧美久久婷婷综合色| 亚洲成av人影院| 色www精品视频在线观看| 国产精品久久久久影院| 国内精品伊人久久久久影院对白| 欧美精品精品一区| 亚洲成人tv网| 欧美三级一区二区| 亚洲国产精品天堂| 欧美午夜一区二区三区免费大片| 国产精品初高中害羞小美女文| 粉嫩av一区二区三区粉嫩| 久久久久久久一区| 国产一区二区电影| 国产午夜精品一区二区| 国产精品一区二区你懂的| 国产午夜一区二区三区| 国产精品性做久久久久久| 国产免费久久精品| 成人免费视频国产在线观看| 欧美国产禁国产网站cc| 波多野结衣中文一区|