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

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

?? firmware.a51

?? the vhdl model of usb. it is very helpful.
?? A51
?? 第 1 頁 / 共 2 頁
字號:
;-------------------------------------------------------------------------------
;  Copyright (c) 2000 by Trenz Electronic.
;  Duenner Kirchweg 77, 32257 Buende, Germany, www.trenz-electronic.de
;      
;  This program is free software; you can redistribute it and/or modify
;  it under the terms of the GNU General Public License as published by
;  the Free Software Foundation; either version 2 of the License, or
;  (at your option) any later version.
;      
;  This program is distributed in the hope that it will be useful,
;  but WITHOUT ANY WARRANTY; without even the implied warranty of
;  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;  GNU General Public License for more details.
;      
;  You should have received a copy of the GNU General Public License
;  along with this program; if not, write to the Free Software
;  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
;-------------------------------------------------------------------------------
;  Project:      Full-Speed USB 1.1 Function Controller
;  File:         firmware.a51
;  Description:  usbSIE reference application, firmware.
;  Version:      FB, 2000jun21
;-------------------------------------------------------------------------------

	$MOD51

STACKTOP EQU 70H                                ; start of stack (grows up)

ledREG      EQU 0F000h                          ; 7-Segment register address
ledREG0     EQU 00h
ledREG1     EQU 01h
ledREG2     EQU 02h
ledREG3     EQU 03h
ledREG4     EQU 04h
ledREG5     EQU 05h
ledREG6     EQU 06h
ledREG7     EQU 07h
ledREG8     EQU 08h
ledREG9     EQU 09h
ledREGa     EQU 0Ah
ledREGb     EQU 0Bh
ledREGc     EQU 0Ch
ledREGd     EQU 0Dh
ledREGe     EQU 0Eh
ledREGf     EQU 0Fh

;ledREG0     EQU 77h                             ; "0"
;ledREG1     EQU 12h                             ; "1"
;ledREG2     EQU 5Eh                             ; "2"

usbFIFO     EQU 0E000h                          ; usb fifos
usbFIFOlen  EQU 8                               ; usb fifo depth

usbCTRL       EQU 0D000h                        ; usb endpoint #0 control
usbCTRLread   EQU 80h                           ; control read sequence
usbCTRLwrite  EQU 40h                           ; control write sequence
usbCTRLstatus EQU 20h                           ; status acknowledge
usbCTRLstall  EQU 10h                           ; STALL endpoint

usbSTAT       EQU 0D000h                        ; usb endpoint #0 status
usbSTATsetup  EQU 80h                           ; setup stage
usbSTATdata   EQU 40h                           ; data stage
usbSTATstatus EQU 20h                           ; status stage
usbSTATall    EQU 0E0h                          ; any status bit

usbDADX     EQU 0C000h                          ; usb device address

bmRequestType EQU usbFIFO
bRequest      EQU usbFIFO + 1
wValueLo      EQU usbFIFO + 2
wValueHi      EQU usbFIFO + 3
wIndexLo      EQU usbFIFO + 4
wIndexHi      EQU usbFIFO + 5
wLengthLo     EQU usbFIFO + 6
wLengthHi     EQU usbFIFO + 7

;-------------------------------------------------------------------------------
	DSEG	AT 20H

FLAGS:         DS  1                            ; This register is bit-addressable
  Configured   EQU FLAGS.0	                    ; Is this device configured
  STALL		   EQU FLAGS.1	                    ; Need to STALL endpoint 0
  SendData	   EQU FLAGS.2                      ; Need to send data to PC Host
  IsDescriptor EQU FLAGS.3                      ; Enable a shortcut reply

Temp:
Temp1:         DS 1                             ; A temporary working register
Temp2:         DS 1                             ; A temporary working register
Temp3:         DS 1                             ; A temporary working register
Temp4:         DS 1                             ; A temporary working register
Temp5:         DS 1                             ; A temporary working register
Temp6:         DS 1                             ; A temporary working register
Temp7:         DS 1                             ; A temporary working register

