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

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

?? usbhw.c

?? LPC23XX USB hid keyboard
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*----------------------------------------------------------------------------
 *      U S B  -  K e r n e l
 *----------------------------------------------------------------------------
 *      Name:    USBHW.C
 *      Purpose: USB Hardware Layer Module for Philips LPC214x/LPC318x/23xx/24xx
 *      Version: V1.10
 *----------------------------------------------------------------------------
 *      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-2006 Keil Software.
 *---------------------------------------------------------------------------*/

#include <LPC23xx.H>                        /* LPC23xx definitions */

#include "type.h"

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


#pragma diag_suppress 1441


#define EP_MSK_CTRL 0x0001      /* Control Endpoint Logical Address Mask */
#define EP_MSK_BULK 0xC924      /* Bulk Endpoint Logical Address Mask */
#define EP_MSK_INT  0x4492      /* Interrupt Endpoint Logical Address Mask */
#define EP_MSK_ISO  0x1248      /* Isochronous Endpoint Logical Address Mask */


#if USB_DMA

#pragma arm section zidata = "USB_RAM"
DWORD UDCA[USB_EP_NUM];                     /* UDCA in USB RAM */
DWORD DD_NISO_Mem[4*DD_NISO_CNT];           /* Non-Iso DMA Descriptor Memory */
DWORD DD_ISO_Mem [5*DD_ISO_CNT];            /* Iso DMA Descriptor Memory */
#pragma arm section zidata
DWORD udca[USB_EP_NUM];                     /* UDCA saved values */

DWORD DDMemMap[2];                          /* DMA Descriptor Memory Usage */

#endif


/*
 *  Get Endpoint Physical Address
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    Endpoint Physical Address
 */

DWORD EPAdr (DWORD EPNum) {
  DWORD val;

  val = (EPNum & 0x0F) << 1;
  if (EPNum & 0x80) {
    val += 1;
  }
  return (val);
}


/*
 *  Write Command
 *    Parameters:      cmd:   Command
 *    Return Value:    None
 */

void WrCmd (DWORD cmd) {

  DEV_INT_CLR = CCEMTY_INT;
  CMD_CODE = cmd;
 while ((DEV_INT_STAT & CCEMTY_INT) == 0);
}


/*
 *  Write Command Data
 *    Parameters:      cmd:   Command
 *                     val:   Data
 *    Return Value:    None
 */

void WrCmdDat (DWORD cmd, DWORD val) {

  DEV_INT_CLR = CCEMTY_INT;
  CMD_CODE = cmd;
  while ((DEV_INT_STAT & CCEMTY_INT) == 0);
  DEV_INT_CLR = CCEMTY_INT;
  CMD_CODE = val;
  while ((DEV_INT_STAT & CCEMTY_INT) == 0);
}


/*
 *  Read Command Data
 *    Parameters:      cmd:   Command
 *    Return Value:    Data Value
 */

DWORD RdCmdDat (DWORD cmd) {

  DEV_INT_CLR = CCEMTY_INT | CDFULL_INT;
  CMD_CODE = cmd;
  while ((DEV_INT_STAT & CDFULL_INT) == 0);
  return (CMD_DATA);
}


/*
 *  USB Initialize Function
 *   Called by the User to initialize USB
 *    Return Value:    None
 */

void USB_Init (void) {

  PINSEL1 &= ~0x3C000000;                 /* P0.29 USB1_D+, P0.30 USB1_D- */ 
  PINSEL1 |=  0x14000000;                 /* PINSEL1 26.27, 28.29         */

  PINSEL3 &= ~0x30000030;                 /* P1.18 GoodLink, P1.30 VBus   */
  PINSEL3 |=  0x20000010;                 /* PINSEL3 4.5, 28.29           */

  /* The SoftConnect pin for LPC2300 on USB_U1 doesn't work for now, 
     make it GPIO and make it low to turn on pull-up on D+. 
	 Once it's fixed, make #if 1 and set it as SoftConn Pin. */
#if 0
  PINSEL4 &= ~0x000C0000;                 /* P2.9 USB1 SoftConnect        */
  PINSEL4 |= 0x000040000;                 /* PINSEl4 18.19                */
#else
  PINSEL4 &= ~0x000C0000;
  FIO2DIR |= (1 << 9);
  FIO2CLR  = (1 << 9);
#endif
	
  PCONP |= 0x80000000;                    /* USB PCLK -> enable USB Per.  */

  OTG_CLK_CTRL = 0x12;	                  /* Dev clock, AHB clock enable  */
  while ((OTG_CLK_STAT & 0x12) != 0x12);
  
  VICVectAddr22 = (unsigned long)USB_ISR; /* USB Interrupt -> Vector 22   */
  VICVectCntl22 = 0x01;                   /* USB Interrupt -> Priority  1   */
  VICIntEnable = 1 << 22;                 /* Enable USB Interrupt         */

//  DEV_INT_EN = DEV_STAT_INT;              /* Enable Device Status Interrupt */

#if 1 /* Partial Manual Reset since Automatic Bus Reset is not working */
  USB_Reset();
  USB_SetAddress(0);
#endif
}


