|
|
|
@ -33,8 +33,6 @@ _USB_MODULE_LEDS .EQU 0xff8a |
|
|
|
|
|
|
|
; .area _INITIALIZED removed by z88dk |
|
|
|
|
|
|
|
_result: |
|
|
|
DEFS 1 |
|
|
|
|
|
|
|
#ENDIF |
|
|
|
|
|
|
|
@ -50,12 +48,12 @@ _result: |
|
|
|
;-------------------------------------------------------- |
|
|
|
; code |
|
|
|
;-------------------------------------------------------- |
|
|
|
;source-doc/base-drv/ch376.c:8: void ch_command(const uint8_t command) __z88dk_fastcall { |
|
|
|
;source-doc/base-drv/ch376.c:6: void ch_command(const uint8_t command) __z88dk_fastcall { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_command |
|
|
|
; --------------------------------- |
|
|
|
_ch_command: |
|
|
|
;source-doc/base-drv/ch376.c:10: while ((CH376_COMMAND_PORT & PARA_STATE_BUSY) && --counter != 0) |
|
|
|
;source-doc/base-drv/ch376.c:8: while ((CH376_COMMAND_PORT & PARA_STATE_BUSY) && --counter != 0) |
|
|
|
ld b,0xff |
|
|
|
l_ch_command_00102: |
|
|
|
ld a, +((_CH376_COMMAND_PORT) / 256) |
|
|
|
@ -64,150 +62,150 @@ l_ch_command_00102: |
|
|
|
jr Z,l_ch_command_00104 |
|
|
|
djnz l_ch_command_00102 |
|
|
|
l_ch_command_00104: |
|
|
|
;source-doc/base-drv/ch376.c:21: CH376_COMMAND_PORT = command; |
|
|
|
;source-doc/base-drv/ch376.c:19: CH376_COMMAND_PORT = command; |
|
|
|
ld a, l |
|
|
|
ld bc,_CH376_COMMAND_PORT |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:22: } |
|
|
|
;source-doc/base-drv/ch376.c:20: } |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:26: usb_error ch_long_wait_int_and_get_status(void) { return ch_wait_int_and_get_status(5000); } |
|
|
|
;source-doc/base-drv/ch376.c:24: usb_error ch_long_wait_int_and_get_status(void) { return ch_wait_int_and_get_status(5000); } |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_long_wait_int_and_get_status |
|
|
|
; --------------------------------- |
|
|
|
_ch_long_wait_int_and_get_statu: |
|
|
|
ld hl,0x1388 |
|
|
|
jp _ch_wait_int_and_get_status |
|
|
|
;source-doc/base-drv/ch376.c:28: usb_error ch_short_wait_int_and_get_statu(void) { return ch_wait_int_and_get_status(100); } |
|
|
|
;source-doc/base-drv/ch376.c:26: usb_error ch_short_wait_int_and_get_statu(void) { return ch_wait_int_and_get_status(100); } |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_short_wait_int_and_get_statu |
|
|
|
; --------------------------------- |
|
|
|
_ch_short_wait_int_and_get_stat: |
|
|
|
ld hl,0x0064 |
|
|
|
jp _ch_wait_int_and_get_status |
|
|
|
;source-doc/base-drv/ch376.c:30: usb_error ch_very_short_wait_int_and_get_(void) { return ch_wait_int_and_get_status(10); } |
|
|
|
;source-doc/base-drv/ch376.c:28: usb_error ch_very_short_wait_int_and_get_(void) { return ch_wait_int_and_get_status(10); } |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_very_short_wait_int_and_get_ |
|
|
|
; --------------------------------- |
|
|
|
_ch_very_short_wait_int_and_get: |
|
|
|
ld hl,0x000a |
|
|
|
jp _ch_wait_int_and_get_status |
|
|
|
;source-doc/base-drv/ch376.c:32: usb_error ch_get_status(void) { |
|
|
|
;source-doc/base-drv/ch376.c:30: usb_error ch_get_status(void) { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_get_status |
|
|
|
; --------------------------------- |
|
|
|
_ch_get_status: |
|
|
|
;source-doc/base-drv/ch376.c:33: ch_command(CH_CMD_GET_STATUS); |
|
|
|
;source-doc/base-drv/ch376.c:31: ch_command(CH_CMD_GET_STATUS); |
|
|
|
ld l,0x22 |
|
|
|
call _ch_command |
|
|
|
;source-doc/base-drv/ch376.c:34: uint8_t ch_status = CH376_DATA_PORT; |
|
|
|
;source-doc/base-drv/ch376.c:32: uint8_t ch_status = CH376_DATA_PORT; |
|
|
|
ld a, +((_CH376_DATA_PORT) / 256) |
|
|
|
in a, (((_CH376_DATA_PORT) & 0xFF)) |
|
|
|
;source-doc/base-drv/ch376.c:36: if (ch_status >= USB_FILERR_MIN && ch_status <= USB_FILERR_MAX) |
|
|
|
;source-doc/base-drv/ch376.c:34: if (ch_status >= USB_FILERR_MIN && ch_status <= USB_FILERR_MAX) |
|
|
|
cp 0x41 |
|
|
|
jr C,l_ch_get_status_00102 |
|
|
|
cp 0xb5 |
|
|
|
jr NC,l_ch_get_status_00102 |
|
|
|
;source-doc/base-drv/ch376.c:37: return ch_status; |
|
|
|
;source-doc/base-drv/ch376.c:35: return ch_status; |
|
|
|
ld l, a |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00102: |
|
|
|
;source-doc/base-drv/ch376.c:39: if (ch_status == CH_CMD_RET_SUCCESS) |
|
|
|
;source-doc/base-drv/ch376.c:37: if (ch_status == CH_CMD_RET_SUCCESS) |
|
|
|
cp 0x51 |
|
|
|
jr NZ,l_ch_get_status_00105 |
|
|
|
;source-doc/base-drv/ch376.c:40: return USB_ERR_OK; |
|
|
|
;source-doc/base-drv/ch376.c:38: return USB_ERR_OK; |
|
|
|
ld l,0x00 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00105: |
|
|
|
;source-doc/base-drv/ch376.c:42: if (ch_status == CH_USB_INT_SUCCESS) |
|
|
|
;source-doc/base-drv/ch376.c:40: if (ch_status == CH_USB_INT_SUCCESS) |
|
|
|
cp 0x14 |
|
|
|
jr NZ,l_ch_get_status_00107 |
|
|
|
;source-doc/base-drv/ch376.c:43: return USB_ERR_OK; |
|
|
|
;source-doc/base-drv/ch376.c:41: return USB_ERR_OK; |
|
|
|
ld l,0x00 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00107: |
|
|
|
;source-doc/base-drv/ch376.c:45: if (ch_status == CH_USB_INT_CONNECT) |
|
|
|
;source-doc/base-drv/ch376.c:43: if (ch_status == CH_USB_INT_CONNECT) |
|
|
|
cp 0x15 |
|
|
|
jr NZ,l_ch_get_status_00109 |
|
|
|
;source-doc/base-drv/ch376.c:46: return USB_INT_CONNECT; |
|
|
|
;source-doc/base-drv/ch376.c:44: return USB_INT_CONNECT; |
|
|
|
ld l,0x81 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00109: |
|
|
|
;source-doc/base-drv/ch376.c:48: if (ch_status == CH_USB_INT_DISK_READ) |
|
|
|
;source-doc/base-drv/ch376.c:46: if (ch_status == CH_USB_INT_DISK_READ) |
|
|
|
cp 0x1d |
|
|
|
jr NZ,l_ch_get_status_00111 |
|
|
|
;source-doc/base-drv/ch376.c:49: return USB_ERR_DISK_READ; |
|
|
|
;source-doc/base-drv/ch376.c:47: return USB_ERR_DISK_READ; |
|
|
|
ld l,0x1d |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00111: |
|
|
|
;source-doc/base-drv/ch376.c:51: if (ch_status == CH_USB_INT_DISK_WRITE) |
|
|
|
;source-doc/base-drv/ch376.c:49: if (ch_status == CH_USB_INT_DISK_WRITE) |
|
|
|
cp 0x1e |
|
|
|
jr NZ,l_ch_get_status_00113 |
|
|
|
;source-doc/base-drv/ch376.c:52: return USB_ERR_DISK_WRITE; |
|
|
|
;source-doc/base-drv/ch376.c:50: return USB_ERR_DISK_WRITE; |
|
|
|
ld l,0x1e |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00113: |
|
|
|
;source-doc/base-drv/ch376.c:54: if (ch_status == CH_USB_INT_DISCONNECT) { |
|
|
|
;source-doc/base-drv/ch376.c:52: if (ch_status == CH_USB_INT_DISCONNECT) { |
|
|
|
cp 0x16 |
|
|
|
jr NZ,l_ch_get_status_00115 |
|
|
|
;source-doc/base-drv/ch376.c:55: ch_cmd_set_usb_mode(5); |
|
|
|
;source-doc/base-drv/ch376.c:53: ch_cmd_set_usb_mode(5); |
|
|
|
ld l,0x05 |
|
|
|
call _ch_cmd_set_usb_mode |
|
|
|
;source-doc/base-drv/ch376.c:56: return USB_ERR_NO_DEVICE; |
|
|
|
;source-doc/base-drv/ch376.c:54: return USB_ERR_NO_DEVICE; |
|
|
|
ld l,0x05 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00115: |
|
|
|
;source-doc/base-drv/ch376.c:59: if (ch_status == CH_USB_INT_BUF_OVER) |
|
|
|
;source-doc/base-drv/ch376.c:57: if (ch_status == CH_USB_INT_BUF_OVER) |
|
|
|
cp 0x17 |
|
|
|
jr NZ,l_ch_get_status_00117 |
|
|
|
;source-doc/base-drv/ch376.c:60: return USB_ERR_DATA_ERROR; |
|
|
|
;source-doc/base-drv/ch376.c:58: return USB_ERR_DATA_ERROR; |
|
|
|
ld l,0x04 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00117: |
|
|
|
;source-doc/base-drv/ch376.c:62: ch_status &= 0x2F; |
|
|
|
;source-doc/base-drv/ch376.c:60: ch_status &= 0x2F; |
|
|
|
and 0x2f |
|
|
|
;source-doc/base-drv/ch376.c:64: if (ch_status == 0x2A) |
|
|
|
;source-doc/base-drv/ch376.c:62: if (ch_status == 0x2A) |
|
|
|
cp 0x2a |
|
|
|
jr NZ,l_ch_get_status_00119 |
|
|
|
;source-doc/base-drv/ch376.c:65: return USB_ERR_NAK; |
|
|
|
;source-doc/base-drv/ch376.c:63: return USB_ERR_NAK; |
|
|
|
ld l,0x01 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00119: |
|
|
|
;source-doc/base-drv/ch376.c:67: if (ch_status == 0x2E) |
|
|
|
;source-doc/base-drv/ch376.c:65: if (ch_status == 0x2E) |
|
|
|
cp 0x2e |
|
|
|
jr NZ,l_ch_get_status_00121 |
|
|
|
;source-doc/base-drv/ch376.c:68: return USB_ERR_STALL; |
|
|
|
;source-doc/base-drv/ch376.c:66: return USB_ERR_STALL; |
|
|
|
ld l,0x02 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00121: |
|
|
|
;source-doc/base-drv/ch376.c:70: ch_status &= 0x23; |
|
|
|
;source-doc/base-drv/ch376.c:68: ch_status &= 0x23; |
|
|
|
and 0x23 |
|
|
|
;source-doc/base-drv/ch376.c:72: if (ch_status == 0x20) |
|
|
|
;source-doc/base-drv/ch376.c:70: if (ch_status == 0x20) |
|
|
|
cp 0x20 |
|
|
|
jr NZ,l_ch_get_status_00123 |
|
|
|
;source-doc/base-drv/ch376.c:73: return USB_ERR_TIMEOUT; |
|
|
|
;source-doc/base-drv/ch376.c:71: return USB_ERR_TIMEOUT; |
|
|
|
ld l,0x03 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00123: |
|
|
|
;source-doc/base-drv/ch376.c:75: if (ch_status == 0x23) |
|
|
|
;source-doc/base-drv/ch376.c:73: if (ch_status == 0x23) |
|
|
|
sub 0x23 |
|
|
|
jr NZ,l_ch_get_status_00125 |
|
|
|
;source-doc/base-drv/ch376.c:76: return USB_TOKEN_OUT_OF_SYNC; |
|
|
|
;source-doc/base-drv/ch376.c:74: return USB_TOKEN_OUT_OF_SYNC; |
|
|
|
ld l,0x07 |
|
|
|
jr l_ch_get_status_00126 |
|
|
|
l_ch_get_status_00125: |
|
|
|
;source-doc/base-drv/ch376.c:78: return USB_ERR_UNEXPECTED_STATUS_FROM_; |
|
|
|
;source-doc/base-drv/ch376.c:76: return USB_ERR_UNEXPECTED_STATUS_FROM_; |
|
|
|
ld l,0x08 |
|
|
|
l_ch_get_status_00126: |
|
|
|
;source-doc/base-drv/ch376.c:79: } |
|
|
|
;source-doc/base-drv/ch376.c:77: } |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:81: void ch_cmd_reset_all(void) { ch_command(CH_CMD_RESET_ALL); } |
|
|
|
;source-doc/base-drv/ch376.c:79: void ch_cmd_reset_all(void) { ch_command(CH_CMD_RESET_ALL); } |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_cmd_reset_all |
|
|
|
; --------------------------------- |
|
|
|
_ch_cmd_reset_all: |
|
|
|
ld l,0x05 |
|
|
|
jp _ch_command |
|
|
|
;source-doc/base-drv/ch376.c:100: uint8_t ch_probe(void) { |
|
|
|
;source-doc/base-drv/ch376.c:98: uint8_t ch_probe(void) { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_probe |
|
|
|
; --------------------------------- |
|
|
|
@ -216,66 +214,66 @@ _ch_probe: |
|
|
|
ld ix,0 |
|
|
|
add ix,sp |
|
|
|
dec sp |
|
|
|
;source-doc/base-drv/ch376.c:102: do { |
|
|
|
;source-doc/base-drv/ch376.c:100: do { |
|
|
|
ld (ix-1),0x05 |
|
|
|
l_ch_probe_00103: |
|
|
|
;source-doc/base-drv/ch376.c:85: ch_command(CH_CMD_CHECK_EXIST); |
|
|
|
;source-doc/base-drv/ch376.c:83: ch_command(CH_CMD_CHECK_EXIST); |
|
|
|
ld l,0x06 |
|
|
|
call _ch_command |
|
|
|
;source-doc/base-drv/ch376.c:86: CH376_DATA_PORT = (uint8_t)~0x55; |
|
|
|
;source-doc/base-drv/ch376.c:84: CH376_DATA_PORT = (uint8_t)~0x55; |
|
|
|
ld a,0xaa |
|
|
|
ld bc,_CH376_DATA_PORT |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:87: delay(); |
|
|
|
;source-doc/base-drv/ch376.c:85: delay(); |
|
|
|
call _delay |
|
|
|
;source-doc/base-drv/ch376.c:88: complement = CH376_DATA_PORT; |
|
|
|
;source-doc/base-drv/ch376.c:86: complement = CH376_DATA_PORT; |
|
|
|
ld a, +((_CH376_DATA_PORT) / 256) |
|
|
|
in a, (((_CH376_DATA_PORT) & 0xFF)) |
|
|
|
;source-doc/base-drv/ch376.c:89: return complement == 0x55; |
|
|
|
;source-doc/base-drv/ch376.c:87: return complement == 0x55; |
|
|
|
sub 0x55 |
|
|
|
jr NZ,l_ch_probe_00102 |
|
|
|
;source-doc/base-drv/ch376.c:103: if (ch_cmd_check_exist()) |
|
|
|
;source-doc/base-drv/ch376.c:104: return true; |
|
|
|
;source-doc/base-drv/ch376.c:101: if (ch_cmd_check_exist()) |
|
|
|
;source-doc/base-drv/ch376.c:102: return true; |
|
|
|
ld l,0x01 |
|
|
|
jr l_ch_probe_00107 |
|
|
|
l_ch_probe_00102: |
|
|
|
;source-doc/base-drv/ch376.c:106: delay_medium(); |
|
|
|
;source-doc/base-drv/ch376.c:104: delay_medium(); |
|
|
|
call _delay_medium |
|
|
|
;source-doc/base-drv/ch376.c:107: } while (--i != 0); |
|
|
|
;source-doc/base-drv/ch376.c:105: } while (--i != 0); |
|
|
|
dec (ix-1) |
|
|
|
jr NZ,l_ch_probe_00103 |
|
|
|
;source-doc/base-drv/ch376.c:109: return false; |
|
|
|
;source-doc/base-drv/ch376.c:107: return false; |
|
|
|
ld l,0x00 |
|
|
|
l_ch_probe_00107: |
|
|
|
;source-doc/base-drv/ch376.c:110: } |
|
|
|
;source-doc/base-drv/ch376.c:108: } |
|
|
|
inc sp |
|
|
|
pop ix |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:112: usb_error ch_cmd_set_usb_mode(const uint8_t mode) __z88dk_fastcall { |
|
|
|
;source-doc/base-drv/ch376.c:110: usb_error ch_cmd_set_usb_mode(const uint8_t mode) __z88dk_fastcall { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_cmd_set_usb_mode |
|
|
|
; --------------------------------- |
|
|
|
_ch_cmd_set_usb_mode: |
|
|
|
ld c, l |
|
|
|
;source-doc/base-drv/ch376.c:113: uint8_t result = 0; |
|
|
|
;source-doc/base-drv/ch376.c:111: uint8_t result = 0; |
|
|
|
ld b,0x00 |
|
|
|
;source-doc/base-drv/ch376.c:115: CH376_COMMAND_PORT = CH_CMD_SET_USB_MODE; |
|
|
|
;source-doc/base-drv/ch376.c:113: CH376_COMMAND_PORT = CH_CMD_SET_USB_MODE; |
|
|
|
ld a,0x15 |
|
|
|
push bc |
|
|
|
ld bc,_CH376_COMMAND_PORT |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:116: delay(); |
|
|
|
;source-doc/base-drv/ch376.c:114: delay(); |
|
|
|
call _delay |
|
|
|
pop bc |
|
|
|
;source-doc/base-drv/ch376.c:117: CH376_DATA_PORT = mode; |
|
|
|
;source-doc/base-drv/ch376.c:115: CH376_DATA_PORT = mode; |
|
|
|
ld a, c |
|
|
|
push bc |
|
|
|
ld bc,_CH376_DATA_PORT |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:118: delay(); |
|
|
|
;source-doc/base-drv/ch376.c:116: delay(); |
|
|
|
call _delay |
|
|
|
pop bc |
|
|
|
;source-doc/base-drv/ch376.c:122: while (result != CH_CMD_RET_SUCCESS && result != CH_CMD_RET_ABORT && --count != 0) { |
|
|
|
;source-doc/base-drv/ch376.c:120: while (result != CH_CMD_RET_SUCCESS && result != CH_CMD_RET_ABORT && --count != 0) { |
|
|
|
ld c,0x7f |
|
|
|
l_ch_cmd_set_usb_mode_00103: |
|
|
|
ld a, b |
|
|
|
@ -294,17 +292,17 @@ l_ch_cmd_set_usb_mode_00147: |
|
|
|
jr Z,l_ch_cmd_set_usb_mode_00105 |
|
|
|
dec c |
|
|
|
jr Z,l_ch_cmd_set_usb_mode_00105 |
|
|
|
;source-doc/base-drv/ch376.c:123: result = CH376_DATA_PORT; |
|
|
|
;source-doc/base-drv/ch376.c:121: result = CH376_DATA_PORT; |
|
|
|
ld a, +((_CH376_DATA_PORT) / 256) |
|
|
|
in a, (((_CH376_DATA_PORT) & 0xFF)) |
|
|
|
ld b, a |
|
|
|
;source-doc/base-drv/ch376.c:124: delay(); |
|
|
|
;source-doc/base-drv/ch376.c:122: delay(); |
|
|
|
push bc |
|
|
|
call _delay |
|
|
|
pop bc |
|
|
|
jr l_ch_cmd_set_usb_mode_00103 |
|
|
|
l_ch_cmd_set_usb_mode_00105: |
|
|
|
;source-doc/base-drv/ch376.c:127: return (result == CH_CMD_RET_SUCCESS) ? USB_ERR_OK : USB_ERR_FAIL; |
|
|
|
;source-doc/base-drv/ch376.c:125: return (result == CH_CMD_RET_SUCCESS) ? USB_ERR_OK : USB_ERR_FAIL; |
|
|
|
ld a, e |
|
|
|
or a |
|
|
|
jr Z,l_ch_cmd_set_usb_mode_00108 |
|
|
|
@ -313,24 +311,24 @@ l_ch_cmd_set_usb_mode_00105: |
|
|
|
l_ch_cmd_set_usb_mode_00108: |
|
|
|
ld l,0x0e |
|
|
|
l_ch_cmd_set_usb_mode_00109: |
|
|
|
;source-doc/base-drv/ch376.c:128: } |
|
|
|
;source-doc/base-drv/ch376.c:126: } |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:130: uint8_t ch_cmd_get_ic_version(void) { |
|
|
|
;source-doc/base-drv/ch376.c:128: uint8_t ch_cmd_get_ic_version(void) { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_cmd_get_ic_version |
|
|
|
; --------------------------------- |
|
|
|
_ch_cmd_get_ic_version: |
|
|
|
;source-doc/base-drv/ch376.c:131: ch_command(CH_CMD_GET_IC_VER); |
|
|
|
;source-doc/base-drv/ch376.c:129: ch_command(CH_CMD_GET_IC_VER); |
|
|
|
ld l,0x01 |
|
|
|
call _ch_command |
|
|
|
;source-doc/base-drv/ch376.c:132: return CH376_DATA_PORT & 0x1f; |
|
|
|
;source-doc/base-drv/ch376.c:130: return CH376_DATA_PORT & 0x1f; |
|
|
|
ld a, +((_CH376_DATA_PORT) / 256) |
|
|
|
in a, (((_CH376_DATA_PORT) & 0xFF)) |
|
|
|
and 0x1f |
|
|
|
ld l, a |
|
|
|
;source-doc/base-drv/ch376.c:133: } |
|
|
|
;source-doc/base-drv/ch376.c:131: } |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:135: void ch_issue_token(const uint8_t toggle_bit, const uint8_t endpoint, const ch376_pid pid) { |
|
|
|
;source-doc/base-drv/ch376.c:133: void ch_issue_token(const uint8_t toggle_bit, const uint8_t endpoint, const ch376_pid pid) { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_issue_token |
|
|
|
; --------------------------------- |
|
|
|
@ -338,14 +336,14 @@ _ch_issue_token: |
|
|
|
push ix |
|
|
|
ld ix,0 |
|
|
|
add ix,sp |
|
|
|
;source-doc/base-drv/ch376.c:136: ch_command(CH_CMD_ISSUE_TKN_X); |
|
|
|
;source-doc/base-drv/ch376.c:134: ch_command(CH_CMD_ISSUE_TKN_X); |
|
|
|
ld l,0x4e |
|
|
|
call _ch_command |
|
|
|
;source-doc/base-drv/ch376.c:137: CH376_DATA_PORT = toggle_bit; |
|
|
|
;source-doc/base-drv/ch376.c:135: CH376_DATA_PORT = toggle_bit; |
|
|
|
ld a,(ix+4) |
|
|
|
ld bc,_CH376_DATA_PORT |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:138: CH376_DATA_PORT = endpoint << 4 | pid; |
|
|
|
;source-doc/base-drv/ch376.c:136: CH376_DATA_PORT = endpoint << 4 | pid; |
|
|
|
ld a,(ix+5) |
|
|
|
add a, a |
|
|
|
add a, a |
|
|
|
@ -354,15 +352,15 @@ _ch_issue_token: |
|
|
|
or (ix+6) |
|
|
|
ld bc,_CH376_DATA_PORT |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:139: } |
|
|
|
;source-doc/base-drv/ch376.c:137: } |
|
|
|
pop ix |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:141: void ch_issue_token_in(const endpoint_param *const endpoint) __z88dk_fastcall { |
|
|
|
;source-doc/base-drv/ch376.c:139: void ch_issue_token_in(const endpoint_param *const endpoint) __z88dk_fastcall { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_issue_token_in |
|
|
|
; --------------------------------- |
|
|
|
_ch_issue_token_in: |
|
|
|
;source-doc/base-drv/ch376.c:142: ch_issue_token(endpoint->toggle ? 0x80 : 0x00, endpoint->number, CH_PID_IN); |
|
|
|
;source-doc/base-drv/ch376.c:140: ch_issue_token(endpoint->toggle ? 0x80 : 0x00, endpoint->number, CH_PID_IN); |
|
|
|
ld e,l |
|
|
|
ld d,h |
|
|
|
ld a, (hl) |
|
|
|
@ -386,14 +384,14 @@ l_ch_issue_token_in_00104: |
|
|
|
call _ch_issue_token |
|
|
|
pop af |
|
|
|
inc sp |
|
|
|
;source-doc/base-drv/ch376.c:143: } |
|
|
|
;source-doc/base-drv/ch376.c:141: } |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:145: void ch_issue_token_out(const endpoint_param *const endpoint) __z88dk_fastcall { |
|
|
|
;source-doc/base-drv/ch376.c:143: void ch_issue_token_out(const endpoint_param *const endpoint) __z88dk_fastcall { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_issue_token_out |
|
|
|
; --------------------------------- |
|
|
|
_ch_issue_token_out: |
|
|
|
;source-doc/base-drv/ch376.c:146: ch_issue_token(endpoint->toggle ? 0x40 : 0x00, endpoint->number, CH_PID_OUT); |
|
|
|
;source-doc/base-drv/ch376.c:144: ch_issue_token(endpoint->toggle ? 0x40 : 0x00, endpoint->number, CH_PID_OUT); |
|
|
|
ld e,l |
|
|
|
ld d,h |
|
|
|
ld a, (hl) |
|
|
|
@ -417,9 +415,9 @@ l_ch_issue_token_out_00104: |
|
|
|
call _ch_issue_token |
|
|
|
pop af |
|
|
|
inc sp |
|
|
|
;source-doc/base-drv/ch376.c:147: } |
|
|
|
;source-doc/base-drv/ch376.c:145: } |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:149: void ch_issue_token_out_ep0(void) { ch_issue_token(0x40, 0, CH_PID_OUT); } |
|
|
|
;source-doc/base-drv/ch376.c:147: void ch_issue_token_out_ep0(void) { ch_issue_token(0x40, 0, CH_PID_OUT); } |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_issue_token_out_ep0 |
|
|
|
; --------------------------------- |
|
|
|
@ -435,7 +433,7 @@ _ch_issue_token_out_ep0: |
|
|
|
pop af |
|
|
|
inc sp |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:151: void ch_issue_token_in_ep0(void) { ch_issue_token(0x80, 0, CH_PID_IN); } |
|
|
|
;source-doc/base-drv/ch376.c:149: void ch_issue_token_in_ep0(void) { ch_issue_token(0x80, 0, CH_PID_IN); } |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_issue_token_in_ep0 |
|
|
|
; --------------------------------- |
|
|
|
@ -451,7 +449,7 @@ _ch_issue_token_in_ep0: |
|
|
|
pop af |
|
|
|
inc sp |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:153: void ch_issue_token_setup(void) { ch_issue_token(0, 0, CH_PID_SETUP); } |
|
|
|
;source-doc/base-drv/ch376.c:151: void ch_issue_token_setup(void) { ch_issue_token(0, 0, CH_PID_SETUP); } |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_issue_token_setup |
|
|
|
; --------------------------------- |
|
|
|
@ -469,7 +467,7 @@ _ch_issue_token_setup: |
|
|
|
pop af |
|
|
|
inc sp |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:155: usb_error ch_data_in_transfer(uint8_t *buffer, int16_t buffer_size, endpoint_param *const endpoint) { |
|
|
|
;source-doc/base-drv/ch376.c:153: usb_error ch_data_in_transfer(uint8_t *buffer, int16_t buffer_size, endpoint_param *const endpoint) { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_data_in_transfer |
|
|
|
; --------------------------------- |
|
|
|
@ -477,37 +475,36 @@ _ch_data_in_transfer: |
|
|
|
push ix |
|
|
|
ld ix,0 |
|
|
|
add ix,sp |
|
|
|
;source-doc/base-drv/ch376.c:158: if (buffer_size == 0) |
|
|
|
;source-doc/base-drv/ch376.c:157: if (buffer_size == 0) |
|
|
|
ld a,(ix+7) |
|
|
|
or (ix+6) |
|
|
|
jr NZ,l_ch_data_in_transfer_00102 |
|
|
|
;source-doc/base-drv/ch376.c:159: return USB_ERR_OK; |
|
|
|
;source-doc/base-drv/ch376.c:158: return USB_ERR_OK; |
|
|
|
ld l,0x00 |
|
|
|
jp l_ch_data_in_transfer_00111 |
|
|
|
l_ch_data_in_transfer_00102: |
|
|
|
;source-doc/base-drv/ch376.c:161: USB_MODULE_LEDS = 0x01; |
|
|
|
;source-doc/base-drv/ch376.c:160: USB_MODULE_LEDS = 0x01; |
|
|
|
ld a,0x01 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:162: do { |
|
|
|
;source-doc/base-drv/ch376.c:161: do { |
|
|
|
ld c,(ix+8) |
|
|
|
ld b,(ix+9) |
|
|
|
l_ch_data_in_transfer_00107: |
|
|
|
;source-doc/base-drv/ch376.c:163: ch_issue_token_in(endpoint); |
|
|
|
;source-doc/base-drv/ch376.c:162: ch_issue_token_in(endpoint); |
|
|
|
ld l,c |
|
|
|
ld h,b |
|
|
|
push hl |
|
|
|
call _ch_issue_token_in |
|
|
|
;source-doc/base-drv/ch376.c:165: result = ch_long_wait_int_and_get_status(); |
|
|
|
;source-doc/base-drv/ch376.c:164: result = ch_long_wait_int_and_get_status(); |
|
|
|
call _ch_long_wait_int_and_get_statu |
|
|
|
pop bc |
|
|
|
ld a, l |
|
|
|
ld (_result), a |
|
|
|
;source-doc/base-drv/ch376.c:166: CHECK(result); |
|
|
|
ld a,(_result) |
|
|
|
pop bc |
|
|
|
ld l, a |
|
|
|
;source-doc/base-drv/ch376.c:165: CHECK(result); |
|
|
|
or a |
|
|
|
jr NZ,l_ch_data_in_transfer_00110 |
|
|
|
;source-doc/base-drv/ch376.c:168: endpoint->toggle = !endpoint->toggle; |
|
|
|
;source-doc/base-drv/ch376.c:167: endpoint->toggle = !endpoint->toggle; |
|
|
|
ld e, c |
|
|
|
ld d, b |
|
|
|
ld l, e |
|
|
|
@ -521,32 +518,32 @@ l_ch_data_in_transfer_00107: |
|
|
|
and 0xfe |
|
|
|
or l |
|
|
|
ld (de), a |
|
|
|
;source-doc/base-drv/ch376.c:170: count = ch_read_data(buffer); |
|
|
|
;source-doc/base-drv/ch376.c:169: count = ch_read_data(buffer); |
|
|
|
push bc |
|
|
|
ld l,(ix+4) |
|
|
|
ld h,(ix+5) |
|
|
|
call _ch_read_data |
|
|
|
ld e, a |
|
|
|
pop bc |
|
|
|
;source-doc/base-drv/ch376.c:172: if (count == 0) { |
|
|
|
;source-doc/base-drv/ch376.c:171: if (count == 0) { |
|
|
|
ld a, e |
|
|
|
;source-doc/base-drv/ch376.c:173: USB_MODULE_LEDS = 0x00; |
|
|
|
;source-doc/base-drv/ch376.c:172: USB_MODULE_LEDS = 0x00; |
|
|
|
or a |
|
|
|
jr NZ,l_ch_data_in_transfer_00106 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:174: return USB_ERR_DATA_ERROR; |
|
|
|
;source-doc/base-drv/ch376.c:173: return USB_ERR_DATA_ERROR; |
|
|
|
ld l,0x04 |
|
|
|
jr l_ch_data_in_transfer_00111 |
|
|
|
l_ch_data_in_transfer_00106: |
|
|
|
;source-doc/base-drv/ch376.c:177: buffer += count; |
|
|
|
;source-doc/base-drv/ch376.c:176: buffer += count; |
|
|
|
ld a,(ix+4) |
|
|
|
add a, e |
|
|
|
ld (ix+4),a |
|
|
|
jr NC,l_ch_data_in_transfer_00148 |
|
|
|
inc (ix+5) |
|
|
|
l_ch_data_in_transfer_00148: |
|
|
|
;source-doc/base-drv/ch376.c:178: buffer_size -= count; |
|
|
|
;source-doc/base-drv/ch376.c:177: buffer_size -= count; |
|
|
|
ld d,0x00 |
|
|
|
ld a,(ix+6) |
|
|
|
sub e |
|
|
|
@ -554,7 +551,7 @@ l_ch_data_in_transfer_00148: |
|
|
|
ld a,(ix+7) |
|
|
|
sbc a, d |
|
|
|
ld (ix+7),a |
|
|
|
;source-doc/base-drv/ch376.c:179: } while (buffer_size > 0); |
|
|
|
;source-doc/base-drv/ch376.c:178: } while (buffer_size > 0); |
|
|
|
xor a |
|
|
|
cp (ix+6) |
|
|
|
sbc a,(ix+7) |
|
|
|
@ -562,26 +559,25 @@ l_ch_data_in_transfer_00148: |
|
|
|
xor 0x80 |
|
|
|
l_ch_data_in_transfer_00149: |
|
|
|
jp M, l_ch_data_in_transfer_00107 |
|
|
|
;source-doc/base-drv/ch376.c:181: USB_MODULE_LEDS = 0x00; |
|
|
|
;source-doc/base-drv/ch376.c:180: USB_MODULE_LEDS = 0x00; |
|
|
|
ld a,0x00 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:182: return USB_ERR_OK; |
|
|
|
;source-doc/base-drv/ch376.c:181: return USB_ERR_OK; |
|
|
|
ld l,0x00 |
|
|
|
jr l_ch_data_in_transfer_00111 |
|
|
|
;source-doc/base-drv/ch376.c:184: done: |
|
|
|
;source-doc/base-drv/ch376.c:183: done: |
|
|
|
l_ch_data_in_transfer_00110: |
|
|
|
;source-doc/base-drv/ch376.c:185: USB_MODULE_LEDS = 0x00; |
|
|
|
;source-doc/base-drv/ch376.c:184: USB_MODULE_LEDS = 0x00; |
|
|
|
ld a,0x00 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:186: return result; |
|
|
|
ld hl, (_result) |
|
|
|
;source-doc/base-drv/ch376.c:185: return result; |
|
|
|
l_ch_data_in_transfer_00111: |
|
|
|
;source-doc/base-drv/ch376.c:187: } |
|
|
|
;source-doc/base-drv/ch376.c:186: } |
|
|
|
pop ix |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:190: usb_error ch_data_in_transfer_n(uint8_t *const buffer, uint8_t *const buffer_size, endpoint_param *const endpoint) { |
|
|
|
;source-doc/base-drv/ch376.c:189: usb_error ch_data_in_transfer_n(uint8_t *const buffer, uint8_t *const buffer_size, endpoint_param *const endpoint) { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_data_in_transfer_n |
|
|
|
; --------------------------------- |
|
|
|
@ -589,20 +585,20 @@ _ch_data_in_transfer_n: |
|
|
|
push ix |
|
|
|
ld ix,0 |
|
|
|
add ix,sp |
|
|
|
;source-doc/base-drv/ch376.c:194: USB_MODULE_LEDS = 0x01; |
|
|
|
;source-doc/base-drv/ch376.c:193: USB_MODULE_LEDS = 0x01; |
|
|
|
ld a,0x01 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:196: ch_issue_token_in(endpoint); |
|
|
|
;source-doc/base-drv/ch376.c:195: ch_issue_token_in(endpoint); |
|
|
|
ld l,(ix+8) |
|
|
|
ld h,(ix+9) |
|
|
|
call _ch_issue_token_in |
|
|
|
;source-doc/base-drv/ch376.c:198: CHECK(ch_long_wait_int_and_get_status()); |
|
|
|
;source-doc/base-drv/ch376.c:197: CHECK(ch_long_wait_int_and_get_status()); |
|
|
|
call _ch_long_wait_int_and_get_statu |
|
|
|
ld a,l |
|
|
|
or a |
|
|
|
jr NZ,l_ch_data_in_transfer_n_00103 |
|
|
|
;source-doc/base-drv/ch376.c:200: endpoint->toggle = !endpoint->toggle; |
|
|
|
;source-doc/base-drv/ch376.c:199: endpoint->toggle = !endpoint->toggle; |
|
|
|
ld l,(ix+8) |
|
|
|
ld h,(ix+9) |
|
|
|
ld a, (hl) |
|
|
|
@ -614,33 +610,33 @@ _ch_data_in_transfer_n: |
|
|
|
and 0xfe |
|
|
|
or c |
|
|
|
ld (hl), a |
|
|
|
;source-doc/base-drv/ch376.c:202: count = ch_read_data(buffer); |
|
|
|
;source-doc/base-drv/ch376.c:201: count = ch_read_data(buffer); |
|
|
|
ld l,(ix+4) |
|
|
|
ld h,(ix+5) |
|
|
|
call _ch_read_data |
|
|
|
;source-doc/base-drv/ch376.c:204: *buffer_size = count; |
|
|
|
;source-doc/base-drv/ch376.c:203: *buffer_size = count; |
|
|
|
ld c,(ix+6) |
|
|
|
ld b,(ix+7) |
|
|
|
ld (bc), a |
|
|
|
;source-doc/base-drv/ch376.c:206: USB_MODULE_LEDS = 0x00; |
|
|
|
;source-doc/base-drv/ch376.c:205: USB_MODULE_LEDS = 0x00; |
|
|
|
ld a,0x00 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:208: return USB_ERR_OK; |
|
|
|
;source-doc/base-drv/ch376.c:207: return USB_ERR_OK; |
|
|
|
ld l,0x00 |
|
|
|
jr l_ch_data_in_transfer_n_00104 |
|
|
|
;source-doc/base-drv/ch376.c:209: done: |
|
|
|
;source-doc/base-drv/ch376.c:208: done: |
|
|
|
l_ch_data_in_transfer_n_00103: |
|
|
|
;source-doc/base-drv/ch376.c:210: USB_MODULE_LEDS = 0x00; |
|
|
|
;source-doc/base-drv/ch376.c:209: USB_MODULE_LEDS = 0x00; |
|
|
|
ld a,0x00 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:211: return result; |
|
|
|
;source-doc/base-drv/ch376.c:210: return result; |
|
|
|
l_ch_data_in_transfer_n_00104: |
|
|
|
;source-doc/base-drv/ch376.c:212: } |
|
|
|
;source-doc/base-drv/ch376.c:211: } |
|
|
|
pop ix |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:214: usb_error ch_data_out_transfer(const uint8_t *buffer, int16_t buffer_length, endpoint_param *const endpoint) { |
|
|
|
;source-doc/base-drv/ch376.c:213: usb_error ch_data_out_transfer(const uint8_t *buffer, int16_t buffer_length, endpoint_param *const endpoint) { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_data_out_transfer |
|
|
|
; --------------------------------- |
|
|
|
@ -649,7 +645,7 @@ _ch_data_out_transfer: |
|
|
|
ld ix,0 |
|
|
|
add ix,sp |
|
|
|
dec sp |
|
|
|
;source-doc/base-drv/ch376.c:217: const uint8_t max_packet_size = calc_max_packet_size(endpoint->max_packet_sizex); |
|
|
|
;source-doc/base-drv/ch376.c:216: const uint8_t max_packet_size = calc_max_packet_size(endpoint->max_packet_sizex); |
|
|
|
ld c,(ix+8) |
|
|
|
ld b,(ix+9) |
|
|
|
ld e, c |
|
|
|
@ -657,13 +653,13 @@ _ch_data_out_transfer: |
|
|
|
inc de |
|
|
|
ld a, (de) |
|
|
|
ld (ix-1),a |
|
|
|
;source-doc/base-drv/ch376.c:219: USB_MODULE_LEDS = 0x02; |
|
|
|
;source-doc/base-drv/ch376.c:218: USB_MODULE_LEDS = 0x02; |
|
|
|
ld a,0x02 |
|
|
|
push bc |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
pop bc |
|
|
|
;source-doc/base-drv/ch376.c:221: while (buffer_length > 0) { |
|
|
|
;source-doc/base-drv/ch376.c:220: while (buffer_length > 0) { |
|
|
|
l_ch_data_out_transfer_00103: |
|
|
|
xor a |
|
|
|
cp (ix+6) |
|
|
|
@ -672,7 +668,7 @@ l_ch_data_out_transfer_00103: |
|
|
|
xor 0x80 |
|
|
|
l_ch_data_out_transfer_00139: |
|
|
|
jp P, l_ch_data_out_transfer_00105 |
|
|
|
;source-doc/base-drv/ch376.c:222: const uint8_t size = max_packet_size < buffer_length ? max_packet_size : buffer_length; |
|
|
|
;source-doc/base-drv/ch376.c:221: const uint8_t size = max_packet_size < buffer_length ? max_packet_size : buffer_length; |
|
|
|
ld d,(ix-1) |
|
|
|
ld e,0x00 |
|
|
|
ld a, d |
|
|
|
@ -688,7 +684,7 @@ l_ch_data_out_transfer_00109: |
|
|
|
ld d,(ix+6) |
|
|
|
ld e,(ix+7) |
|
|
|
l_ch_data_out_transfer_00110: |
|
|
|
;source-doc/base-drv/ch376.c:223: buffer = ch_write_data(buffer, size); |
|
|
|
;source-doc/base-drv/ch376.c:222: buffer = ch_write_data(buffer, size); |
|
|
|
push bc |
|
|
|
push de |
|
|
|
push de |
|
|
|
@ -703,7 +699,7 @@ l_ch_data_out_transfer_00110: |
|
|
|
pop bc |
|
|
|
ld (ix+4),l |
|
|
|
ld (ix+5),h |
|
|
|
;source-doc/base-drv/ch376.c:224: buffer_length -= size; |
|
|
|
;source-doc/base-drv/ch376.c:223: buffer_length -= size; |
|
|
|
ld e,0x00 |
|
|
|
ld a,(ix+6) |
|
|
|
sub d |
|
|
|
@ -711,19 +707,19 @@ l_ch_data_out_transfer_00110: |
|
|
|
ld a,(ix+7) |
|
|
|
sbc a, e |
|
|
|
ld (ix+7),a |
|
|
|
;source-doc/base-drv/ch376.c:225: ch_issue_token_out(endpoint); |
|
|
|
;source-doc/base-drv/ch376.c:224: ch_issue_token_out(endpoint); |
|
|
|
ld l,c |
|
|
|
ld h,b |
|
|
|
push hl |
|
|
|
call _ch_issue_token_out |
|
|
|
;source-doc/base-drv/ch376.c:227: CHECK(ch_long_wait_int_and_get_status()); |
|
|
|
;source-doc/base-drv/ch376.c:226: CHECK(ch_long_wait_int_and_get_status()); |
|
|
|
call _ch_long_wait_int_and_get_statu |
|
|
|
ld a, l |
|
|
|
pop bc |
|
|
|
ld l, a |
|
|
|
or a |
|
|
|
jr NZ,l_ch_data_out_transfer_00106 |
|
|
|
;source-doc/base-drv/ch376.c:229: endpoint->toggle = !endpoint->toggle; |
|
|
|
;source-doc/base-drv/ch376.c:228: endpoint->toggle = !endpoint->toggle; |
|
|
|
ld e, c |
|
|
|
ld d, b |
|
|
|
ld l, e |
|
|
|
@ -739,40 +735,38 @@ l_ch_data_out_transfer_00110: |
|
|
|
ld (de), a |
|
|
|
jr l_ch_data_out_transfer_00103 |
|
|
|
l_ch_data_out_transfer_00105: |
|
|
|
;source-doc/base-drv/ch376.c:232: USB_MODULE_LEDS = 0x00; |
|
|
|
;source-doc/base-drv/ch376.c:231: USB_MODULE_LEDS = 0x00; |
|
|
|
ld a,0x00 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:233: return USB_ERR_OK; |
|
|
|
;source-doc/base-drv/ch376.c:232: return USB_ERR_OK; |
|
|
|
ld l,0x00 |
|
|
|
jr l_ch_data_out_transfer_00107 |
|
|
|
;source-doc/base-drv/ch376.c:235: done: |
|
|
|
;source-doc/base-drv/ch376.c:234: done: |
|
|
|
l_ch_data_out_transfer_00106: |
|
|
|
;source-doc/base-drv/ch376.c:236: USB_MODULE_LEDS = 0x00; |
|
|
|
;source-doc/base-drv/ch376.c:235: USB_MODULE_LEDS = 0x00; |
|
|
|
ld a,0x00 |
|
|
|
ld bc,_USB_MODULE_LEDS |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:237: return result; |
|
|
|
;source-doc/base-drv/ch376.c:236: return result; |
|
|
|
l_ch_data_out_transfer_00107: |
|
|
|
;source-doc/base-drv/ch376.c:238: } |
|
|
|
;source-doc/base-drv/ch376.c:237: } |
|
|
|
inc sp |
|
|
|
pop ix |
|
|
|
ret |
|
|
|
;source-doc/base-drv/ch376.c:240: void ch_set_usb_address(const uint8_t device_address) __z88dk_fastcall { |
|
|
|
;source-doc/base-drv/ch376.c:239: void ch_set_usb_address(const uint8_t device_address) __z88dk_fastcall { |
|
|
|
; --------------------------------- |
|
|
|
; Function ch_set_usb_address |
|
|
|
; --------------------------------- |
|
|
|
_ch_set_usb_address: |
|
|
|
;source-doc/base-drv/ch376.c:241: ch_command(CH_CMD_SET_USB_ADDR); |
|
|
|
;source-doc/base-drv/ch376.c:240: ch_command(CH_CMD_SET_USB_ADDR); |
|
|
|
push hl |
|
|
|
ld l,0x13 |
|
|
|
call _ch_command |
|
|
|
pop hl |
|
|
|
;source-doc/base-drv/ch376.c:242: CH376_DATA_PORT = device_address; |
|
|
|
;source-doc/base-drv/ch376.c:241: CH376_DATA_PORT = device_address; |
|
|
|
ld a, l |
|
|
|
ld bc,_CH376_DATA_PORT |
|
|
|
out (c), a |
|
|
|
;source-doc/base-drv/ch376.c:243: } |
|
|
|
;source-doc/base-drv/ch376.c:242: } |
|
|
|
ret |
|
|
|
_result: |
|
|
|
DEFB +0x00 |
|
|
|
|