;Idle_Time:     DS 1	                            ; The time the PC host wants us to wait
ConfigVal:     DS 1                             ; configuration value
EpHalt:        DS 1                             ; endpoint HALT feature

	DSEG
	ORG 30H
;CNTR:          DS 1                             ; counter for wait routine

;-------------------------------------------------------------------------------
	CSEG
	ORG 0000H                                   ; program starts at 0 after reset

start:
	MOV  SP, #STACKTOP                          ; initialize stack pointer ...

	;-- set device address to zero
	MOV  A, #00h
	MOV  DPTR, #usbDADX
	MOVX @DPTR, A

waitSETUP:
	;-- display "0"
	MOV  A, #ledREG0
	MOV  DPTR, #ledREG
	MOVX @DPTR, A

	;-- wait for SETUP transaction
	MOV  DPTR, #usbSTAT
w1:	MOVX A, @DPTR
	ANL  A, #usbSTATall
	CJNE A, #usbSTATsetup, w1

	;-- display "1"
	MOV  A, #ledREG1
	MOV  DPTR, #ledREG
	MOVX @DPTR, A

	CALL Dispatch

	JMP waitSETUP

;-------------------------------------------------------------------------------
;* * *   d i s p a t c h   c h a p t e r   9   r e q u e s t s   * * * * * * * *
;-------------------------------------------------------------------------------
Dispatch:
	;-------------------------------------------
	; Reference: USB Serial Bus Specification 1.1
	;            Chapter 9.3 USB Device Requests
	;   bmRequestType
	;     (7) Data transfer direction
	;        0= Host-to-device
	;        1= Device-to-host
	;     (6-5) Type
	;        00= Standard
	;        01= Class
	;        10= Vendor
	;        11= Reserved
	;     (4-0) Recipient
	;        00000= Device
	;        00001= Interface
	;        00010= Endpoint
	;        00011= Other
	;        All other codes are reserved
	;-------------------------------------------
	; Reference: USB Design by Example, 
	;            John Hyde, Wile Computer Publishing,
	;            ISBN 0-471-37048-7
	;            Chapter 6 Buttons & Lights, Example 1-Step 3: 
	;                       Implement Microcontroller Code
	;
	;   with bmRequest(5) select
	;   cc= "11"                      when '1',
	;       bmRequestType(1 downto 0) when others;
	;   rr= bRequest(3 downto 0);
	;   code= cc & rr;
	;
	;   Note: cc  recipient
	;         00= device
	;         01= interface
	;         10= endpoint
	;         11= class
	;- - - - - - - - - - - - - - - - - - - - - -
	; rr device            interface         endpoint        class
	; 0  devGET_STATUS     ifGET_STATUS      epGET_STATUS    ---
	; 1  devCLEAR_FEATURE  ifCLEAR_FEATURE   epCLEAR_FEATURE xxxGET_REPORT
	; 2  ---               ---               ---             xxxGET_IDLE
	; 3  devSET_FEATURE    ifSET_FEATURE     epSET_FEATURE   xxxGET_PROTOCOL
	; 4  ---               ---               ---             ---
	; 5  SET_ADDRESS       ---               ---             ---
	; 6  GET_DESCRIPTOR    xxxGET_DESCRIPTOR ---             ---
	; 7  SET_DESCRIPTOR    xxxSET_DESCRIPTOR ---             ---
	; 8  GET_CONFIGURATION ---               ---             ---
	; 9  SET_CONFIGURATION ---               ---             xxxSET_REPORT
	; a  ---               GET_INTERFACE     ---             xxxSET_IDLE
	; b  ---               SET_INTERFACE     ---             xxxSET_PROTOCOL
	; c  ---               ---               epSYNC_FRAME
	;-------------------------------------------

	MOV  DPTR, #bmRequestType
	MOVX A, @DPTR

	MOV  C, ACC.7		                        ; Data transfer direction
 	MOV  SendData, C

	ANL	 A, #01011100b
	JNZ  BadRequest                             ; reserved code

	MOVX A, @DPTR
	MOV  C, ACC.0
	ANL  C, ACC.1
	JC   BadRequest                             ; recipient= other

	JNB	 ACC.5, n5                              ; bmRequestType(5)
	MOV  A, #00000011b                          ; cc= "11"
