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

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

?? usbcore.c

?? 深圳優龍科技LPC2378實例代碼僅供參考
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*----------------------------------------------------------------------------
 *      U S B  -  K e r n e l
 *----------------------------------------------------------------------------
 *      Name:    USBCORE.C
 *      Purpose: USB Core Module
 *      Version: V1.10
 *----------------------------------------------------------------------------
 *      This software is supplied "AS IS" without any warranties, express,
 *      implied or statutory, including but not limited to the implied
 *      warranties of fitness for purpose, satisfactory quality and
 *      noninfringement. Keil extends you a royalty-free right to reproduce
 *      and distribute executable files created using this software for use
 *      on Philips LPC2xxx microcontroller devices only. Nothing else gives
 *      you the right to use this software.
 *
 *      Copyright (c) 2005-2006 Keil Software.
 *---------------------------------------------------------------------------*/

#include "type.h"

#include "usb.h"
#include "usbcfg.h"
#include "usbhw.h"
#include "usbcore.h"
#include "usbdesc.h"
#include "usbuser.h"

#if (USB_AUDIO)
#include "audio.h"
#include "adcuser.h"
#endif

#if (USB_HID)
#include "hid.h"
#include "hiduser.h"
#endif

#if (USB_MSC)
#include "msc.h"
#include "mscuser.h"
#endif


WORD  USB_DeviceStatus;
BYTE  USB_DeviceAddress;
BYTE  USB_Configuration;
DWORD USB_EndPointMask;
DWORD USB_EndPointHalt;
BYTE  USB_NumInterfaces;
BYTE  USB_AltSetting[USB_IF_NUM];

BYTE  EP0Buf[USB_MAX_PACKET0];


USB_EP_DATA EP0Data;

USB_SETUP_PACKET SetupPacket;


/*
 *  Reset USB Core
 *    Parameters:      None
 *    Return Value:    None
 */

void USB_ResetCore (void) {

  USB_DeviceStatus  = USB_POWER;
  USB_DeviceAddress = 0;
  USB_Configuration = 0;
  USB_EndPointMask  = 0x00010001;
  USB_EndPointHalt  = 0x00000000;
}


/*
 *  USB Request - Setup Stage
 *    Parameters:      None (global SetupPacket)
 *    Return Value:    None
 */

void USB_SetupStage (void) {
  USB_ReadEP(0x00, (BYTE *)&SetupPacket);
}


/*
 *  USB Request - Data In Stage
 *    Parameters:      None (global EP0Data)
 *    Return Value:    None
 */

void USB_DataInStage (void) {
  DWORD cnt;

  if (EP0Data.Count > USB_MAX_PACKET0) {
    cnt = USB_MAX_PACKET0;
  } else {
    cnt = EP0Data.Count;
  }
  cnt = USB_WriteEP(0x80, EP0Data.pData, cnt);
  EP0Data.pData += cnt;
  EP0Data.Count -= cnt;
}


/*
 *  USB Request - Data Out Stage
 *    Parameters:      None (global EP0Data)
 *    Return Value:    None
 */

void USB_DataOutStage (void) {
  DWORD cnt;

  cnt = USB_ReadEP(0x00, EP0Data.pData);
  EP0Data.pData += cnt;
  EP0Data.Count -= cnt;
}


/*
 *  USB Request - Status In Stage
 *    Parameters:      None
 *    Return Value:    None
 */

void USB_StatusInStage (void) {
  USB_WriteEP(0x80, NULL, 0);
}


/*
 *  USB Request - Status Out Stage
 *    Parameters:      None
 *    Return Value:    None
 */

void USB_StatusOutStage (void) {
  USB_ReadEP(0x00, EP0Buf);
}


/*
 *  Get Status USB Request
 *    Parameters:      None (global SetupPacket)
 *    Return Value:    TRUE - Success, FALSE - Error
 */