/*
 *  USB Connect Function
 *   Called by the User to Connect/Disconnect USB
 *    Parameters:      con:   Connect/Disconnect
 *    Return Value:    None
 */

void USB_Connect (BOOL con) {
  WrCmdDat(CMD_SET_DEV_STAT, DAT_WR_BYTE(con ? DEV_CON : 0));
}


/*
 *  USB Reset Function
 *   Called automatically on USB Reset
 *    Return Value:    None
 */

void USB_Reset (void) {
#if USB_DMA
  DWORD n;
#endif

  EP_INDEX = 0;
  MAXPACKET_SIZE = USB_MAX_PACKET0;
  EP_INDEX = 1;
  MAXPACKET_SIZE = USB_MAX_PACKET0;
  while ((DEV_INT_STAT & EP_RLZED_INT) == 0);

  EP_INT_CLR  = 0xFFFFFFFF;
  EP_INT_EN   = 0xFFFFFFFF ^ USB_DMA_EP;
  DEV_INT_CLR = 0xFFFFFFFF;
  DEV_INT_EN  = DEV_STAT_INT    | EP_SLOW_INT    |
               (USB_SOF_EVENT   ? FRAME_INT : 0) |
               (USB_ERROR_EVENT ? ERR_INT   : 0);

#if USB_DMA
  UDCA_HEAD   = USB_RAM_ADR;
  DMA_REQ_CLR = 0xFFFFFFFF;
  EP_DMA_DIS  = 0xFFFFFFFF;
  EP_DMA_EN   = USB_DMA_EP;
  EOT_INT_CLR = 0xFFFFFFFF;
  NDD_REQ_INT_CLR = 0xFFFFFFFF;
  SYS_ERR_INT_CLR = 0xFFFFFFFF;
  DMA_INT_EN  = 0x00000007;
  DDMemMap[0] = 0x00000000;
  DDMemMap[1] = 0x00000000;
  for (n = 0; n < USB_EP_NUM; n++) {
    udca[n] = 0;
    UDCA[n] = 0;
  }
#endif
}


/*
 *  USB Suspend Function
 *   Called automatically on USB Suspend
 *    Return Value:    None
 */

void USB_Suspend (void) {
  /* Performed by Hardware */
}


/*
 *  USB Resume Function
 *   Called automatically on USB Resume
 *    Return Value:    None
 */

void USB_Resume (void) {
  /* Performed by Hardware */
}


/*
 *  USB Remote Wakeup Function
 *   Called automatically on USB Remote Wakeup
 *    Return Value:    None
 */

void USB_WakeUp (void) {

  if (USB_DeviceStatus & USB_GETSTATUS_REMOTE_WAKEUP) {
    WrCmdDat(CMD_SET_DEV_STAT, DAT_WR_BYTE(DEV_CON));
  }
}


/*
 *  USB Remote Wakeup Configuration Function
 *    Parameters:      cfg:   Enable/Disable
 *    Return Value:    None
 */

void USB_WakeUpCfg (BOOL cfg) {
  /* Not needed */
}


/*
 *  USB Set Address Function
 *    Parameters:      adr:   USB Address
 *    Return Value:    None
 */

void USB_SetAddress (DWORD adr) {
  WrCmdDat(CMD_SET_ADDR, DAT_WR_BYTE(DEV_EN | adr)); /* Don't wait for next */
  WrCmdDat(CMD_SET_ADDR, DAT_WR_BYTE(DEV_EN | adr)); /*  Setup Status Phase */
}


/*
 *  USB Configure Function
 *    Parameters:      cfg:   Configure/Deconfigure
 *    Return Value:    None
 */

void USB_Configure (BOOL cfg) {

  WrCmdDat(CMD_CFG_DEV, DAT_WR_BYTE(cfg ? CONF_DVICE : 0));

  REALIZE_EP = 0x00000003;
  while ((DEV_INT_STAT & EP_RLZED_INT) == 0);
  DEV_INT_CLR = EP_RLZED_INT;
}


/*
 *  Configure USB Endpoint according to Descriptor
 *    Parameters:      pEPD:  Pointer to Endpoint Descriptor
 *    Return Value:    None
 */