n5:	ANL  A, #00000011b                          ; cc= bmRequestType(1 downto 0)

	SWAP A
	MOV  Temp, A                                ; Save HI nibble of rr

	INC  DPTR
	MOVX A, @DPTR                               ; bRequest

	ANL	A, #00001111b                           ; bRequest(3 downto 0)
 	ORL	A, Temp                                 ; this is rr!

	MOV  DPTR, #CommandTable
	CALL BumpDPTR		                        ; point to entry

	MOVX A, @DPTR                               ; get the offset
	MOV  DPTR, #CommandTable
	CALL BumpDPTR                               ; get routine address

	PUSH DPL                                    ; create return address on stack
	PUSH DPH                                    ; Note: JMP @A+DPTR not used since A, DPTR needed
	RET                                         ; go to service routine

BadRequest:
	JMP  invalid

BumpDPTR:                                       ; Returns (DPTR + ACC)
	ADD  A, DPL
	MOV  DPL, A
	JNC  nc
	INC  DPH                                    ; Need 16 bit arithmetic here
nc:	RET

; Since the table only contains byte offsets, it is important that all these routines are
; within one page (100H) of CommandTable
CommandTable:
	;-- device commands
	DB devGET_STATUS     - CommandTable         ; 0
	DB devCLEAR_FEATURE  - CommandTable         ; 1
	DB invalid           - CommandTable         ; 2
	DB devSET_FEATURE    - CommandTable         ; 3
	DB invalid           - CommandTable         ; 4
	DB SET_ADDRESS       - CommandTable         ; 5
	DB GET_DESCRIPTOR    - CommandTable         ; 6
	DB SET_DESCRIPTOR    - CommandTable         ; 7
	DB GET_CONFIGURATION - CommandTable         ; 8
	DB SET_CONFIGURATION - CommandTable         ; 9
	DB invalid           - CommandTable         ; 10
	DB invalid           - CommandTable         ; 11
	DB invalid           - CommandTable         ; 12
	DB invalid           - CommandTable         ; 13
	DB invalid           - CommandTable         ; 14
	DB invalid           - CommandTable         ; 15

	;-- interface commands
	DB ifGET_STATUS      - CommandTable         ;
	DB ifCLEAR_FEATURE   - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB ifSET_FEATURE     - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB xxxGET_DESCRIPTOR - CommandTable         ;
	DB xxxSET_DESCRIPTOR - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB GET_INTERFACE     - CommandTable         ;
	DB SET_INTERFACE     - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;

	;-- endpoint commands
	DB epGET_STATUS      - CommandTable         ;
	DB epCLEAR_FEATURE   - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB epSET_FEATURE     - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB epSYNCH_FRAME     - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;

	;-- class requests
	DB invalid           - CommandTable         ;
	DB xxxGET_REPORT     - CommandTable         ;
	DB xxxGET_IDLE       - CommandTable         ;
	DB xxxGET_PROTOCOL   - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB xxxSET_REPORT     - CommandTable         ;
	DB xxxSET_IDLE       - CommandTable         ;
	DB xxxSET_PROTOCOL   - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;
	DB invalid           - CommandTable         ;

;-------------------------------------------------------------------------------
;* * *   s t a n d a r d   d e v i c e   r e q u e s t s   * * * * * * * * * * *
;-------------------------------------------------------------------------------

;*** 9.4.1 Clear Feature *******************************************************
epCLEAR_FEATURE:
	MOV  DPTR, #wValueLo
	MOVX A, @DPTR                               ; endpoint

	;-- todo: store HALT info for every endpoint
	MOV  EpHalt, #0
	
	JMP  NoDataControl

;*** 9.4.2 Get Configuration ***************************************************
GET_CONFIGURATION:
	;-- put config val into fifo
	MOV  DPTR, #usbFIFO
	MOV  A, ConfigVal
	MOVX @DPTR, A

	MOV  A, #1
	JMP  ControlRead

