1
0
mirror of https://github.com/gnss-sdr/gnss-sdr synced 2025-01-15 11:45:47 +00:00
gnss-sdr/firmware/GN3S_v2/lib/usb_common.asm
Javier Arribas b849b20a8c Added optional support for Sparkfun SiGe GN3S USB GPS RF sampler:
- Added a pre-compiled custom GN3S firmware.
- Added a fully-compliant GNU Radio source block for GN3S USB dongle. It can be used also from GNU Radio companion and from Python applications.
- Added a new GN3S_Signal_Source block. It is possible to disable the GN3S signal source compilation. See README.

git-svn-id: https://svn.code.sf.net/p/gnss-sdr/code/trunk@217 64b25241-fba3-4117-9849-534c7e92360d
2012-07-30 15:46:07 +00:00

1596 lines
35 KiB
NASM

;--------------------------------------------------------
; File Created by SDCC : free open source ANSI-C Compiler
; Version 2.9.0 #5416 (Feb 3 2010) (UNIX)
; This file was generated Mon Jul 30 11:40:53 2012
;--------------------------------------------------------
.module usb_common
.optsdcc -mmcs51 --model-small
;--------------------------------------------------------
; Public variables in this module
;--------------------------------------------------------
.globl _epcs
.globl _plausible_endpoint
.globl _EIPX6
.globl _EIPX5
.globl _EIPX4
.globl _PI2C
.globl _PUSB
.globl _EIEX6
.globl _EIEX5
.globl _EIEX4
.globl _EI2C
.globl _EIUSB
.globl _SMOD1
.globl _ERESI
.globl _RESI
.globl _INT6
.globl _CY
.globl _AC
.globl _F0
.globl _RS1
.globl _RS0
.globl _OV
.globl _FL
.globl _P
.globl _TF2
.globl _EXF2
.globl _RCLK
.globl _TCLK
.globl _EXEN2
.globl _TR2
.globl _C_T2
.globl _CP_RL2
.globl _SM01
.globl _SM11
.globl _SM21
.globl _REN1
.globl _TB81
.globl _RB81
.globl _TI1
.globl _RI1
.globl _PS1
.globl _PT2
.globl _PS0
.globl _PT1
.globl _PX1
.globl _PT0
.globl _PX0
.globl _D7
.globl _D6
.globl _D5
.globl _D4
.globl _D3
.globl _D2
.globl _D1
.globl _D0
.globl _EA
.globl _ES1
.globl _ET2
.globl _ES0
.globl _ET1
.globl _EX1
.globl _ET0
.globl _EX0
.globl _SM0
.globl _SM1
.globl _SM2
.globl _REN
.globl _TB8
.globl _RB8
.globl _TI
.globl _RI
.globl _TF1
.globl _TR1
.globl _TF0
.globl _TR0
.globl _IE1
.globl _IT1
.globl _IE0
.globl _IT0
.globl _SEL
.globl _A7
.globl _A6
.globl _A5
.globl _A4
.globl _A3
.globl _A2
.globl _A1
.globl _A0
.globl _EIP
.globl _B
.globl _EIE
.globl _ACC
.globl _EICON
.globl _PSW
.globl _TH2
.globl _TL2
.globl _RCAP2H
.globl _RCAP2L
.globl _T2CON
.globl _SBUF1
.globl _SCON1
.globl _GPIFSGLDATLNOX
.globl _GPIFSGLDATLX
.globl _GPIFSGLDATH
.globl _GPIFTRIG
.globl _EP01STAT
.globl _IP
.globl _OEE
.globl _OED
.globl _OEC
.globl _OEB
.globl _OEA
.globl _IOE
.globl _IOD
.globl _AUTOPTRSETUP
.globl _EP68FIFOFLGS
.globl _EP24FIFOFLGS
.globl _EP2468STAT
.globl _IE
.globl _INT4CLR
.globl _INT2CLR
.globl _IOC
.globl _AUTODAT2
.globl _AUTOPTRL2
.globl _AUTOPTRH2
.globl _AUTODAT1
.globl _APTR1L
.globl _APTR1H
.globl _SBUF0
.globl _SCON0
.globl _MPAGE
.globl _EXIF
.globl _IOB
.globl _CKCON
.globl _TH1
.globl _TH0
.globl _TL1
.globl _TL0
.globl _TMOD
.globl _TCON
.globl _PCON
.globl _DPS
.globl _DPH1
.globl _DPL1
.globl _DPH
.globl _DPL
.globl _SP
.globl _IOA
.globl _EP8FIFOBUF
.globl _EP6FIFOBUF
.globl _EP4FIFOBUF
.globl _EP2FIFOBUF
.globl _EP1INBUF
.globl _EP1OUTBUF
.globl _EP0BUF
.globl _CT4
.globl _CT3
.globl _CT2
.globl _CT1
.globl _USBTEST
.globl _TESTCFG
.globl _DBUG
.globl _UDMACRCQUAL
.globl _UDMACRCL
.globl _UDMACRCH
.globl _GPIFHOLDAMOUNT
.globl _FLOWSTBHPERIOD
.globl _FLOWSTBEDGE
.globl _FLOWSTB
.globl _FLOWHOLDOFF
.globl _FLOWEQ1CTL
.globl _FLOWEQ0CTL
.globl _FLOWLOGIC
.globl _FLOWSTATE
.globl _GPIFABORT
.globl _GPIFREADYSTAT
.globl _GPIFREADYCFG
.globl _XGPIFSGLDATLNOX
.globl _XGPIFSGLDATLX
.globl _XGPIFSGLDATH
.globl _EP8GPIFTRIG
.globl _EP8GPIFPFSTOP
.globl _EP8GPIFFLGSEL
.globl _EP6GPIFTRIG
.globl _EP6GPIFPFSTOP
.globl _EP6GPIFFLGSEL
.globl _EP4GPIFTRIG
.globl _EP4GPIFPFSTOP
.globl _EP4GPIFFLGSEL
.globl _EP2GPIFTRIG
.globl _EP2GPIFPFSTOP
.globl _EP2GPIFFLGSEL
.globl _GPIFTCB0
.globl _GPIFTCB1
.globl _GPIFTCB2
.globl _GPIFTCB3
.globl _GPIFADRL
.globl _GPIFADRH
.globl _GPIFCTLCFG
.globl _GPIFIDLECTL
.globl _GPIFIDLECS
.globl _GPIFWFSELECT
.globl _SETUPDAT
.globl _SUDPTRCTL
.globl _SUDPTRL
.globl _SUDPTRH
.globl _EP8FIFOBCL
.globl _EP8FIFOBCH
.globl _EP6FIFOBCL
.globl _EP6FIFOBCH
.globl _EP4FIFOBCL
.globl _EP4FIFOBCH
.globl _EP2FIFOBCL
.globl _EP2FIFOBCH
.globl _EP8FIFOFLGS
.globl _EP6FIFOFLGS
.globl _EP4FIFOFLGS
.globl _EP2FIFOFLGS
.globl _EP8CS
.globl _EP6CS
.globl _EP4CS
.globl _EP2CS
.globl _EP1INCS
.globl _EP1OUTCS
.globl _EP0CS
.globl _EP8BCL
.globl _EP8BCH
.globl _EP6BCL
.globl _EP6BCH
.globl _EP4BCL
.globl _EP4BCH
.globl _EP2BCL
.globl _EP2BCH
.globl _EP1INBC
.globl _EP1OUTBC
.globl _EP0BCL
.globl _EP0BCH
.globl _FNADDR
.globl _MICROFRAME
.globl _USBFRAMEL
.globl _USBFRAMEH
.globl _TOGCTL
.globl _WAKEUPCS
.globl _SUSPEND
.globl _USBCS
.globl _XAUTODAT2
.globl _XAUTODAT1
.globl _I2CTL
.globl _I2DAT
.globl _I2CS
.globl _PORTECFG
.globl _PORTCCFG
.globl _PORTACFG
.globl _INTSETUP
.globl _INT4IVEC
.globl _INT2IVEC
.globl _CLRERRCNT
.globl _ERRCNTLIM
.globl _USBERRIRQ
.globl _USBERRIE
.globl _GPIFIRQ
.globl _GPIFIE
.globl _EPIRQ
.globl _EPIE
.globl _USBIRQ
.globl _USBIE
.globl _NAKIRQ
.globl _NAKIE
.globl _IBNIRQ
.globl _IBNIE
.globl _EP8FIFOIRQ
.globl _EP8FIFOIE
.globl _EP6FIFOIRQ
.globl _EP6FIFOIE
.globl _EP4FIFOIRQ
.globl _EP4FIFOIE
.globl _EP2FIFOIRQ
.globl _EP2FIFOIE
.globl _OUTPKTEND
.globl _INPKTEND
.globl _EP8ISOINPKTS
.globl _EP6ISOINPKTS
.globl _EP4ISOINPKTS
.globl _EP2ISOINPKTS
.globl _EP8FIFOPFL
.globl _EP8FIFOPFH
.globl _EP6FIFOPFL
.globl _EP6FIFOPFH
.globl _EP4FIFOPFL
.globl _EP4FIFOPFH
.globl _EP2FIFOPFL
.globl _EP2FIFOPFH
.globl _EP8AUTOINLENL
.globl _EP8AUTOINLENH
.globl _EP6AUTOINLENL
.globl _EP6AUTOINLENH
.globl _EP4AUTOINLENL
.globl _EP4AUTOINLENH
.globl _EP2AUTOINLENL
.globl _EP2AUTOINLENH
.globl _EP8FIFOCFG
.globl _EP6FIFOCFG
.globl _EP4FIFOCFG
.globl _EP2FIFOCFG
.globl _EP8CFG
.globl _EP6CFG
.globl _EP4CFG
.globl _EP2CFG
.globl _EP1INCFG
.globl _EP1OUTCFG
.globl _REVCTL
.globl _REVID
.globl _FIFOPINPOLAR
.globl _UART230
.globl _BPADDRL
.globl _BPADDRH
.globl _BREAKPT
.globl _FIFORESET
.globl _PINFLAGSCD
.globl _PINFLAGSAB
.globl _IFCONFIG
.globl _CPUCS
.globl _RES_WAVEDATA_END
.globl _GPIF_WAVE_DATA
.globl __usb_rx_overrun
.globl __usb_got_SUDAV
.globl _other_config_descr
.globl _current_config_descr
.globl _current_devqual_descr
.globl _current_device_descr
.globl __usb_alt_setting
.globl __usb_config
.globl _usb_install_handlers
.globl _usb_handle_setup_packet
;--------------------------------------------------------
; special function registers
;--------------------------------------------------------
.area RSEG (DATA)
_IOA = 0x0080
_SP = 0x0081
_DPL = 0x0082
_DPH = 0x0083
_DPL1 = 0x0084
_DPH1 = 0x0085
_DPS = 0x0086
_PCON = 0x0087
_TCON = 0x0088
_TMOD = 0x0089
_TL0 = 0x008a
_TL1 = 0x008b
_TH0 = 0x008c
_TH1 = 0x008d
_CKCON = 0x008e
_IOB = 0x0090
_EXIF = 0x0091
_MPAGE = 0x0092
_SCON0 = 0x0098
_SBUF0 = 0x0099
_APTR1H = 0x009a
_APTR1L = 0x009b
_AUTODAT1 = 0x009c
_AUTOPTRH2 = 0x009d
_AUTOPTRL2 = 0x009e
_AUTODAT2 = 0x009f
_IOC = 0x00a0
_INT2CLR = 0x00a1
_INT4CLR = 0x00a2
_IE = 0x00a8
_EP2468STAT = 0x00aa
_EP24FIFOFLGS = 0x00ab
_EP68FIFOFLGS = 0x00ac
_AUTOPTRSETUP = 0x00af
_IOD = 0x00b0
_IOE = 0x00b1
_OEA = 0x00b2
_OEB = 0x00b3
_OEC = 0x00b4
_OED = 0x00b5
_OEE = 0x00b6
_IP = 0x00b8
_EP01STAT = 0x00ba
_GPIFTRIG = 0x00bb
_GPIFSGLDATH = 0x00bd
_GPIFSGLDATLX = 0x00be
_GPIFSGLDATLNOX = 0x00bf
_SCON1 = 0x00c0
_SBUF1 = 0x00c1
_T2CON = 0x00c8
_RCAP2L = 0x00ca
_RCAP2H = 0x00cb
_TL2 = 0x00cc
_TH2 = 0x00cd
_PSW = 0x00d0
_EICON = 0x00d8
_ACC = 0x00e0
_EIE = 0x00e8
_B = 0x00f0
_EIP = 0x00f8
;--------------------------------------------------------
; special function bits
;--------------------------------------------------------
.area RSEG (DATA)
_A0 = 0x0080
_A1 = 0x0081
_A2 = 0x0082
_A3 = 0x0083
_A4 = 0x0084
_A5 = 0x0085
_A6 = 0x0086
_A7 = 0x0087
_SEL = 0x0086
_IT0 = 0x0088
_IE0 = 0x0089
_IT1 = 0x008a
_IE1 = 0x008b
_TR0 = 0x008c
_TF0 = 0x008d
_TR1 = 0x008e
_TF1 = 0x008f
_RI = 0x0098
_TI = 0x0099
_RB8 = 0x009a
_TB8 = 0x009b
_REN = 0x009c
_SM2 = 0x009d
_SM1 = 0x009e
_SM0 = 0x009f
_EX0 = 0x00a8
_ET0 = 0x00a9
_EX1 = 0x00aa
_ET1 = 0x00ab
_ES0 = 0x00ac
_ET2 = 0x00ad
_ES1 = 0x00ae
_EA = 0x00af
_D0 = 0x00b0
_D1 = 0x00b1
_D2 = 0x00b2
_D3 = 0x00b3
_D4 = 0x00b4
_D5 = 0x00b5
_D6 = 0x00b6
_D7 = 0x00b7
_PX0 = 0x00b8
_PT0 = 0x00b9
_PX1 = 0x00ba
_PT1 = 0x00bb
_PS0 = 0x00bc
_PT2 = 0x00bd
_PS1 = 0x00be
_RI1 = 0x00c0
_TI1 = 0x00c1
_RB81 = 0x00c2
_TB81 = 0x00c3
_REN1 = 0x00c4
_SM21 = 0x00c5
_SM11 = 0x00c6
_SM01 = 0x00c7
_CP_RL2 = 0x00c8
_C_T2 = 0x00c9
_TR2 = 0x00ca
_EXEN2 = 0x00cb
_TCLK = 0x00cc
_RCLK = 0x00cd
_EXF2 = 0x00ce
_TF2 = 0x00cf
_P = 0x00d0
_FL = 0x00d1
_OV = 0x00d2
_RS0 = 0x00d3
_RS1 = 0x00d4
_F0 = 0x00d5
_AC = 0x00d6
_CY = 0x00d7
_INT6 = 0x00db
_RESI = 0x00dc
_ERESI = 0x00dd
_SMOD1 = 0x00df
_EIUSB = 0x00e8
_EI2C = 0x00e9
_EIEX4 = 0x00ea
_EIEX5 = 0x00eb
_EIEX6 = 0x00ec
_PUSB = 0x00f8
_PI2C = 0x00f9
_EIPX4 = 0x00fa
_EIPX5 = 0x00fb
_EIPX6 = 0x00fc
;--------------------------------------------------------
; overlayable register banks
;--------------------------------------------------------
.area REG_BANK_0 (REL,OVR,DATA)
.ds 8
;--------------------------------------------------------
; overlayable bit register bank
;--------------------------------------------------------
.area BIT_BANK (REL,OVR,DATA)
bits:
.ds 1
b0 = bits[0]
b1 = bits[1]
b2 = bits[2]
b3 = bits[3]
b4 = bits[4]
b5 = bits[5]
b6 = bits[6]
b7 = bits[7]
;--------------------------------------------------------
; internal ram data
;--------------------------------------------------------
.area DSEG (DATA)
__usb_config::
.ds 1
__usb_alt_setting::
.ds 1
_current_device_descr::
.ds 2
_current_devqual_descr::
.ds 2
_current_config_descr::
.ds 2
_other_config_descr::
.ds 2
;--------------------------------------------------------
; overlayable items in internal ram
;--------------------------------------------------------
.area OSEG (OVR,DATA)
.area OSEG (OVR,DATA)
;--------------------------------------------------------
; indirectly addressable internal ram data
;--------------------------------------------------------
.area ISEG (DATA)
;--------------------------------------------------------
; absolute internal ram data
;--------------------------------------------------------
.area IABS (ABS,DATA)
.area IABS (ABS,DATA)
;--------------------------------------------------------
; bit data
;--------------------------------------------------------
.area BSEG (BIT)
__usb_got_SUDAV::
.ds 1
__usb_rx_overrun::
.ds 1
;--------------------------------------------------------
; paged external ram data
;--------------------------------------------------------
.area PSEG (PAG,XDATA)
;--------------------------------------------------------
; external ram data
;--------------------------------------------------------
.area XSEG (XDATA)
_GPIF_WAVE_DATA = 0xe400
_RES_WAVEDATA_END = 0xe480
_CPUCS = 0xe600
_IFCONFIG = 0xe601
_PINFLAGSAB = 0xe602
_PINFLAGSCD = 0xe603
_FIFORESET = 0xe604
_BREAKPT = 0xe605
_BPADDRH = 0xe606
_BPADDRL = 0xe607
_UART230 = 0xe608
_FIFOPINPOLAR = 0xe609
_REVID = 0xe60a
_REVCTL = 0xe60b
_EP1OUTCFG = 0xe610
_EP1INCFG = 0xe611
_EP2CFG = 0xe612
_EP4CFG = 0xe613
_EP6CFG = 0xe614
_EP8CFG = 0xe615
_EP2FIFOCFG = 0xe618
_EP4FIFOCFG = 0xe619
_EP6FIFOCFG = 0xe61a
_EP8FIFOCFG = 0xe61b
_EP2AUTOINLENH = 0xe620
_EP2AUTOINLENL = 0xe621
_EP4AUTOINLENH = 0xe622
_EP4AUTOINLENL = 0xe623
_EP6AUTOINLENH = 0xe624
_EP6AUTOINLENL = 0xe625
_EP8AUTOINLENH = 0xe626
_EP8AUTOINLENL = 0xe627
_EP2FIFOPFH = 0xe630
_EP2FIFOPFL = 0xe631
_EP4FIFOPFH = 0xe632
_EP4FIFOPFL = 0xe633
_EP6FIFOPFH = 0xe634
_EP6FIFOPFL = 0xe635
_EP8FIFOPFH = 0xe636
_EP8FIFOPFL = 0xe637
_EP2ISOINPKTS = 0xe640
_EP4ISOINPKTS = 0xe641
_EP6ISOINPKTS = 0xe642
_EP8ISOINPKTS = 0xe643
_INPKTEND = 0xe648
_OUTPKTEND = 0xe649
_EP2FIFOIE = 0xe650
_EP2FIFOIRQ = 0xe651
_EP4FIFOIE = 0xe652
_EP4FIFOIRQ = 0xe653
_EP6FIFOIE = 0xe654
_EP6FIFOIRQ = 0xe655
_EP8FIFOIE = 0xe656
_EP8FIFOIRQ = 0xe657
_IBNIE = 0xe658
_IBNIRQ = 0xe659
_NAKIE = 0xe65a
_NAKIRQ = 0xe65b
_USBIE = 0xe65c
_USBIRQ = 0xe65d
_EPIE = 0xe65e
_EPIRQ = 0xe65f
_GPIFIE = 0xe660
_GPIFIRQ = 0xe661
_USBERRIE = 0xe662
_USBERRIRQ = 0xe663
_ERRCNTLIM = 0xe664
_CLRERRCNT = 0xe665
_INT2IVEC = 0xe666
_INT4IVEC = 0xe667
_INTSETUP = 0xe668
_PORTACFG = 0xe670
_PORTCCFG = 0xe671
_PORTECFG = 0xe672
_I2CS = 0xe678
_I2DAT = 0xe679
_I2CTL = 0xe67a
_XAUTODAT1 = 0xe67b
_XAUTODAT2 = 0xe67c
_USBCS = 0xe680
_SUSPEND = 0xe681
_WAKEUPCS = 0xe682
_TOGCTL = 0xe683
_USBFRAMEH = 0xe684
_USBFRAMEL = 0xe685
_MICROFRAME = 0xe686
_FNADDR = 0xe687
_EP0BCH = 0xe68a
_EP0BCL = 0xe68b
_EP1OUTBC = 0xe68d
_EP1INBC = 0xe68f
_EP2BCH = 0xe690
_EP2BCL = 0xe691
_EP4BCH = 0xe694
_EP4BCL = 0xe695
_EP6BCH = 0xe698
_EP6BCL = 0xe699
_EP8BCH = 0xe69c
_EP8BCL = 0xe69d
_EP0CS = 0xe6a0
_EP1OUTCS = 0xe6a1
_EP1INCS = 0xe6a2
_EP2CS = 0xe6a3
_EP4CS = 0xe6a4
_EP6CS = 0xe6a5
_EP8CS = 0xe6a6
_EP2FIFOFLGS = 0xe6a7
_EP4FIFOFLGS = 0xe6a8
_EP6FIFOFLGS = 0xe6a9
_EP8FIFOFLGS = 0xe6aa
_EP2FIFOBCH = 0xe6ab
_EP2FIFOBCL = 0xe6ac
_EP4FIFOBCH = 0xe6ad
_EP4FIFOBCL = 0xe6ae
_EP6FIFOBCH = 0xe6af
_EP6FIFOBCL = 0xe6b0
_EP8FIFOBCH = 0xe6b1
_EP8FIFOBCL = 0xe6b2
_SUDPTRH = 0xe6b3
_SUDPTRL = 0xe6b4
_SUDPTRCTL = 0xe6b5
_SETUPDAT = 0xe6b8
_GPIFWFSELECT = 0xe6c0
_GPIFIDLECS = 0xe6c1
_GPIFIDLECTL = 0xe6c2
_GPIFCTLCFG = 0xe6c3
_GPIFADRH = 0xe6c4
_GPIFADRL = 0xe6c5
_GPIFTCB3 = 0xe6ce
_GPIFTCB2 = 0xe6cf
_GPIFTCB1 = 0xe6d0
_GPIFTCB0 = 0xe6d1
_EP2GPIFFLGSEL = 0xe6d2
_EP2GPIFPFSTOP = 0xe6d3
_EP2GPIFTRIG = 0xe6d4
_EP4GPIFFLGSEL = 0xe6da
_EP4GPIFPFSTOP = 0xe6db
_EP4GPIFTRIG = 0xe6dc
_EP6GPIFFLGSEL = 0xe6e2
_EP6GPIFPFSTOP = 0xe6e3
_EP6GPIFTRIG = 0xe6e4
_EP8GPIFFLGSEL = 0xe6ea
_EP8GPIFPFSTOP = 0xe6eb
_EP8GPIFTRIG = 0xe6ec
_XGPIFSGLDATH = 0xe6f0
_XGPIFSGLDATLX = 0xe6f1
_XGPIFSGLDATLNOX = 0xe6f2
_GPIFREADYCFG = 0xe6f3
_GPIFREADYSTAT = 0xe6f4
_GPIFABORT = 0xe6f5
_FLOWSTATE = 0xe6c6
_FLOWLOGIC = 0xe6c7
_FLOWEQ0CTL = 0xe6c8
_FLOWEQ1CTL = 0xe6c9
_FLOWHOLDOFF = 0xe6ca
_FLOWSTB = 0xe6cb
_FLOWSTBEDGE = 0xe6cc
_FLOWSTBHPERIOD = 0xe6cd
_GPIFHOLDAMOUNT = 0xe60c
_UDMACRCH = 0xe67d
_UDMACRCL = 0xe67e
_UDMACRCQUAL = 0xe67f
_DBUG = 0xe6f8
_TESTCFG = 0xe6f9
_USBTEST = 0xe6fa
_CT1 = 0xe6fb
_CT2 = 0xe6fc
_CT3 = 0xe6fd
_CT4 = 0xe6fe
_EP0BUF = 0xe740
_EP1OUTBUF = 0xe780
_EP1INBUF = 0xe7c0
_EP2FIFOBUF = 0xf000
_EP4FIFOBUF = 0xf400
_EP6FIFOBUF = 0xf800
_EP8FIFOBUF = 0xfc00
;--------------------------------------------------------
; absolute external ram data
;--------------------------------------------------------
.area XABS (ABS,XDATA)
;--------------------------------------------------------
; external initialized ram data
;--------------------------------------------------------
.area HOME (CODE)
.area GSINIT0 (CODE)
.area GSINIT1 (CODE)
.area GSINIT2 (CODE)
.area GSINIT3 (CODE)
.area GSINIT4 (CODE)
.area GSINIT5 (CODE)
.area GSINIT (CODE)
.area GSFINAL (CODE)
.area CSEG (CODE)
;--------------------------------------------------------
; global & static initialisations
;--------------------------------------------------------
.area HOME (CODE)
.area GSINIT (CODE)
.area GSFINAL (CODE)
.area GSINIT (CODE)
; usb_common.c:72: unsigned char _usb_config = 0;
mov __usb_config,#0x00
; usb_common.c:73: unsigned char _usb_alt_setting = 0; // FIXME really 1/interface
mov __usb_alt_setting,#0x00
;--------------------------------------------------------
; Home
;--------------------------------------------------------
.area HOME (CODE)
.area HOME (CODE)
;--------------------------------------------------------
; code
;--------------------------------------------------------
.area CSEG (CODE)
;------------------------------------------------------------
;Allocation info for local variables in function 'setup_descriptors'
;------------------------------------------------------------
;------------------------------------------------------------
; usb_common.c:81: setup_descriptors (void)
; -----------------------------------------
; function setup_descriptors
; -----------------------------------------
_setup_descriptors:
ar2 = 0x02
ar3 = 0x03
ar4 = 0x04
ar5 = 0x05
ar6 = 0x06
ar7 = 0x07
ar0 = 0x00
ar1 = 0x01
; usb_common.c:83: if (USBCS & bmHSM){ // high speed mode
mov dptr,#_USBCS
movx a,@dptr
mov r2,a
jnb acc.7,00102$
; usb_common.c:84: current_device_descr = high_speed_device_descr;
mov _current_device_descr,#_high_speed_device_descr
mov (_current_device_descr + 1),#(_high_speed_device_descr >> 8)
; usb_common.c:85: current_devqual_descr = high_speed_devqual_descr;
mov _current_devqual_descr,#_high_speed_devqual_descr
mov (_current_devqual_descr + 1),#(_high_speed_devqual_descr >> 8)
; usb_common.c:86: current_config_descr = high_speed_config_descr;
mov _current_config_descr,#_high_speed_config_descr
mov (_current_config_descr + 1),#(_high_speed_config_descr >> 8)
; usb_common.c:87: other_config_descr = full_speed_config_descr;
mov _other_config_descr,#_full_speed_config_descr
mov (_other_config_descr + 1),#(_full_speed_config_descr >> 8)
ret
00102$:
; usb_common.c:90: current_device_descr = full_speed_device_descr;
mov _current_device_descr,#_full_speed_device_descr
mov (_current_device_descr + 1),#(_full_speed_device_descr >> 8)
; usb_common.c:91: current_devqual_descr = full_speed_devqual_descr;
mov _current_devqual_descr,#_full_speed_devqual_descr
mov (_current_devqual_descr + 1),#(_full_speed_devqual_descr >> 8)
; usb_common.c:92: current_config_descr = full_speed_config_descr;
mov _current_config_descr,#_full_speed_config_descr
mov (_current_config_descr + 1),#(_full_speed_config_descr >> 8)
; usb_common.c:93: other_config_descr = high_speed_config_descr;
mov _other_config_descr,#_high_speed_config_descr
mov (_other_config_descr + 1),#(_high_speed_config_descr >> 8)
ret
;------------------------------------------------------------
;Allocation info for local variables in function 'isr_SUDAV'
;------------------------------------------------------------
;------------------------------------------------------------
; usb_common.c:103: isr_SUDAV (void) interrupt
; -----------------------------------------
; function isr_SUDAV
; -----------------------------------------
_isr_SUDAV:
; usb_common.c:105: clear_usb_irq ();
anl _EXIF,#0xEF
mov _INT2CLR,#0x00
; usb_common.c:106: _usb_got_SUDAV = 1;
setb __usb_got_SUDAV
reti
; eliminated unneeded push/pop psw
; eliminated unneeded push/pop dpl
; eliminated unneeded push/pop dph
; eliminated unneeded push/pop b
; eliminated unneeded push/pop acc
;------------------------------------------------------------
;Allocation info for local variables in function 'isr_USBRESET'
;------------------------------------------------------------
;------------------------------------------------------------
; usb_common.c:111: isr_USBRESET (void) interrupt
; -----------------------------------------
; function isr_USBRESET
; -----------------------------------------
_isr_USBRESET:
push bits
push acc
push b
push dpl
push dph
push (0+2)
push (0+3)
push (0+4)
push (0+5)
push (0+6)
push (0+7)
push (0+0)
push (0+1)
push psw
mov psw,#0x00
; usb_common.c:113: clear_usb_irq ();
anl _EXIF,#0xEF
mov _INT2CLR,#0x00
; usb_common.c:114: setup_descriptors ();
lcall _setup_descriptors
pop psw
pop (0+1)
pop (0+0)
pop (0+7)
pop (0+6)
pop (0+5)
pop (0+4)
pop (0+3)
pop (0+2)
pop dph
pop dpl
pop b
pop acc
pop bits
reti
;------------------------------------------------------------
;Allocation info for local variables in function 'isr_HIGHSPEED'
;------------------------------------------------------------
;------------------------------------------------------------
; usb_common.c:118: isr_HIGHSPEED (void) interrupt
; -----------------------------------------
; function isr_HIGHSPEED
; -----------------------------------------
_isr_HIGHSPEED:
push bits
push acc
push b
push dpl
push dph
push (0+2)
push (0+3)
push (0+4)
push (0+5)
push (0+6)
push (0+7)
push (0+0)
push (0+1)
push psw
mov psw,#0x00
; usb_common.c:120: clear_usb_irq ();
anl _EXIF,#0xEF
mov _INT2CLR,#0x00
; usb_common.c:121: setup_descriptors ();
lcall _setup_descriptors
pop psw
pop (0+1)
pop (0+0)
pop (0+7)
pop (0+6)
pop (0+5)
pop (0+4)
pop (0+3)
pop (0+2)
pop dph
pop dpl
pop b
pop acc
pop bits
reti
;------------------------------------------------------------
;Allocation info for local variables in function 'usb_install_handlers'
;------------------------------------------------------------
;------------------------------------------------------------
; usb_common.c:125: usb_install_handlers (void)
; -----------------------------------------
; function usb_install_handlers
; -----------------------------------------
_usb_install_handlers:
; usb_common.c:127: setup_descriptors (); // ensure that they're set before use
lcall _setup_descriptors
; usb_common.c:129: hook_uv (UV_SUDAV, (unsigned short) isr_SUDAV);
mov _hook_uv_PARM_2,#_isr_SUDAV
mov (_hook_uv_PARM_2 + 1),#(_isr_SUDAV >> 8)
mov dpl,#0x00
lcall _hook_uv
; usb_common.c:130: hook_uv (UV_USBRESET, (unsigned short) isr_USBRESET);
mov _hook_uv_PARM_2,#_isr_USBRESET
mov (_hook_uv_PARM_2 + 1),#(_isr_USBRESET >> 8)
mov dpl,#0x10
lcall _hook_uv
; usb_common.c:131: hook_uv (UV_HIGHSPEED, (unsigned short) isr_HIGHSPEED);
mov _hook_uv_PARM_2,#_isr_HIGHSPEED
mov (_hook_uv_PARM_2 + 1),#(_isr_HIGHSPEED >> 8)
mov dpl,#0x14
lcall _hook_uv
; usb_common.c:133: USBIE = bmSUDAV | bmURES | bmHSGRANT;
mov dptr,#_USBIE
mov a,#0x31
movx @dptr,a
ret
;------------------------------------------------------------
;Allocation info for local variables in function 'plausible_endpoint'
;------------------------------------------------------------
;ep Allocated to registers r2
;------------------------------------------------------------
; usb_common.c:140: plausible_endpoint (unsigned char ep)
; -----------------------------------------
; function plausible_endpoint
; -----------------------------------------
_plausible_endpoint:
; usb_common.c:142: ep &= ~0x80; // ignore direction bit
; usb_common.c:144: if (ep > 8)
mov a,dpl
anl a,#0x7F
mov r2,a
add a,#0xff - 0x08
jnc 00102$
; usb_common.c:145: return 0;
mov dpl,#0x00
ret
00102$:
; usb_common.c:147: if (ep == 1)
cjne r2,#0x01,00104$
; usb_common.c:148: return 1;
mov dpl,#0x01
ret
00104$:
; usb_common.c:150: return (ep & 0x1) == 0; // must be even
anl ar2,#0x01
clr a
cjne r2,#0x00,00112$
inc a
00112$:
mov dpl,a
ret
;------------------------------------------------------------
;Allocation info for local variables in function 'epcs'
;------------------------------------------------------------
;ep Allocated to registers r2
;------------------------------------------------------------
; usb_common.c:157: epcs (unsigned char ep)
; -----------------------------------------
; function epcs
; -----------------------------------------
_epcs:
mov r2,dpl
; usb_common.c:159: if (ep == 0x01) // ep1 has different in and out CS regs
cjne r2,#0x01,00102$
; usb_common.c:160: return EP1OUTCS;
mov dptr,#_EP1OUTCS
movx a,@dptr
mov r3,a
mov r4,#0x00
mov dpl,r3
mov dph,r4
ret
00102$:
; usb_common.c:162: if (ep == 0x81)
cjne r2,#0x81,00104$
; usb_common.c:163: return EP1INCS;
mov dptr,#_EP1INCS
movx a,@dptr
mov r3,a
mov r4,#0x00
mov dpl,r3
mov dph,r4
ret
00104$:
; usb_common.c:165: ep &= ~0x80; // ignore direction bit
anl ar2,#0x7F
; usb_common.c:167: if (ep == 0x00) // ep0
mov a,r2
jnz 00106$
; usb_common.c:168: return EP0CS;
mov dptr,#_EP0CS
movx a,@dptr
mov r3,a
mov r4,#0x00
mov dpl,r3
mov dph,r4
ret
00106$:
; usb_common.c:170: return EP2CS + (ep >> 1); // 2, 4, 6, 8 are consecutive
mov dptr,#_EP2CS
movx a,@dptr
mov r3,a
mov r4,#0x00
mov a,r2
clr c
rrc a
mov r2,a
mov r5,#0x00
mov a,r2
add a,r3
mov r3,a
mov a,r5
addc a,r4
mov dpl,r3
mov dph,a
ret
;------------------------------------------------------------
;Allocation info for local variables in function 'usb_handle_setup_packet'
;------------------------------------------------------------
;p Allocated to registers r2 r3
;__00060000 Allocated to registers r2 r3
;__00050001 Allocated to registers r2 r3
;------------------------------------------------------------
; usb_common.c:174: usb_handle_setup_packet (void)
; -----------------------------------------
; function usb_handle_setup_packet
; -----------------------------------------
_usb_handle_setup_packet:
; usb_common.c:176: _usb_got_SUDAV = 0;
clr __usb_got_SUDAV
; usb_common.c:180: switch (bRequestType & bmRT_TYPE_MASK){
mov dptr,#_SETUPDAT
movx a,@dptr
mov r2,a
anl ar2,#0x60
cjne r2,#0x00,00206$
sjmp 00106$
00206$:
cjne r2,#0x20,00207$
sjmp 00102$
00207$:
cjne r2,#0x40,00208$
sjmp 00103$
00208$:
cjne r2,#0x60,00209$
sjmp 00210$
00209$:
ljmp 00175$
00210$:
; usb_common.c:183: case bmRT_TYPE_RESERVED:
00102$:
; usb_common.c:184: fx2_stall_ep0 (); // we don't handle these. indicate error
lcall _fx2_stall_ep0
; usb_common.c:185: break;
ljmp 00175$
; usb_common.c:187: case bmRT_TYPE_VENDOR:
00103$:
; usb_common.c:191: if (!app_vendor_cmd ())
lcall _app_vendor_cmd
mov a,dpl
jz 00211$
ljmp 00175$
00211$:
; usb_common.c:192: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:193: break;
ljmp 00175$
; usb_common.c:195: case bmRT_TYPE_STD:
00106$:
; usb_common.c:198: if ((bRequestType & bmRT_DIR_MASK) == bmRT_DIR_IN){
mov dptr,#_SETUPDAT
movx a,@dptr
mov r2,a
anl ar2,#0x80
cjne r2,#0x80,00212$
sjmp 00213$
00212$:
ljmp 00173$
00213$:
; usb_common.c:204: switch (bRequest){
mov dptr,#(_SETUPDAT + 0x0001)
movx a,@dptr
mov r2,a
cjne r2,#0x00,00214$
ljmp 00128$
00214$:
cjne r2,#0x06,00215$
sjmp 00109$
00215$:
cjne r2,#0x08,00216$
sjmp 00107$
00216$:
cjne r2,#0x0A,00217$
sjmp 00108$
00217$:
ljmp 00138$
; usb_common.c:206: case RQ_GET_CONFIG:
00107$:
; usb_common.c:207: EP0BUF[0] = _usb_config; // FIXME app should handle
mov dptr,#_EP0BUF
mov a,__usb_config
movx @dptr,a
; usb_common.c:208: EP0BCH = 0;
mov dptr,#_EP0BCH
clr a
movx @dptr,a
; usb_common.c:209: EP0BCL = 1;
mov dptr,#_EP0BCL
mov a,#0x01
movx @dptr,a
; usb_common.c:210: break;
ljmp 00175$
; usb_common.c:214: case RQ_GET_INTERFACE:
00108$:
; usb_common.c:215: EP0BUF[0] = _usb_alt_setting; // FIXME app should handle
mov dptr,#_EP0BUF
mov a,__usb_alt_setting
movx @dptr,a
; usb_common.c:216: EP0BCH = 0;
mov dptr,#_EP0BCH
clr a
movx @dptr,a
; usb_common.c:217: EP0BCL = 1;
mov dptr,#_EP0BCL
mov a,#0x01
movx @dptr,a
; usb_common.c:218: break;
ljmp 00175$
; usb_common.c:222: case RQ_GET_DESCR:
00109$:
; usb_common.c:223: switch (wValueH){
mov dptr,#(_SETUPDAT + 0x0003)
movx a,@dptr
mov r2,a
cjne r2,#0x01,00218$
sjmp 00110$
00218$:
cjne r2,#0x02,00219$
sjmp 00114$
00219$:
cjne r2,#0x03,00220$
sjmp 00122$
00220$:
cjne r2,#0x06,00221$
sjmp 00111$
00221$:
cjne r2,#0x07,00222$
sjmp 00119$
00222$:
ljmp 00126$
; usb_common.c:225: case DT_DEVICE:
00110$:
; usb_common.c:226: SUDPTRH = MSB (current_device_descr);
mov r2,_current_device_descr
mov r3,(_current_device_descr + 1)
mov dptr,#_SUDPTRH
mov a,r3
movx @dptr,a
; usb_common.c:227: SUDPTRL = LSB (current_device_descr);
mov r3,#0x00
mov dptr,#_SUDPTRL
mov a,r2
movx @dptr,a
; usb_common.c:228: break;
ljmp 00175$
; usb_common.c:230: case DT_DEVQUAL:
00111$:
; usb_common.c:231: SUDPTRH = MSB (current_devqual_descr);
mov r2,_current_devqual_descr
mov r3,(_current_devqual_descr + 1)
mov dptr,#_SUDPTRH
mov a,r3
movx @dptr,a
; usb_common.c:232: SUDPTRL = LSB (current_devqual_descr);
mov r3,#0x00
mov dptr,#_SUDPTRL
mov a,r2
movx @dptr,a
; usb_common.c:233: break;
ljmp 00175$
; usb_common.c:237: fx2_stall_ep0 ();
00114$:
; usb_common.c:239: SUDPTRH = MSB (current_config_descr);
mov r2,_current_config_descr
mov r3,(_current_config_descr + 1)
mov dptr,#_SUDPTRH
mov a,r3
movx @dptr,a
; usb_common.c:240: SUDPTRL = LSB (current_config_descr);
mov r3,#0x00
mov dptr,#_SUDPTRL
mov a,r2
movx @dptr,a
; usb_common.c:242: break;
ljmp 00175$
; usb_common.c:246: fx2_stall_ep0 ();
00119$:
; usb_common.c:248: SUDPTRH = MSB (other_config_descr);
mov r2,_other_config_descr
mov r3,(_other_config_descr + 1)
mov dptr,#_SUDPTRH
mov a,r3
movx @dptr,a
; usb_common.c:249: SUDPTRL = LSB (other_config_descr);
mov r3,#0x00
mov dptr,#_SUDPTRL
mov a,r2
movx @dptr,a
; usb_common.c:251: break;
ljmp 00175$
; usb_common.c:253: case DT_STRING:
00122$:
; usb_common.c:254: if (wValueL >= nstring_descriptors)
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
mov r2,a
mov dptr,#_nstring_descriptors
movx a,@dptr
mov r3,a
clr c
mov a,r2
subb a,r3
jc 00124$
; usb_common.c:255: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
ljmp 00175$
00124$:
; usb_common.c:257: xdata char *p = string_descriptors[wValueL];
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
mov b,#0x02
mul ab
add a,#_string_descriptors
mov dpl,a
mov a,#(_string_descriptors >> 8)
addc a,b
mov dph,a
movx a,@dptr
mov r2,a
inc dptr
movx a,@dptr
; usb_common.c:258: SUDPTRH = MSB (p);
mov dptr,#_SUDPTRH
movx @dptr,a
; usb_common.c:259: SUDPTRL = LSB (p);
mov r3,#0x00
mov dptr,#_SUDPTRL
mov a,r2
movx @dptr,a
; usb_common.c:261: break;
ljmp 00175$
; usb_common.c:263: default:
00126$:
; usb_common.c:264: fx2_stall_ep0 (); // invalid request
lcall _fx2_stall_ep0
; usb_common.c:267: break;
ljmp 00175$
; usb_common.c:271: case RQ_GET_STATUS:
00128$:
; usb_common.c:272: switch (bRequestType & bmRT_RECIP_MASK){
mov dptr,#_SETUPDAT
movx a,@dptr
mov r2,a
anl ar2,#0x1F
cjne r2,#0x00,00224$
sjmp 00129$
00224$:
cjne r2,#0x01,00225$
sjmp 00130$
00225$:
; usb_common.c:273: case bmRT_RECIP_DEVICE:
cjne r2,#0x02,00135$
sjmp 00131$
00129$:
; usb_common.c:274: EP0BUF[0] = bmGSDA_SELF_POWERED; // FIXME app should handle
mov dptr,#_EP0BUF
mov a,#0x01
movx @dptr,a
; usb_common.c:275: EP0BUF[1] = 0;
mov dptr,#(_EP0BUF + 0x0001)
; usb_common.c:276: EP0BCH = 0;
clr a
movx @dptr,a
mov dptr,#_EP0BCH
movx @dptr,a
; usb_common.c:277: EP0BCL = 2;
mov dptr,#_EP0BCL
mov a,#0x02
movx @dptr,a
; usb_common.c:278: break;
; usb_common.c:280: case bmRT_RECIP_INTERFACE:
sjmp 00138$
00130$:
; usb_common.c:281: EP0BUF[0] = 0;
mov dptr,#_EP0BUF
; usb_common.c:282: EP0BUF[1] = 0;
; usb_common.c:283: EP0BCH = 0;
clr a
movx @dptr,a
mov dptr,#(_EP0BUF + 0x0001)
movx @dptr,a
mov dptr,#_EP0BCH
movx @dptr,a
; usb_common.c:284: EP0BCL = 2;
mov dptr,#_EP0BCL
mov a,#0x02
movx @dptr,a
; usb_common.c:285: break;
; usb_common.c:287: case bmRT_RECIP_ENDPOINT:
sjmp 00138$
00131$:
; usb_common.c:288: if (plausible_endpoint (wIndexL)){
mov dptr,#(_SETUPDAT + 0x0004)
movx a,@dptr
mov dpl,a
lcall _plausible_endpoint
mov a,dpl
jz 00133$
; usb_common.c:289: EP0BUF[0] = *epcs (wIndexL) & bmEPSTALL;
mov dptr,#(_SETUPDAT + 0x0004)
movx a,@dptr
mov dpl,a
lcall _epcs
movx a,@dptr
mov r2,a
anl ar2,#0x01
mov dptr,#_EP0BUF
mov a,r2
movx @dptr,a
; usb_common.c:290: EP0BUF[1] = 0;
mov dptr,#(_EP0BUF + 0x0001)
; usb_common.c:291: EP0BCH = 0;
clr a
movx @dptr,a
mov dptr,#_EP0BCH
movx @dptr,a
; usb_common.c:292: EP0BCL = 2;
mov dptr,#_EP0BCL
mov a,#0x02
movx @dptr,a
sjmp 00138$
00133$:
; usb_common.c:295: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:296: break;
; usb_common.c:298: default:
sjmp 00138$
00135$:
; usb_common.c:299: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:306: default:
00138$:
; usb_common.c:307: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:309: }
ljmp 00175$
00173$:
; usb_common.c:318: switch (bRequest){
mov dptr,#(_SETUPDAT + 0x0001)
movx a,@dptr
mov r2,a
add a,#0xff - 0x0B
jnc 00228$
ljmp 00170$
00228$:
mov a,r2
add a,r2
add a,r2
mov dptr,#00229$
jmp @a+dptr
00229$:
ljmp 00170$
ljmp 00142$
ljmp 00161$
ljmp 00154$
ljmp 00170$
ljmp 00168$
ljmp 00170$
ljmp 00169$
ljmp 00170$
ljmp 00140$
ljmp 00170$
ljmp 00141$
; usb_common.c:320: case RQ_SET_CONFIG:
00140$:
; usb_common.c:321: _usb_config = wValueL; // FIXME app should handle
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
mov __usb_config,a
; usb_common.c:322: break;
ljmp 00175$
; usb_common.c:324: case RQ_SET_INTERFACE:
00141$:
; usb_common.c:325: _usb_alt_setting = wValueL; // FIXME app should handle
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
mov __usb_alt_setting,a
; usb_common.c:326: break;
ljmp 00175$
; usb_common.c:330: case RQ_CLEAR_FEATURE:
00142$:
; usb_common.c:331: switch (bRequestType & bmRT_RECIP_MASK){
mov dptr,#_SETUPDAT
movx a,@dptr
mov r2,a
anl ar2,#0x1F
cjne r2,#0x00,00230$
sjmp 00143$
00230$:
; usb_common.c:333: case bmRT_RECIP_DEVICE:
cjne r2,#0x02,00152$
sjmp 00147$
00143$:
; usb_common.c:334: switch (wValueL){
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
; usb_common.c:337: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:339: break;
ljmp 00175$
; usb_common.c:341: case bmRT_RECIP_ENDPOINT:
00147$:
; usb_common.c:342: if (wValueL == FS_ENDPOINT_HALT && plausible_endpoint (wIndexL)){
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
jnz 00149$
mov dptr,#(_SETUPDAT + 0x0004)
movx a,@dptr
mov dpl,a
lcall _plausible_endpoint
mov a,dpl
jz 00149$
; usb_common.c:343: *epcs (wIndexL) &= ~bmEPSTALL;
mov dptr,#(_SETUPDAT + 0x0004)
movx a,@dptr
mov dpl,a
lcall _epcs
mov r2,dpl
mov r3,dph
movx a,@dptr
mov r4,a
anl ar4,#0xFE
mov dpl,r2
mov dph,r3
mov a,r4
movx @dptr,a
; usb_common.c:344: fx2_reset_data_toggle (wIndexL);
mov dptr,#(_SETUPDAT + 0x0004)
movx a,@dptr
mov dpl,a
lcall _fx2_reset_data_toggle
sjmp 00175$
00149$:
; usb_common.c:347: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:348: break;
; usb_common.c:350: default:
sjmp 00175$
00152$:
; usb_common.c:351: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:354: break;
; usb_common.c:358: case RQ_SET_FEATURE:
sjmp 00175$
00154$:
; usb_common.c:359: switch (bRequestType & bmRT_RECIP_MASK){
mov dptr,#_SETUPDAT
movx a,@dptr
mov r2,a
anl ar2,#0x1F
cjne r2,#0x00,00175$
; usb_common.c:362: switch (wValueL){
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
mov r2,a
cjne r2,#0x01,00236$
sjmp 00158$
00236$:
cjne r2,#0x02,00237$
sjmp 00175$
00237$:
; usb_common.c:368: default:
00158$:
; usb_common.c:369: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:373: break;
; usb_common.c:375: case bmRT_RECIP_ENDPOINT:
sjmp 00175$
00161$:
; usb_common.c:376: switch (wValueL){
mov dptr,#(_SETUPDAT + 0x0002)
movx a,@dptr
mov r2,a
jnz 00166$
; usb_common.c:378: if (plausible_endpoint (wIndexL))
mov dptr,#(_SETUPDAT + 0x0004)
movx a,@dptr
mov dpl,a
lcall _plausible_endpoint
mov a,dpl
jz 00164$
; usb_common.c:379: *epcs (wIndexL) |= bmEPSTALL;
mov dptr,#(_SETUPDAT + 0x0004)
movx a,@dptr
mov dpl,a
lcall _epcs
mov r2,dpl
mov r3,dph
movx a,@dptr
mov r4,a
orl ar4,#0x01
mov dpl,r2
mov dph,r3
mov a,r4
movx @dptr,a
sjmp 00175$
00164$:
; usb_common.c:381: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:382: break;
; usb_common.c:384: default:
sjmp 00175$
00166$:
; usb_common.c:385: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:388: break;
; usb_common.c:392: case RQ_SET_ADDRESS: // handled by fx2 hardware
sjmp 00175$
00168$:
; usb_common.c:393: case RQ_SET_DESCR: // not implemented
00169$:
; usb_common.c:394: default:
00170$:
; usb_common.c:395: fx2_stall_ep0 ();
lcall _fx2_stall_ep0
; usb_common.c:401: } // bmRT_TYPE_MASK
00175$:
; usb_common.c:404: EP0CS |= bmHSNAK;
mov dptr,#_EP0CS
movx a,@dptr
orl a,#0x80
movx @dptr,a
ret
.area CSEG (CODE)
.area CONST (CODE)
.area CABS (ABS,CODE)