void USB_ConfigEP (USB_ENDPOINT_DESCRIPTOR *pEPD) {
  DWORD num;

  num = EPAdr(pEPD->bEndpointAddress);
  REALIZE_EP |= (1 << num);
  EP_INDEX = num;
  MAXPACKET_SIZE = pEPD->wMaxPacketSize;
  while ((DEV_INT_STAT & EP_RLZED_INT) == 0);
  DEV_INT_CLR = EP_RLZED_INT;
}


/*
 *  Set Direction for USB Control Endpoint
 *    Parameters:      dir:   Out (dir == 0), In (dir <> 0)
 *    Return Value:    None
 */

void USB_DirCtrlEP (DWORD dir) {
  /* Not needed */
}


/*
 *  Enable USB Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    None
 */

void USB_EnableEP (DWORD EPNum) {
  WrCmdDat(CMD_SET_EP_STAT(EPAdr(EPNum)), DAT_WR_BYTE(0));
}


/*
 *  Disable USB Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    None
 */

void USB_DisableEP (DWORD EPNum) {
  WrCmdDat(CMD_SET_EP_STAT(EPAdr(EPNum)), DAT_WR_BYTE(EP_STAT_DA));
}


/*
 *  Reset USB Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    None
 */

void USB_ResetEP (DWORD EPNum) {
  WrCmdDat(CMD_SET_EP_STAT(EPAdr(EPNum)), DAT_WR_BYTE(0));
}


/*
 *  Set Stall for USB Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    None
 */

void USB_SetStallEP (DWORD EPNum) {
  WrCmdDat(CMD_SET_EP_STAT(EPAdr(EPNum)), DAT_WR_BYTE(EP_STAT_ST));
}


/*
 *  Clear Stall for USB Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    None
 */

void USB_ClrStallEP (DWORD EPNum) {
  WrCmdDat(CMD_SET_EP_STAT(EPAdr(EPNum)), DAT_WR_BYTE(0));
}


/*
 *  Read USB Endpoint Data
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *                     pData: Pointer to Data Buffer
 *    Return Value:    Number of bytes read
 */

DWORD USB_ReadEP (DWORD EPNum, BYTE *pData) {
  DWORD cnt, n;

  USB_CTRL = ((EPNum & 0x0F) << 2) | CTRL_RD_EN;

  do {
    cnt = RX_PLENGTH;
  } while ((cnt & PKT_RDY) == 0);
  cnt &= PKT_LNGTH_MASK;

  for (n = 0; n < (cnt + 3) / 4; n++) {
    *((__packed DWORD *)pData) = RX_DATA;
    pData += 4;
  }

  USB_CTRL = 0;

  if (((EP_MSK_ISO >> EPNum) & 1) == 0) {   /* Non-Isochronous Endpoint */
    WrCmd(CMD_SEL_EP(EPAdr(EPNum)));
    WrCmd(CMD_CLR_BUF);
  }

  return (cnt);
}


/*
 *  Write USB Endpoint Data
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *                     pData: Pointer to Data Buffer
 *                     cnt:   Number of bytes to write
 *    Return Value:    Number of bytes written
 */

