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

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

?? usbhw.c

?? 基于LPC2000 ARM7的設備驅動程序,已在KEIL下調試通過
?? 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.05
 *----------------------------------------------------------------------------
 *      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"                        /* LPC23xx/24xx definitions */

#include "type.h"
#include "irq.h"
#include "target.h"
#include "timer.h"

#include "usb.h"
#include "usbcfg.h"
#include "usbreg.h"
#include "usbhw.h"
#include "usbcore.h"
#include "usbuser.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;

#if POWERDOWN_MODE_USB_WAKEUP
volatile DWORD SuspendFlag = 0;
extern volatile DWORD timer0_counter;
#endif

#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

DWORD UDCA[USB_EP_NUM] __at USB_RAM_ADR;    /* UDCA in USB RAM */
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 | CDFULL_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 (DWORD BoardType) 
{
  DeviceInterruptCount = 0;
  DevStatusReset = 0;
  DevStatusSuspend = 0;
  DevStatusResume = 0;
  DevStatusConnect = 0;
  DevStatusConnectChange = 0;
  SuspendFlag = 0;

  if ( BoardType == ENG_BOARD_LPC24XX )
  {
	OTG_CLK_CTRL = 0x1B;	/* 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 & 0x1B) != 0x1B );
	/* Configure port 2 (side B) to be used as device */
	OTG_STAT_CTRL = 0x03;
 
	// P0.13   = USB-b:LEDn, P0.14   = USB-b:Device_En-Bn
	PINSEL0 &= ~0x3C000000;
	PINSEL0 |= 0x24000000;

	// P0.31    = USB:D+B
	PINSEL1 &= ~0xC0000000;
	PINSEL1 |= 0x40000000;

	// P1.30    = USB-b:VBUS-B
	PINSEL3 &= ~0x30000000;
	PINSEL3 |= 0x20000000;

	// Drive the host VBUS power switch enables low, to turn it off.
	IODIR0 |= ((1 << 12)|(1 << 19)); // P0.12 and P0.19 are output
	IOCLR0 |= ((1 << 12)|(1 << 19)); // P0.12 and P0.19 are 0
  }
  else if ( BoardType == KEIL_BOARD_LPC23XX )
  {
	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 = 0x1B;
	while ( (OTG_CLK_STAT & 0x1B) != 0x1B ); 
	OTG_STAT_CTRL = 0x03;		/* 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
  }
  else if ( BoardType == EA_BOARD_LPC24XX )
  {
	/* On Embedded Artists's LPC24xx OEM board, U2 is used as USB device. */
	/* In order to setup OTG_STAT_CTRL register, OTG clock needs to be enabled 
	as well: */
	OTG_CLK_CTRL = 0x1B;
	while ( (OTG_CLK_STAT & 0x1B) != 0x1B ); 
	OTG_STAT_CTRL = 0x03;	/* This has to be set after OTG_CLK_CTRL configuration. */
 
	/* On USB port2, P0.13 is GoodLink, P0.14 is SoftConnect,
	P0.31 is D+, D- is a dedicated pin which doesn't belong to any port, 
	PINSEL0 bit 26~27 0x01. PINSEL0, bit 28~29 0x10.
	PINSEL1 bit 30~31 0x01. */
	PINSEL0 &= ((0x03 << 26) | (0x03 << 28));
	PINSEL0 |= ((0x01 << 26) | (0x02 << 28));
	PINSEL1 &= 0x3FFFFFFF;
	PINSEL1 |= (0x01 << 30);

	/* 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;
    UDCA[n] = 0;
  }
#endif
}


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

void USB_Suspend (void) {
  /* Performed by Hardware */
#if POWERDOWN_MODE_USB_WAKEUP
  timer0_counter = 0;
  enable_timer( 0 );
  
  if ( SuspendFlag == 0 ) {
	SuspendFlag = 1;
  }
#endif
}


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

void USB_Resume (void) {
  /* Performed by Hardware */
#if POWERDOWN_MODE_USB_WAKEUP
  disable_timer( 0 );
  timer0_counter = 0;
  if ( SuspendFlag == 1 ) {
	SuspendFlag = 0;
  }
#endif
}


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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲男人天堂av| 亚洲欧洲日产国码二区| 欧美亚洲丝袜传媒另类| av一本久道久久综合久久鬼色| 蜜臂av日日欢夜夜爽一区| 日韩主播视频在线| 亚洲一区二区视频| 天天综合色天天综合| 日韩高清国产一区在线| 蜜乳av一区二区| 国产一区二区三区在线观看免费| 韩国中文字幕2020精品| 成人久久18免费网站麻豆| 成人精品一区二区三区中文字幕| av电影在线观看一区| 99国产欧美另类久久久精品| 日本福利一区二区| 91天堂素人约啪| 欧美日本精品一区二区三区| 欧美一区欧美二区| 国产三级欧美三级日产三级99| 中文一区二区完整视频在线观看| 亚洲色图欧洲色图| 午夜精品久久久久久久久久久 | 国产主播一区二区三区| 国产乱码精品一区二区三区av| 成人小视频在线| 欧美日韩成人综合天天影院| 日韩精品一区二区三区中文精品| 国产亚洲成年网址在线观看| 亚洲免费资源在线播放| 青青草97国产精品免费观看| www.在线成人| 91精品国产一区二区三区香蕉 | 中文字幕亚洲不卡| 亚洲成av人片www| 成人免费毛片片v| 91精品久久久久久久久99蜜臂| 国产婷婷色一区二区三区| 亚洲另类春色校园小说| 美美哒免费高清在线观看视频一区二区 | 91麻豆精品国产91久久久久 | jvid福利写真一区二区三区| 欧美女孩性生活视频| 久久众筹精品私拍模特| 亚洲成精国产精品女| eeuss鲁片一区二区三区在线观看| 欧美日韩精品欧美日韩精品| 中文字幕第一区第二区| 精久久久久久久久久久| 在线视频一区二区三区| 国产欧美日韩在线视频| 日韩vs国产vs欧美| 色94色欧美sute亚洲线路一ni | 国产91精品精华液一区二区三区| 欧美人妇做爰xxxⅹ性高电影 | 欧美年轻男男videosbes| 中文字幕在线不卡| 国产精品99久久久久久有的能看| 日韩一级高清毛片| 亚洲成人动漫在线免费观看| 91网站在线播放| 中文字幕中文乱码欧美一区二区| 极品少妇一区二区三区精品视频 | 91天堂素人约啪| 国产精品色在线观看| 狠狠v欧美v日韩v亚洲ⅴ| 日韩一本二本av| 日本特黄久久久高潮| 欧美日韩精品欧美日韩精品一综合| 亚洲精品视频免费观看| www.激情成人| 亚洲手机成人高清视频| 色偷偷一区二区三区| 国产精品免费免费| 99在线热播精品免费| 国产精品久久久久久妇女6080 | 日韩一级黄色大片| 麻豆精品久久精品色综合| 日韩精品一区二区三区老鸭窝| 美女www一区二区| 久久网站热最新地址| 国产一区二区三区综合| 中国av一区二区三区| 99国产精品99久久久久久| 亚洲老妇xxxxxx| 欧美日韩综合在线| 青青青爽久久午夜综合久久午夜| 欧美一区二区三区婷婷月色| 精品无码三级在线观看视频| 国产欧美一二三区| 在线精品国精品国产尤物884a | 精品99999| 成人午夜电影网站| 亚洲色图欧美偷拍| 欧美一个色资源| 国产精品一色哟哟哟| 国产精品视频九色porn| 在线观看日韩毛片| 免费日韩伦理电影| 国产精品久久二区二区| 欧美日韩国产综合久久| 精品中文av资源站在线观看| 日韩伦理av电影| 日韩一本二本av| 91香蕉视频mp4| 蜜桃视频一区二区| 国产精品久久久久aaaa樱花| 欧美福利一区二区| 风间由美一区二区三区在线观看 | 亚洲视频一区二区免费在线观看 | 久久丁香综合五月国产三级网站| 国产精品色哟哟| 3751色影院一区二区三区| 国产盗摄精品一区二区三区在线| 一区二区三区精品| 精品三级在线看| 色噜噜久久综合| 国产精品影视网| 日本午夜一本久久久综合| 亚洲女同一区二区| 欧美a级理论片| 亚洲色图.com| 精品福利av导航| 欧美在线观看18| 成人一区二区三区在线观看| 日韩电影免费在线| 亚洲黄网站在线观看| 久久精品免视看| 欧美一级艳片视频免费观看| 91在线无精精品入口| 国产九色sp调教91| 首页亚洲欧美制服丝腿| 亚洲女与黑人做爰| 中文字幕第一页久久| 久久久久免费观看| 日韩欧美电影在线| 欧美唯美清纯偷拍| 色婷婷综合久色| 成人福利电影精品一区二区在线观看 | av在线这里只有精品| 国产精品99久久久久久似苏梦涵| 日本最新不卡在线| 日韩av一区二区在线影视| 一二三四社区欧美黄| 亚洲精品视频在线| 一区av在线播放| 亚洲欧美一区二区久久| 亚洲欧美国产高清| 综合网在线视频| 亚洲视频在线一区| 亚洲乱码中文字幕综合| 亚洲欧洲综合另类| 一区二区视频在线| 亚洲综合另类小说| 亚洲一二三四区| 亚洲一线二线三线久久久| 最新热久久免费视频| 亚洲天堂中文字幕| 亚洲黄色片在线观看| 一区二区三区中文免费| 亚洲成人av电影在线| 日韩国产精品大片| 久久se这里有精品| 国产成人一级电影| 99久久综合99久久综合网站| 波多野结衣亚洲| 在线观看精品一区| 欧美久久一二区| 日韩欧美一区二区不卡| 久久久亚洲精品一区二区三区| 国产日本亚洲高清| 亚洲精品国产a| 免费一级欧美片在线观看| 国产麻豆精品95视频| 本田岬高潮一区二区三区| 欧美中文字幕久久| 欧美tickle裸体挠脚心vk| 国产精品三级视频| 午夜天堂影视香蕉久久| 精品中文av资源站在线观看| www.亚洲激情.com| 欧美巨大另类极品videosbest | 国产精品三级视频| 亚洲国产另类精品专区| 激情综合五月婷婷| 91色乱码一区二区三区| 69堂精品视频| 国产精品免费免费| 丝袜美腿亚洲综合| 成人短视频下载| 日韩欧美自拍偷拍| 亚洲欧美日韩国产一区二区三区| 日本三级亚洲精品| 99久久精品国产观看| 欧美大片拔萝卜| 一区二区三区91| av在线播放不卡| 精品黑人一区二区三区久久| 亚洲国产色一区|