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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? usbhw.c

?? USB聲音驅(qū)動(dòng),基于NXP ARM7.已在KEIL下調(diào)試通過.
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/*----------------------------------------------------------------------------
 *      U S B  -  K e r n e l
 *----------------------------------------------------------------------------
 *      Name:    USBHW.C
 *      Purpose: USB Hardware Layer Module for Philips LPC214x
 *      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 "LPC23xX.H"                        /* LPC230x definitions */
#include "type.h"
#include "usb.h"
#include "usbcfg.h"
#include "usbreg.h"
#include "usbhw.h"
#include "usbcore.h"
#include "usbuser.h"
#include "target.h"
#include "irq.h"

volatile DWORD DeviceInterruptCount = 0;
volatile DWORD DevStatusReset = 0;
volatile DWORD DevStatusSuspend = 0;
volatile DWORD DevStatusResume = 0;
volatile DWORD DevStatusConnect = 0;
volatile DWORD DevStatusConnectChange = 0;
volatile DWORD DevStatusSuspendChange = 0;
volatile DWORD DeviceStatusValue = 0;

#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
#if KEIL_IDE
DWORD UDCA[USB_EP_NUM] __at USB_RAM_ADR;    /* UDCA in USB RAM */
#else
DWORD *UDCA = (DWORD *)(USB_RAM_ADR);
#endif
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) {

  DeviceInterruptCount = 0;
  DevStatusReset = 0;
  DevStatusSuspend = 0;
  DevStatusResume = 0;
  DevStatusConnect = 0;
  DevStatusConnectChange = 0;

  OTG_CLK_CTRL = 0x12;	/* This module is sent for USB device compliance 
			test. Host and Device are enabled. The host enabling is
			to address USB needClk issue. */ 
  while ( (OTG_CLK_STAT & 0x12) != 0x12 );
  /* For both 100-pin and 144 pin package, if U1 is used, both host and device 
  clock need to be enabled, on 144-pin package, if U2 is used, OTG clock needs
  to enabled as well. In this case, set OTG_CLK_CTRL to 0x1F. */

#if 0
  /* Below lines will be needed if USB_U2 is used as USB Device. for old MCB2300
  board, U2 is used as USB device, on new MCB2300, U1 is used as USB device. */
  /* In order to setup OTG_STAT_CTRL register, OTG clock needs to be enabled as 
  well: */
  OTG_CLK_CTRL = 0x1F;
  while ( (OTG_CLK_STAT & 0x1F) != 0x1F ); 
  OTG_STAT_CTRL = 0x02;		/* This has to be set after OTG_CLK_CTRL configuration. */
#endif
 
  /* P2.9 is USB1 SoftConnect, P1.18 is GoodLink, P0.29 is USB1_D+, 
  P0.30 is USB1_D-. PINSEL1 bit 26~27 0x01, bit 28~29 0x01. 
  PINSEL3 bit 4~5 0x01. PINSEL4, bit 18~19 0x01. */
  PINSEL1 &= ~0x3C000000;
  PINSEL1 |= 0x14000000;

  /* P1.30 is VBus, for testing purpose, I will try both VBus enable and
  GPIO for polling. P1.30, PINSEL3 28~29, 0x10. It should not make any difference
  on the Keil MCB2300 board. */
  PINSEL3 &= ~0x30000030;
  PINSEL3 |= 0x20000010;

  /* 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
  /* This is for rev. "A". */
  PINSEL4 &= ~0x000C0000;
  PINSEL4 |= 0x000040000;
#else
  /* This is for rev. "-". */
  PINSEL4 &= ~0x000C0000;
  FIO2DIR |= (1 << 9);
  FIO2CLR = 1 << 9;
#endif
	
  install_irq( USB_INT, (void *)USB_ISR, HIGHEST_PRIORITY );
    
  USB_Reset();
  USB_SetAddress(0);

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

  return;
}


