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

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

?? usb_core.c

?? 基于CORTEX-M3內核的stm32f10x芯片的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人片一区二区梦乃| 欧美男生操女生| 蜜桃av一区二区| 久久午夜老司机| 成人精品视频一区二区三区尤物| 亚洲欧洲无码一区二区三区| 色女孩综合影院| 日韩精彩视频在线观看| 精品少妇一区二区三区视频免付费| 久久av资源网| 国产精品福利电影一区二区三区四区| 一本一道久久a久久精品| 视频在线观看一区二区三区| 精品处破学生在线二十三| 成人精品电影在线观看| 亚洲狠狠爱一区二区三区| 日韩精品自拍偷拍| 成人一级片在线观看| 一区二区高清免费观看影视大全 | 国产精品系列在线观看| 中文字幕在线播放不卡一区| 国产欧美一区二区三区在线老狼| 不卡视频免费播放| 日产精品久久久久久久性色| 国产三级精品三级在线专区| 欧美性受xxxx| 高清不卡一二三区| 亚欧色一区w666天堂| 日本一区二区三区高清不卡| 欧美精品久久天天躁| 成人综合激情网| 天天做天天摸天天爽国产一区| 欧美激情综合五月色丁香小说| 欧美日韩精品三区| 成人97人人超碰人人99| 另类中文字幕网| 亚洲人精品午夜| 久久久久国产精品人| 在线欧美日韩精品| 国产成人高清视频| 麻豆成人久久精品二区三区小说| 一区二区在线观看免费 | 国产成人小视频| 亚洲福利视频三区| 亚洲三级理论片| 久久久国际精品| 日韩精品一区二区三区视频| 欧美在线一区二区| 成人黄色综合网站| 国产成a人亚洲精品| 免费一级欧美片在线观看| 有码一区二区三区| 中文字幕一区二区三区乱码在线| 精品成人佐山爱一区二区| 欧美丰满美乳xxx高潮www| 色先锋资源久久综合| 成人精品国产一区二区4080| 国产精品影视天天线| 日本欧美久久久久免费播放网| 亚洲免费观看在线观看| 国产免费观看久久| 国产网站一区二区三区| 精品国精品国产| 欧美电影免费观看高清完整版在线 | 欧美刺激午夜性久久久久久久| 欧美亚洲动漫另类| 在线免费av一区| 色综合av在线| 欧美综合一区二区三区| 91在线小视频| 一本一本久久a久久精品综合麻豆| 成人aa视频在线观看| 国产剧情一区二区| 国产精品一区二区久激情瑜伽 | 99re这里只有精品视频首页| 成人av在线一区二区| 成人av电影观看| 91丨九色丨黑人外教| 色综合一区二区| 国产香蕉久久精品综合网| 久久久亚洲精品石原莉奈| 久久久777精品电影网影网| 欧美精品一区二区三区蜜桃| 久久久综合视频| 国产喷白浆一区二区三区| 国产日产精品一区| 国产精品不卡一区| 一区二区三区精品在线| 亚洲成av人**亚洲成av**| 日本不卡不码高清免费观看| 国内精品久久久久影院薰衣草 | 亚洲三级久久久| 亚洲国产精品久久艾草纯爱| 日本成人中文字幕| 国产麻豆视频一区二区| av午夜精品一区二区三区| 欧洲精品一区二区| 日韩一区二区在线观看视频| 国产亚洲精品福利| 一区二区三区91| 老司机精品视频一区二区三区| 国产电影一区在线| 欧美最新大片在线看| 精品毛片乱码1区2区3区| 国产精品女人毛片| 五月天激情综合网| 国产成人av一区二区三区在线| 色综合天天综合网国产成人综合天| 在线观看亚洲成人| 26uuu精品一区二区| 亚洲精品成人在线| 精品综合免费视频观看| 97久久超碰国产精品电影| 欧美精品xxxxbbbb| 中文字幕精品一区二区三区精品| 亚洲成av人片在线| 成人网页在线观看| 欧美日韩夫妻久久| 中文字幕不卡在线观看| 午夜激情一区二区| 成人免费视频app| 337p亚洲精品色噜噜噜| 国产精品欧美经典| 精品一区二区三区免费观看| 欧美亚洲综合另类| 中文字幕欧美日韩一区| 奇米精品一区二区三区四区| 99久久久精品免费观看国产蜜| 日韩欧美国产小视频| 亚洲午夜私人影院| 99久久婷婷国产综合精品电影| 欧美一区二区二区| 亚洲一二三四久久| 成人丝袜视频网| 91精品国产乱码| 尤物视频一区二区| jizz一区二区| 国产夜色精品一区二区av| 日韩二区三区四区| 欧美伊人久久大香线蕉综合69 | 日韩一区中文字幕| 国产乱人伦偷精品视频免下载| 欧美久久久久久蜜桃| 一区二区三区日韩欧美精品| 国产成人亚洲综合a∨婷婷| 欧美变态tickle挠乳网站| 亚洲电影中文字幕在线观看| 一本到不卡免费一区二区| 亚洲欧洲日产国码二区| 久久久精品综合| 亚洲成在人线免费| 色域天天综合网| 亚洲欧美视频在线观看视频| 国产99久久久国产精品潘金| 久久久午夜电影| 久久电影网电视剧免费观看| 欧美一级生活片| 丝袜a∨在线一区二区三区不卡| 色综合天天在线| 综合在线观看色| 91在线精品一区二区三区| 中文字幕中文字幕一区二区| 成人中文字幕合集| 国产婷婷色一区二区三区四区| 国产一区二区三区免费在线观看| 日韩一区二区三区观看| 久久精品久久精品| 亚洲精品在线电影| 国产成人鲁色资源国产91色综| 国产无一区二区| 99综合电影在线视频| 亚洲欧美精品午睡沙发| 欧美综合一区二区| 偷窥国产亚洲免费视频| 欧美一级高清片在线观看| 成人国产精品免费观看视频| 国产成人在线观看| 欧美激情一区二区三区不卡| 国产 日韩 欧美大片| 国产精品看片你懂得| 成人99免费视频| 亚洲电影欧美电影有声小说| 欧美日韩精品一区二区三区四区| 亚洲不卡av一区二区三区| 日韩精品中午字幕| 国产不卡一区视频| 亚洲精品国久久99热| 777久久久精品| 国产麻豆视频精品| 亚洲视频免费观看| 555夜色666亚洲国产免| 国内不卡的二区三区中文字幕| 国产精品久久福利| 欧美军同video69gay| 国产一区二区调教| 日韩久久一区二区|