DWORD USB_WriteEP (DWORD EPNum, BYTE *pData, DWORD cnt) {
  DWORD n;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美乱综合| 日韩欧美123| 精品在线免费视频| 国产亚洲精品aa| 在线观看日韩国产| 一区二区三区高清| 欧美国产成人在线| 一道本成人在线| 欧洲亚洲精品在线| 欧美三级电影网| 精品国产百合女同互慰| 国产日韩欧美综合一区| 中文字幕亚洲欧美在线不卡| 一区二区在线观看视频在线观看| 亚洲综合久久av| 国产乱子伦一区二区三区国色天香| 韩国毛片一区二区三区| 91蜜桃在线免费视频| 精品久久久久久久久久久久久久久久久| 欧美一级午夜免费电影| 国产偷国产偷精品高清尤物| 亚洲一区二区三区视频在线 | 久久精品在这里| 亚洲成人激情av| caoporm超碰国产精品| 在线成人免费视频| 综合在线观看色| 国产一区二区主播在线| 欧美区视频在线观看| 亚洲一区二区精品视频| 欧美一区二区女人| 欧美精品xxxxbbbb| 1024成人网| 国产成人综合亚洲91猫咪| 日韩一区二区麻豆国产| 亚洲国产精品一区二区久久| 99久久综合精品| 国产精品久久久久久久久果冻传媒| 韩国三级电影一区二区| 日韩欧美二区三区| 国产中文字幕精品| 精品国产乱码久久久久久牛牛| 免费欧美日韩国产三级电影| 91精品国产综合久久久久久| 丝袜美腿亚洲一区二区图片| 欧美一区二区在线免费播放| 蜜桃免费网站一区二区三区| 日韩一区二区精品在线观看| 青青草成人在线观看| 久久蜜桃av一区二区天堂 | 99国产欧美另类久久久精品| 国产精品丝袜一区| 欧美亚洲国产一卡| 日韩av中文在线观看| 久久女同性恋中文字幕| 国产成人午夜高潮毛片| 亚洲精品日日夜夜| 欧美成人一区二区| 99热在这里有精品免费| 亚洲第一电影网| xf在线a精品一区二区视频网站| 欧美怡红院视频| 美国十次综合导航| 一区二区三区高清| 精品国产一区二区国模嫣然| 9人人澡人人爽人人精品| 五月天激情综合| 亚洲精品国产无套在线观| 日韩三级.com| 精品视频免费在线| 99久精品国产| 国产九九视频一区二区三区| 日精品一区二区| 亚洲精品v日韩精品| 国产亚洲一区二区在线观看| 在线观看成人免费视频| 奇米精品一区二区三区在线观看| 日韩电影一二三区| 一区二区三区四区蜜桃| 国产精品久久久久桃色tv| 精品国产乱码久久久久久久| 欧美高清hd18日本| 91精品福利在线一区二区三区| 在线免费观看日韩欧美| 色婷婷综合久久| 欧美性色黄大片手机版| 精品福利一区二区三区免费视频| 日本欧美久久久久免费播放网| 亚洲天堂2014| 亚洲精选在线视频| 亚洲精品国产一区二区精华液| 亚洲欧美一区二区三区孕妇| 亚洲欧洲日产国产综合网| 亚洲免费在线观看| 亚洲国产aⅴ成人精品无吗| 日韩经典一区二区| 国内精品伊人久久久久影院对白| 免费看黄色91| 成人福利视频在线看| 在线精品观看国产| 日韩欧美一区中文| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 久久精品久久99精品久久| 精品一区二区三区蜜桃| 成人午夜大片免费观看| 欧美日韩专区在线| 久久久久久**毛片大全| 亚洲日本在线看| 美女诱惑一区二区| 91视频精品在这里| 亚洲精品在线电影| 亚洲国产日韩在线一区模特| 国产在线精品免费av| 欧美亚洲动漫另类| 国产精品久久久久久久久免费桃花| 亚洲成人免费电影| 91亚洲国产成人精品一区二三| 欧美一区二区黄色| 亚洲国产综合色| 成人午夜激情在线| 久久影院午夜论| 精一区二区三区| 日韩一卡二卡三卡国产欧美| 亚洲高清免费在线| 欧洲色大大久久| 怡红院av一区二区三区| 色婷婷久久久亚洲一区二区三区| 久久蜜臀精品av| 成人免费电影视频| 国产精品视频第一区| 成人午夜精品在线| 亚洲乱码国产乱码精品精的特点 | 依依成人综合视频| 欧美在线免费观看亚洲| 亚洲综合免费观看高清在线观看| 99久久精品久久久久久清纯| 专区另类欧美日韩| 欧美中文一区二区三区| 夜色激情一区二区| 欧美日韩高清一区二区不卡| 亚洲福利国产精品| xnxx国产精品| 色综合天天综合给合国产| 成人免费观看视频| 亚洲在线视频一区| 日韩欧美综合一区| 成人在线综合网| 亚洲第一福利一区| 国产欧美一区二区精品性色超碰| 91在线精品一区二区| 日韩激情一二三区| 欧美高清在线一区二区| 欧美人成免费网站| 不卡的av网站| 蜜臀精品久久久久久蜜臀| 中文字幕在线一区| 欧美精品99久久久**| 色先锋资源久久综合| 日本不卡中文字幕| 国产精品久久久久精k8| 欧美久久一区二区| 色综合天天在线| 成人午夜激情片| 国产伦理精品不卡| 久久福利视频一区二区| 一区二区国产视频| 国产精品欧美精品| 亚洲国产高清不卡| 精品伦理精品一区| 欧美一区二区三区在线观看| 日本精品一区二区三区高清| 国产成人综合亚洲91猫咪| 蜜桃久久av一区| 久久精品99国产国产精| 青青草97国产精品免费观看| 天堂午夜影视日韩欧美一区二区| 一区二区欧美国产| 亚洲小说春色综合另类电影| 亚洲一区二区三区视频在线| 亚洲天堂网中文字| 亚洲少妇屁股交4| 亚洲一区二区三区四区中文字幕| 亚洲精品自拍动漫在线| 亚洲综合色婷婷| 日韩精品欧美成人高清一区二区| 日韩极品在线观看| 国产一区二区三区四| 97久久久精品综合88久久| 色诱视频网站一区| 欧美日本国产一区| 欧美成人女星排名| 国产精品日日摸夜夜摸av| 亚洲欧美乱综合| 免费观看91视频大全| 成人免费va视频| 欧美一区二区三区色| 国产精品久久久久影院亚瑟| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美偷拍一区二区| 欧美mv日韩mv国产网站|