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

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

?? usbcore.c

?? lpc2368 usb cdc的測試程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*----------------------------------------------------------------------------
 *      U S B  -  K e r n e l
 *----------------------------------------------------------------------------
 *      Name:    USBCORE.C
 *      Purpose: USB Core Module
 *      Version: V1.1x
 *----------------------------------------------------------------------------
 *      This file is part of the uVision/ARM development tools.
 *      This software may only be used under the terms of a valid, current,
 *      end user licence from KEIL for a compatible version of KEIL software
 *      development tools. Nothing else gives you the right to use it.
 *
 *      Copyright (c) 2005-2007 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

#if (USB_CDC)
#include "cdc.h"
#include "cdcuser.h"
#endif

#pragma diag_suppress 111,1441


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
 */

__inline 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)) {
        *((__packed 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)) {
        *((__packed 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
 */

__inline 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
 */

__inline 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
 */

__inline 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 {
            (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;
      }
      (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) {
    return (TRUE);
  } else {
    return (FALSE);
  }
}


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

__inline BOOL USB_SetInterface (void) {
  USB_COMMON_DESCRIPTOR *pD;
  DWORD                  ifn, alt, old, msk, n, m;
  BOOL                   set;

  if (USB_Configuration == 0) return (FALSE);

  set = FALSE;
  pD  = (USB_COMMON_DESCRIPTOR *)USB_ConfigDescriptor;
  while (pD->bLength) {
    switch (pD->bDescriptorType) {
      case USB_CONFIGURATION_DESCRIPTOR_TYPE:
        if (((USB_CONFIGURATION_DESCRIPTOR *)pD)->bConfigurationValue != USB_Configuration) {
          (BYTE *)pD += ((USB_CONFIGURATION_DESCRIPTOR *)pD)->wTotalLength;
          continue;
        }
        break;
      case USB_INTERFACE_DESCRIPTOR_TYPE:
        ifn = ((USB_INTERFACE_DESCRIPTOR *)pD)->bInterfaceNumber;
        alt = ((USB_INTERFACE_DESCRIPTOR *)pD)->bAlternateSetting;
        msk = 0;
        if ((ifn == SetupPacket.wIndex.WB.L) && (alt == SetupPacket.wValue.WB.L)) {
          set = TRUE;
          old = USB_AltSetting[ifn];
          USB_AltSetting[ifn] = (BYTE)alt;
        }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲尤物久久| 精品日产卡一卡二卡麻豆| 蜜桃视频免费观看一区| 亚洲欧洲日产国码二区| 51精品秘密在线观看| 99久久婷婷国产综合精品| 麻豆一区二区三| 国产呦萝稀缺另类资源| 一区二区在线免费观看| 国产视频一区不卡| 欧美高清www午色夜在线视频| 成人污视频在线观看| 国产精品女主播av| 精品国产凹凸成av人网站| 亚洲与欧洲av电影| 色综合 综合色| 成人性生交大片免费看视频在线| 久久久噜噜噜久久中文字幕色伊伊 | 欧美一区二区在线视频| 成人一区在线看| 蜜臀久久久99精品久久久久久| 中文字幕一区av| 91精品国产丝袜白色高跟鞋| 欧美日韩成人高清| 色偷偷成人一区二区三区91| 4438x亚洲最大成人网| 日韩欧美成人一区| 欧美国产激情二区三区| 老司机精品视频线观看86| 国产一区二区影院| 久草精品在线观看| 亚洲区小说区图片区qvod| 亚洲精品一区二区三区99| 欧美日韩国产小视频| 欧美情侣在线播放| 一区二区三区免费观看| 精品国产a毛片| 91成人在线观看喷潮| 91精品国产一区二区人妖| 2024国产精品视频| 一区二区中文字幕在线| 亚洲成人av电影在线| 欧美三级在线播放| 欧美大胆人体bbbb| 国产精品乱人伦| 亚洲成人一区在线| 国内精品免费**视频| 99麻豆久久久国产精品免费优播| 欧美三日本三级三级在线播放| 精品电影一区二区三区 | 91精品国产欧美一区二区| 26uuuu精品一区二区| 一区二区三区在线视频免费 | 国产精品综合在线视频| 91女神在线视频| 欧美一级精品在线| 日韩一区欧美小说| 国产乱码精品一区二区三区av| 色婷婷av一区二区三区大白胸 | 国产精品拍天天在线| 亚洲18影院在线观看| 国产九色精品成人porny| 欧洲另类一二三四区| 久久久久久久久久美女| 午夜精品久久久久| 不卡一卡二卡三乱码免费网站| 911精品国产一区二区在线| 日本一区二区久久| 久久99精品视频| 欧美性受xxxx黑人xyx性爽| 国产日韩av一区二区| 日本成人在线看| 欧美在线一二三| **欧美大码日韩| 国产精品亚洲人在线观看| 91精品国产综合久久精品app| 国产精品福利一区| 韩国女主播一区二区三区| 欧美性生活久久| ...xxx性欧美| 成人一区二区在线观看| 2023国产精品自拍| 日韩精品一区第一页| 一本色道久久综合亚洲aⅴ蜜桃| 久久久久国产精品麻豆ai换脸| 欧美aaa在线| 91精品国产一区二区三区| 夜夜嗨av一区二区三区网页| 成年人午夜久久久| 中文子幕无线码一区tr| 国产成人午夜高潮毛片| 精品蜜桃在线看| 捆绑紧缚一区二区三区视频| 欧美久久久久久蜜桃| 亚洲精品国产成人久久av盗摄| 国产91精品免费| 久久久99精品久久| 欧美日韩三级一区| 夜色激情一区二区| 91污片在线观看| 亚洲日本护士毛茸茸| 白白色 亚洲乱淫| 日韩一区欧美小说| 91麻豆123| 亚洲综合清纯丝袜自拍| 欧美在线看片a免费观看| 亚洲美女免费在线| 欧美私模裸体表演在线观看| 亚洲美女一区二区三区| 色中色一区二区| 亚洲一二三级电影| 91麻豆精品久久久久蜜臀| 日韩电影免费在线观看网站| 日韩欧美专区在线| 狠狠色狠狠色综合| 中文字幕欧美日韩一区| 成人精品鲁一区一区二区| 中文字幕一区二区不卡| 91黄视频在线| 丝瓜av网站精品一区二区| 欧美一级淫片007| 国产精品自拍三区| 亚洲欧洲三级电影| 在线观看日韩精品| 蜜臀精品一区二区三区在线观看| 日韩欧美中文字幕精品| 国产一区 二区| 国产精品对白交换视频| 色狠狠av一区二区三区| 日韩精品五月天| 久久亚洲综合色| 色婷婷综合久色| 青娱乐精品在线视频| 久久女同性恋中文字幕| jiyouzz国产精品久久| 亚洲自拍偷拍av| 精品美女在线观看| 色综合久久综合中文综合网| 午夜影院久久久| 久久久av毛片精品| 色999日韩国产欧美一区二区| 性做久久久久久久久| 精品国产免费视频| av在线这里只有精品| 五月婷婷欧美视频| 2022国产精品视频| 色综合久久综合中文综合网| 人人超碰91尤物精品国产| 国产日本欧洲亚洲| 欧美日韩在线精品一区二区三区激情| 久久99精品一区二区三区三区| 中文字幕中文字幕中文字幕亚洲无线| 欧美性做爰猛烈叫床潮| 国产乱子轮精品视频| 一区二区三国产精华液| 精品动漫一区二区三区在线观看| 91视频国产观看| 麻豆精品久久久| 夜色激情一区二区| 久久久久久亚洲综合| 欧美日韩情趣电影| 99视频一区二区| 精品一区二区三区在线播放 | 美日韩一区二区| 亚洲人123区| 久久久精品综合| 欧美日韩国产一级| 99久久99久久综合| 另类小说欧美激情| 亚洲一区二区三区国产| 国产三级精品在线| 91精品欧美久久久久久动漫| 不卡一区二区中文字幕| 久久99国产精品免费| 一二三四区精品视频| 国产精品视频一二三区| 日韩欧美久久久| 欧美日产国产精品| av电影在线不卡| 国产精品1区2区| 美女视频网站久久| 亚洲成人激情综合网| 综合久久久久久久| 国产欧美一区二区在线| 日韩精品一区在线| 欧美日韩精品一区二区三区蜜桃 | 欧美揉bbbbb揉bbbbb| www.色精品| 国产乱码精品一区二区三区忘忧草| 首页综合国产亚洲丝袜| 亚洲黄色av一区| 136国产福利精品导航| 久久精子c满五个校花| 日韩一区二区在线看| 欧美三区免费完整视频在线观看| 99国产精品久久久久久久久久久| 国产福利一区二区三区视频| 精品一区二区影视| 美女视频黄 久久| 免费一区二区视频|