;*** 9.4.3 Get Descriptor ******************************************************
GET_DESCRIPTOR:

	MOV  DPTR, #wValueHI
	MOVX A, @DPTR

	DEC  A
	JZ   devGET_DESCRIPTOR                      ; wValueLO= 1

	DEC  A
	JZ   cfgGET_DESCRIPTOR                      ; wValueLO= 2

	DEC  A
	JZ   strGET_DESCRIPTOR                      ; wValueLO= 3

	JMP  invalid

;*** 9.4.5 Get Status **********************************************************
devGET_STATUS:
	MOV  A, #1                                  ; self powered
	JMP  doGET_STATUS

ifGET_STATUS:
	MOV  A, #0                                  ; reserved (zero)
	JMP  doGET_STATUS

epGET_STATUS:
	MOV  A, EpHalt                              ; endpoint HALT
	JMP doGET_STATUS

;*** 9.4.6 Set Address *********************************************************
SET_ADDRESS:
	MOV  DPTR, #wValueLo
	MOVX A, @DPTR

	;-- set device address (deferred until next SETUP transaction)
	MOV  DPTR, #usbDADX
	MOVX @DPTR, A

	JMP  NoDataControl

;*** 9.4.7 Set Configuration ***************************************************
SET_CONFIGURATION:
	;-- save config value
	MOV  DPTR, #wValueLo
	MOVX A, @DPTR
	MOV  ConfigVal, A

	JMP  NoDataControl