BOOL USB_GetStatus (void) {
  DWORD n, m;

  switch (SetupPacket.bmRequestType.BM.Recipient) {
    case REQUEST_TO_DEVICE:
      EP0Data.pData = (BYTE *)&USB_DeviceStatus;
      USB_DataInStage();
      break;
    case REQUEST_TO_INTERFACE:
      if ((USB_Configuration != 0) && (SetupPacket.wIndex.WB.L < USB_NumInterfaces)) {
        *((WORD *)EP0Buf) = 0;
        EP0Data.pData = EP0Buf;
        USB_DataInStage();
      } else {
        return (FALSE);
      }
      break;
    case REQUEST_TO_ENDPOINT:
      n = SetupPacket.wIndex.WB.L & 0x8F;
      m = (n & 0x80) ? ((1 << 16) << (n & 0x0F)) : (1 << n);
      if (((USB_Configuration != 0) || ((n & 0x0F) == 0)) && (USB_EndPointMask & m)) {
        *((WORD *)EP0Buf) = (USB_EndPointHalt & m) ? 1 : 0;
        EP0Data.pData = EP0Buf;
        USB_DataInStage();
      } else {
        return (FALSE);
      }
      break;
    default:
      return (FALSE);
  }
  return (TRUE);
}


/*
 *  Set/Clear Feature USB Request
 *    Parameters:      sc:    0 - Clear, 1 - Set
 *                            None (global SetupPacket)
 *    Return Value:    TRUE - Success, FALSE - Error
 */

BOOL USB_SetClrFeature (DWORD sc) {
  DWORD n, m;

  switch (SetupPacket.bmRequestType.BM.Recipient) {
    case REQUEST_TO_DEVICE:
      if (SetupPacket.wValue.W == USB_FEATURE_REMOTE_WAKEUP) {
        if (sc) {
          USB_WakeUpCfg(TRUE);
          USB_DeviceStatus |=  USB_GETSTATUS_REMOTE_WAKEUP;
        } else {
          USB_WakeUpCfg(FALSE);
          USB_DeviceStatus &= ~USB_GETSTATUS_REMOTE_WAKEUP;
        }
      } else {
        return (FALSE);
      }
      break;
    case REQUEST_TO_INTERFACE:
      return (FALSE);
    case REQUEST_TO_ENDPOINT:
      n = SetupPacket.wIndex.WB.L & 0x8F;
      m = (n & 0x80) ? ((1 << 16) << (n & 0x0F)) : (1 << n);
      if ((USB_Configuration != 0) && ((n & 0x0F) != 0) && (USB_EndPointMask & m)) {
        if (SetupPacket.wValue.W == USB_FEATURE_ENDPOINT_STALL) {
          if (sc) {
            USB_SetStallEP(n);
            USB_EndPointHalt |=  m;
          } else {
            USB_ClrStallEP(n);
            USB_EndPointHalt &= ~m;
          }
        } else {
          return (FALSE);
        }
      } else {
        return (FALSE);
      }
      break;
    default:
      return (FALSE);
  }
  return (TRUE);
}


/*
 *  Get Descriptor USB Request
 *    Parameters:      None (global SetupPacket)
 *    Return Value:    TRUE - Success, FALSE - Error
 */