/*
 *  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;
#if KEIL_IDE
    UDCA[n] = 0;
#else
	*((DWORD *)(UDCA+n)) = 0;
#endif
  }
#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) {
  cfg = 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) {
  dir = 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

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区在线免费观看| 成人午夜电影网站| 亚洲成人一二三| 亚洲免费在线观看| 一区二区三区四区蜜桃| 亚洲精选视频免费看| 亚洲色图欧洲色图| 亚洲精品国产精品乱码不99| 1024精品合集| 亚洲欧美另类综合偷拍| 亚洲欧美日韩综合aⅴ视频| 一区二区在线观看av| 亚洲制服丝袜一区| 午夜视频在线观看一区二区三区| 午夜免费久久看| 日韩综合一区二区| 秋霞影院一区二区| 麻豆精品一区二区三区| 精品一区免费av| 国产精品影视在线观看| 国产成人免费高清| 97久久精品人人做人人爽50路| 99精品视频中文字幕| 91福利资源站| 日韩免费观看高清完整版| 精品久久久久一区| 国产精品第13页| 亚洲综合在线五月| 蜜臀av性久久久久蜜臀aⅴ流畅| 久久91精品国产91久久小草| 国产一区91精品张津瑜| zzijzzij亚洲日本少妇熟睡| 一本到不卡免费一区二区| 欧美日韩黄色一区二区| xfplay精品久久| 综合亚洲深深色噜噜狠狠网站| 亚洲高清中文字幕| 国产在线观看一区二区| 99久久精品免费精品国产| 欧美日韩国产a| 久久久久久久久久久久电影 | 亚洲高清三级视频| 蜜臀国产一区二区三区在线播放| 国产麻豆9l精品三级站| 91高清视频免费看| 久久亚区不卡日本| 一区二区三区精品| 国内外成人在线| 日本韩国精品在线| 欧美xxxx老人做受| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 1区2区3区欧美| 美女被吸乳得到大胸91| 91麻豆免费看| 精品福利一区二区三区| 中文字幕一区二区三区色视频| 亚洲一区二区在线视频| 韩国女主播一区二区三区| 91小宝寻花一区二区三区| 日韩免费看网站| 亚洲六月丁香色婷婷综合久久| 国产精品高潮久久久久无| 蜜桃av噜噜一区二区三区小说| 国产91精品一区二区| 日韩欧美亚洲一区二区| 国产精品久久久久久福利一牛影视| 日韩国产精品91| 不卡av在线网| 久久精品亚洲一区二区三区浴池 | 亚洲精品久久久蜜桃| 麻豆91精品视频| 欧美午夜电影一区| 国产日韩视频一区二区三区| 99精品在线观看视频| 日韩视频免费观看高清完整版| 综合精品久久久| 九九热在线视频观看这里只有精品| 色88888久久久久久影院按摩| 精品盗摄一区二区三区| 日韩中文字幕区一区有砖一区 | 亚洲最新视频在线观看| 国产呦萝稀缺另类资源| 日韩一区二区三区高清免费看看| 亚洲色图一区二区三区| 成人国产精品视频| 国产日韩精品一区| 精品一区二区日韩| 欧美高清一级片在线| 一区二区三区在线看| 丁香天五香天堂综合| 久久久www成人免费毛片麻豆| 丝袜国产日韩另类美女| 欧美日韩一区 二区 三区 久久精品 | 日韩一区二区电影| 亚洲成av人片在www色猫咪| 波波电影院一区二区三区| 久久久九九九九| 经典一区二区三区| 欧美va在线播放| 日韩av在线发布| 日韩免费观看高清完整版| 丝袜美腿亚洲色图| 日韩一级二级三级| 亚洲午夜成aⅴ人片| 欧美图区在线视频| 一区二区三区四区亚洲| 欧美日韩美女一区二区| 亚洲视频一二三区| 国产精品第一页第二页第三页| 日本不卡一二三区黄网| 欧美一区二区免费视频| 偷拍一区二区三区| 欧美一区二区三区在线视频| 夜夜嗨av一区二区三区网页 | 国产精品久久久久久久裸模| www.av精品| 中文字幕中文字幕一区| 一本久久a久久精品亚洲| 亚洲四区在线观看| 欧美无砖砖区免费| 婷婷六月综合亚洲| 精品人伦一区二区色婷婷| 麻豆视频观看网址久久| 久久影院视频免费| 国产剧情av麻豆香蕉精品| 国产精品福利av| 色哟哟欧美精品| 日韩精品亚洲专区| 精品国产a毛片| 国产91高潮流白浆在线麻豆 | 日日夜夜免费精品| 欧美日韩卡一卡二| 久久99精品久久久久久久久久久久 | 国产大陆亚洲精品国产| 亚洲色图欧美偷拍| 欧美性感一类影片在线播放| 免费观看成人av| 欧美国产欧美亚州国产日韩mv天天看完整| 国产激情91久久精品导航| 一区二区三区在线免费视频| 欧美日韩三级在线| 国产激情偷乱视频一区二区三区| 中文字幕一区二区三区在线不卡 | 91精品国产品国语在线不卡| 麻豆精品视频在线| 国产亚洲精品福利| 99久久99久久久精品齐齐| 午夜久久久久久久久| 精品不卡在线视频| 成人精品免费看| 日日骚欧美日韩| 久久亚洲春色中文字幕久久久| 色婷婷亚洲一区二区三区| 亚洲自拍偷拍综合| 日韩你懂的在线播放| 91免费观看在线| 日本色综合中文字幕| 中文字幕欧美一区| 欧美精品久久久久久久多人混战| 精品一区二区久久久| 亚洲天堂av一区| 久久综合一区二区| 91美女在线看| 国产成人丝袜美腿| 亚洲高清免费在线| 最新国产精品久久精品| 欧美一级高清片在线观看| 91丝袜高跟美女视频| 午夜精品成人在线视频| 国产精品第五页| 欧洲在线/亚洲| 高清不卡在线观看av| 日本亚洲三级在线| 18欧美亚洲精品| 国产欧美日韩精品a在线观看| 欧美丝袜丝交足nylons图片| 成人亚洲一区二区一| 偷拍亚洲欧洲综合| 一区二区欧美视频| 国产欧美一区二区精品秋霞影院| 欧美精品乱码久久久久久| 国产成人免费在线观看不卡| 蜜桃精品视频在线| 午夜电影网亚洲视频| 国产精品嫩草影院com| 久久久国产精华| 制服丝袜激情欧洲亚洲| 欧美在线综合视频| 成人性视频免费网站| 国产激情精品久久久第一区二区 | 亚洲一区欧美一区| 国产日产亚洲精品系列| 日韩限制级电影在线观看| 欧美挠脚心视频网站| 精品一区二区三区在线视频| 午夜精品一区二区三区免费视频 | 偷拍一区二区三区| 天天综合日日夜夜精品| 中文字幕人成不卡一区| 国产精品国产三级国产aⅴ入口|