;*** 9.4.9 Set Feature *********************************************************
epSET_FEATURE:

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
激情文学综合插| 一区二区三区美女视频| 午夜av区久久| 欧美亚洲动漫精品| 一个色在线综合| 欧美熟乱第一页| 久久av资源网| 国产欧美日韩视频在线观看| 国产美女精品一区二区三区| 欧美国产精品劲爆| a亚洲天堂av| 亚洲午夜免费视频| 在线电影国产精品| 久久精品99国产精品| 久久婷婷国产综合精品青草| 成人免费视频视频在线观看免费| 中文字幕一区二区三区乱码在线| 欧美日韩一区二区在线观看| 免费观看成人鲁鲁鲁鲁鲁视频| 久久综合九色综合97婷婷女人| av动漫一区二区| 青青草视频一区| 国产精品美女久久久久aⅴ| 在线一区二区视频| 久久精品国产亚洲高清剧情介绍| 国产人久久人人人人爽| 91免费观看视频| 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美美女黄视频| 精品一区二区精品| 亚洲色图另类专区| 精品美女在线播放| 色狠狠av一区二区三区| 国产综合成人久久大片91| 亚洲视频一二三| 欧美精品一区二区三区高清aⅴ | 亚洲码国产岛国毛片在线| 777色狠狠一区二区三区| 国产一区视频导航| 亚洲综合小说图片| 亚洲国产激情av| 欧美一区二区三区思思人| 风流少妇一区二区| 久久精品国产99久久6| 亚洲国产sm捆绑调教视频| 国产精品你懂的在线| 91精品蜜臀在线一区尤物| 色综合久久中文综合久久97| 国产高清精品网站| 免费在线视频一区| 午夜精品久久久久久久久 | 国产一区免费电影| 亚洲综合视频在线观看| 中文子幕无线码一区tr| 日韩视频一区二区三区| 欧美另类久久久品| 欧美性大战久久久久久久蜜臀| 成人av在线观| 国产成人免费视频网站高清观看视频| 日日夜夜一区二区| 亚洲成av人**亚洲成av**| 亚洲视频资源在线| 亚洲欧洲美洲综合色网| 国产女主播在线一区二区| 久久亚洲欧美国产精品乐播 | 欧美激情在线看| 精品国产乱码久久久久久久| 欧美一二三四区在线| 欧美精品一卡两卡| 欧美精品在线视频| 91精品国产色综合久久不卡电影 | 国产成人综合网| 国模套图日韩精品一区二区 | 自拍偷自拍亚洲精品播放| 国产亚洲欧洲997久久综合 | 精品一区二区在线免费观看| 日韩中文字幕一区二区三区| 亚洲成精国产精品女| 成人福利视频在线看| 国产乱码精品一区二区三区忘忧草 | 久久精子c满五个校花| 2023国产一二三区日本精品2022| 欧美α欧美αv大片| 欧美精品一区男女天堂| 国产欧美日韩一区二区三区在线观看| 国产女人18毛片水真多成人如厕 | 国产成人免费在线| 波多野结衣在线aⅴ中文字幕不卡| 成人性视频免费网站| www.日本不卡| 欧美日韩亚洲综合| 在线播放欧美女士性生活| 欧美大肚乱孕交hd孕妇| 国产喂奶挤奶一区二区三区| 中文字幕一区二区在线观看 | 日韩电影一区二区三区| 极品少妇xxxx偷拍精品少妇| 国产在线不卡一卡二卡三卡四卡| 国产99久久久国产精品潘金 | 99精品国产视频| 欧美日韩国产欧美日美国产精品| 91精品国产综合久久蜜臀| 久久亚洲精品国产精品紫薇| 国产精品乱人伦| 亚洲成av人片| 国产精品一级片| 色婷婷综合五月| 欧美一区二区视频观看视频| 国产午夜精品理论片a级大结局 | bt欧美亚洲午夜电影天堂| 在线观看一区二区精品视频| 日韩免费高清av| 亚洲欧洲精品天堂一级| 日韩精品欧美精品| 成人黄色av电影| 91精品国产一区二区| **性色生活片久久毛片| 日韩国产高清在线| 成人av电影在线观看| 日韩亚洲欧美在线| 亚洲天堂a在线| 久草这里只有精品视频| 91亚洲大成网污www| 精品日韩一区二区| 夜夜嗨av一区二区三区四季av | 奇米一区二区三区av| 91在线视频播放| 精品国产乱码久久久久久蜜臀 | 亚洲欧美综合另类在线卡通| 久久爱另类一区二区小说| 欧美性大战久久| 国产精品不卡在线| 国产一区日韩二区欧美三区| 777午夜精品免费视频| 亚洲视频香蕉人妖| 国产精品自拍网站| 日韩视频在线观看一区二区| 亚洲综合图片区| 97国产精品videossex| 国产日韩欧美精品综合| 精一区二区三区| 欧美高清精品3d| 亚洲一区二区三区三| 91丨国产丨九色丨pron| 国产精品久久三区| 国产精品一区二区免费不卡| 欧美成人精品1314www| 日韩精品国产欧美| 欧美日韩国产免费| 亚洲国产综合人成综合网站| 99re热视频精品| 国产精品日韩精品欧美在线| 国产美女一区二区| 久久日韩精品一区二区五区| 精品一区二区三区久久久| 欧美一级片在线看| 日韩经典一区二区| 91麻豆精品91久久久久久清纯| 一区二区三区高清不卡| 91久久精品网| 亚洲制服丝袜av| 欧美在线观看你懂的| 亚洲一区二区精品视频| 欧美日韩一区精品| 亚洲成人资源网| 日韩一区二区三区视频在线观看| 日韩成人一级片| 日韩三级.com| 国模大尺度一区二区三区| 久久婷婷国产综合精品青草| 国产成人av电影在线播放| 欧美国产一区在线| 91蝌蚪porny成人天涯| 一区二区三区在线看| 欧美日韩一区视频| 蜜桃精品视频在线| 久久影视一区二区| 波多野结衣亚洲一区| 亚洲在线视频网站| 717成人午夜免费福利电影| 麻豆精品在线看| 久久久久久日产精品| 91偷拍与自偷拍精品| 亚洲6080在线| 精品99999| va亚洲va日韩不卡在线观看| 亚洲资源在线观看| 欧美xxx久久| 成人99免费视频| 亚洲综合色噜噜狠狠| 3d成人h动漫网站入口| 国产一区二区按摩在线观看| 中文字幕一区在线| 在线不卡一区二区| 成人免费视频网站在线观看| 亚洲第一会所有码转帖| 久久婷婷色综合| 欧美日韩一区二区三区不卡 | 日韩电影在线免费观看| 久久久久国产成人精品亚洲午夜|