BOOL USB_GetDescriptor (void) {
  BYTE  *pD;
  DWORD len, n;

  switch (SetupPacket.bmRequestType.BM.Recipient) {
    case REQUEST_TO_DEVICE:
      switch (SetupPacket.wValue.WB.H) {
        case USB_DEVICE_DESCRIPTOR_TYPE:
          EP0Data.pData = (BYTE *)USB_DeviceDescriptor;
          len = USB_DEVICE_DESC_SIZE;
          break;
        case USB_CONFIGURATION_DESCRIPTOR_TYPE:
          pD = (BYTE *)USB_ConfigDescriptor;
          for (n = 0; n != SetupPacket.wValue.WB.L; n++) {
            if (((USB_CONFIGURATION_DESCRIPTOR *)pD)->bLength != 0) {
              pD += ((USB_CONFIGURATION_DESCRIPTOR *)pD)->wTotalLength;
            }
          }
          if (((USB_CONFIGURATION_DESCRIPTOR *)pD)->bLength == 0) {
            return (FALSE);
          }
          EP0Data.pData = pD;
          len = ((USB_CONFIGURATION_DESCRIPTOR *)pD)->wTotalLength;
          break;
        case USB_STRING_DESCRIPTOR_TYPE:
          EP0Data.pData = (BYTE *)USB_StringDescriptor + SetupPacket.wValue.WB.L;
          len = ((USB_STRING_DESCRIPTOR *)EP0Data.pData)->bLength;
          break;
        default:
          return (FALSE);
      }
      break;
    case REQUEST_TO_INTERFACE:
      switch (SetupPacket.wValue.WB.H) {
#if USB_HID
        case HID_HID_DESCRIPTOR_TYPE:
          if (SetupPacket.wIndex.WB.L != USB_HID_IF_NUM) {
            return (FALSE);    /* Only Single HID Interface is supported */
          }
          EP0Data.pData = (BYTE *)USB_ConfigDescriptor + HID_DESC_OFFSET;
          len = HID_DESC_SIZE;
          break;
        case HID_REPORT_DESCRIPTOR_TYPE:
          if (SetupPacket.wIndex.WB.L != USB_HID_IF_NUM) {
            return (FALSE);    /* Only Single HID Interface is supported */
          }
          EP0Data.pData = (BYTE *)HID_ReportDescriptor;
          len = HID_ReportDescSize;
          break;
        case HID_PHYSICAL_DESCRIPTOR_TYPE:
          return (FALSE);      /* HID Physical Descriptor is not supported */
#endif
        default:
          return (FALSE);
      }
      break;
    default:
      return (FALSE);
  }

  if (EP0Data.Count > len) {
    EP0Data.Count = len;
  }
  USB_DataInStage();

  return (TRUE);
}


/*
 *  Set Configuration USB Request
 *    Parameters:      None (global SetupPacket)
 *    Return Value:    TRUE - Success, FALSE - Error
 */

BOOL USB_SetConfiguration (void) {
  USB_COMMON_DESCRIPTOR *pD;
  DWORD                  alt, n, m;

  if (SetupPacket.wValue.WB.L) {
    pD = (USB_COMMON_DESCRIPTOR *)USB_ConfigDescriptor;
    while (pD->bLength) {
      switch (pD->bDescriptorType) {
        case USB_CONFIGURATION_DESCRIPTOR_TYPE:
          if (((USB_CONFIGURATION_DESCRIPTOR *)pD)->bConfigurationValue == SetupPacket.wValue.WB.L) {
            USB_Configuration = SetupPacket.wValue.WB.L;
            USB_NumInterfaces = ((USB_CONFIGURATION_DESCRIPTOR *)pD)->bNumInterfaces;
            for (n = 0; n < USB_IF_NUM; n++) {
              USB_AltSetting[n] = 0;
            }
            for (n = 1; n < 16; n++) {
              if (USB_EndPointMask & (1 << n)) {
                USB_DisableEP(n);
              }
              if (USB_EndPointMask & ((1 << 16) << n)) {
                USB_DisableEP(n | 0x80);
              }
            }
            USB_EndPointMask = 0x00010001;
            USB_EndPointHalt = 0x00000000;
            USB_Configure(TRUE);
            if (((USB_CONFIGURATION_DESCRIPTOR *)pD)->bmAttributes & USB_CONFIG_SELF_POWERED) {
              USB_DeviceStatus |=  USB_GETSTATUS_SELF_POWERED;
            } else {
              USB_DeviceStatus &= ~USB_GETSTATUS_SELF_POWERED;
            }
          } else {
            pD = (USB_COMMON_DESCRIPTOR *)((BYTE *)pD + ((USB_CONFIGURATION_DESCRIPTOR *)pD)->wTotalLength);
            continue;
          }
          break;
        case USB_INTERFACE_DESCRIPTOR_TYPE:
          alt = ((USB_INTERFACE_DESCRIPTOR *)pD)->bAlternateSetting;
          break;
        case USB_ENDPOINT_DESCRIPTOR_TYPE:
          if (alt == 0) {
            n = ((USB_ENDPOINT_DESCRIPTOR *)pD)->bEndpointAddress & 0x8F;
            m = (n & 0x80) ? ((1 << 16) << (n & 0x0F)) : (1 << n);
            USB_EndPointMask |= m;
            USB_ConfigEP((USB_ENDPOINT_DESCRIPTOR *)pD);
            USB_EnableEP(n);
            USB_ResetEP(n);
          }
          break;
      }
      pD = (USB_COMMON_DESCRIPTOR *)((BYTE *)pD + pD->bLength);
    }
  }
  else {
    USB_Configuration = 0;
    for (n = 1; n < 16; n++) {
      if (USB_EndPointMask & (1 << n)) {
        USB_DisableEP(n);
      }
      if (USB_EndPointMask & ((1 << 16) << n)) {
        USB_DisableEP(n | 0x80);
      }
    }
    USB_EndPointMask  = 0x00010001;
    USB_EndPointHalt  = 0x00000000;
    USB_Configure(FALSE);
  }

  if (USB_Configuration == SetupPacket.wValue.WB.L) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
制服丝袜亚洲精品中文字幕| 欧美日本高清视频在线观看| 欧美国产欧美综合| 欧美在线free| 欧美一区二区久久| 日本黄色一区二区| 国产亚洲欧美在线| 成人午夜视频网站| 午夜视频在线观看一区二区| 6080国产精品一区二区| 激情六月婷婷久久| 亚洲一区欧美一区| 国产精品国产精品国产专区不蜜 | 成熟亚洲日本毛茸茸凸凹| 欧美激情一区在线| 国产iv一区二区三区| 日韩电影在线观看网站| 成人性色生活片免费看爆迷你毛片| 国产黄人亚洲片| 亚洲天堂中文字幕| 成人免费在线播放视频| 极品瑜伽女神91| 26uuu另类欧美亚洲曰本| 亚洲美女区一区| 奇米精品一区二区三区在线观看 | 久久久不卡影院| 综合av第一页| 欧美国产一区在线| av爱爱亚洲一区| 久久精品国产精品亚洲综合| 看电视剧不卡顿的网站| 综合在线观看色| 日韩欧美aaaaaa| 欧美日高清视频| 6080日韩午夜伦伦午夜伦| 欧美性生活影院| 国产日本亚洲高清| 91九色最新地址| 欧美日韩dvd在线观看| 久久久美女毛片| 成人午夜精品在线| av一区二区三区在线| 欧美情侣在线播放| 欧美一区二区三区四区视频| 欧美激情一区二区三区四区| 五月婷婷激情综合| 亚洲国产裸拍裸体视频在线观看乱了| 色94色欧美sute亚洲线路一ni| 欧美二区三区91| 午夜激情久久久| 亚洲国产一区二区视频| av网站一区二区三区| 欧美午夜精品电影| 日本 国产 欧美色综合| 精品国产人成亚洲区| 欧美猛男gaygay网站| 国产精品盗摄一区二区三区| 欧美日韩一区二区三区不卡| 欧美喷潮久久久xxxxx| 国产成人av一区| 久久精品人人做人人综合| 欧美性三三影院| 日韩欧美国产午夜精品| 91国模大尺度私拍在线视频| 欧美放荡的少妇| 成人性色生活片| 欧美一区二区三区在线视频| 在线看不卡av| 日韩精品中文字幕在线不卡尤物| 7777精品伊人久久久大香线蕉的 | 精品国产乱码久久久久久蜜臀| 精品日韩在线一区| 日韩欧美国产一区在线观看| 夜色激情一区二区| 国产精品一区二区三区99| 色呦呦日韩精品| 欧美国产综合一区二区| 粉嫩蜜臀av国产精品网站| 日韩欧美电影在线| 日本va欧美va欧美va精品| 91精品久久久久久久99蜜桃| 伊人开心综合网| 欧美综合一区二区三区| 亚洲视频在线一区| 91看片淫黄大片一级| 亚洲激情在线激情| 欧美日韩色一区| 午夜视频一区在线观看| 日韩欧美国产一区在线观看| 激情综合色综合久久综合| 欧美精品一区视频| 成人一级片网址| 中文字幕亚洲不卡| 色婷婷综合久久久久中文| 亚洲午夜电影在线观看| 欧美高清视频在线高清观看mv色露露十八| 亚洲午夜一区二区三区| 欧美一区二区二区| 国产精品一区二区在线播放| 国产精品电影一区二区三区| 在线亚洲免费视频| 美女脱光内衣内裤视频久久影院| 精品国产人成亚洲区| 成人国产一区二区三区精品| 一级特黄大欧美久久久| 欧美一区二区三区免费在线看| 国产一区在线精品| 国产精品久久久久天堂| 欧美三级中文字| 另类综合日韩欧美亚洲| 中文字幕第一区二区| 欧美日韩性生活| 国产精华液一区二区三区| 亚洲激情六月丁香| 日韩精品一区二区三区在线播放| 成人天堂资源www在线| 伊人一区二区三区| 波多野结衣精品在线| 亚洲精品美国一| 91精品国产免费久久综合| 成人夜色视频网站在线观看| 亚洲成人自拍网| 国产日韩精品一区二区浪潮av| 欧美午夜精品免费| www..com久久爱| 久久丁香综合五月国产三级网站| 亚洲日本中文字幕区| 欧美mv日韩mv| 欧美日本一区二区在线观看| 成人午夜在线免费| 国产在线看一区| 午夜精品成人在线视频| 亚洲精品乱码久久久久久黑人| 日韩欧美黄色影院| 欧美日韩在线一区二区| 92精品国产成人观看免费| 精品一区二区三区在线播放视频 | 在线视频你懂得一区| 国产乱妇无码大片在线观看| 五月天精品一区二区三区| 亚洲欧洲无码一区二区三区| 久久人人超碰精品| 日韩一区二区三区视频在线| 欧美日韩在线播放三区四区| 97精品国产露脸对白| 丁香天五香天堂综合| 国产成人在线影院| 国产一区三区三区| 韩国理伦片一区二区三区在线播放 | 91福利视频在线| 99r国产精品| 色综合久久88色综合天天免费| 成人午夜又粗又硬又大| caoporm超碰国产精品| 国产999精品久久久久久| 国产风韵犹存在线视精品| 国产精品 日产精品 欧美精品| 国产一区二区三区在线观看免费 | 久久婷婷成人综合色| 欧美精品一区二区三区在线| 精品区一区二区| 一区二区三区丝袜| 中文字幕视频一区| 亚洲人成人一区二区在线观看 | 91视频在线观看| 国产精品亚洲一区二区三区妖精 | 蜜臀久久99精品久久久久久9 | 99re这里只有精品视频首页| 成人h精品动漫一区二区三区| 亚洲第一二三四区| 亚洲第一电影网| 日韩午夜av一区| 2023国产一二三区日本精品2022| 欧美mv和日韩mv的网站| 欧美色大人视频| 欧美久久一区二区| 青青草国产成人99久久| 亚洲欧洲日韩女同| 午夜成人免费电影| 国产精品一二三| 色哟哟欧美精品| 日韩精品资源二区在线| 中文字幕 久热精品 视频在线 | 国产一二三精品| 91玉足脚交白嫩脚丫在线播放| 欧美日韩一区二区三区四区五区| 欧美一区二区在线免费观看| 国产区在线观看成人精品| 一个色在线综合| 精品在线观看免费| 色婷婷av一区二区三区大白胸| 91精品综合久久久久久| 国产日韩av一区| 奇米影视在线99精品| 91美女片黄在线观看91美女| 欧美一二区视频| 一区二区三区影院| 国产福利不卡视频| 91精品国产综合久久小美女| 国产精品久久久久久久裸模|