|
|
|
@ -62,77 +62,77 @@ _report: |
|
|
|
;-------------------------------------------------------- |
|
|
|
; code |
|
|
|
;-------------------------------------------------------- |
|
|
|
;source-doc/keyboard/kyb-init.c:11: void keyboard_init(void) { |
|
|
|
;source-doc/keyboard/kyb-init.c:12: void keyboard_init(void) { |
|
|
|
; --------------------------------- |
|
|
|
; Function keyboard_init |
|
|
|
; --------------------------------- |
|
|
|
_keyboard_init: |
|
|
|
;source-doc/keyboard/kyb-init.c:13: uint8_t index = 1; |
|
|
|
;source-doc/keyboard/kyb-init.c:14: uint8_t index = 1; |
|
|
|
ld c,0x01 |
|
|
|
;source-doc/keyboard/kyb-init.c:14: keyboard_config = NULL; |
|
|
|
;source-doc/keyboard/kyb-init.c:15: keyboard_config = NULL; |
|
|
|
ld hl,0x0000 |
|
|
|
ld (_keyboard_config),hl |
|
|
|
;source-doc/keyboard/kyb-init.c:16: do { |
|
|
|
;source-doc/keyboard/kyb-init.c:17: do { |
|
|
|
ld b,0x01 |
|
|
|
l_keyboard_init_00105: |
|
|
|
;source-doc/keyboard/kyb-init.c:17: keyboard_config = (device_config_keyboard *)get_usb_device_config(index); |
|
|
|
;source-doc/keyboard/kyb-init.c:18: keyboard_config = (device_config_keyboard *)get_usb_device_config(index); |
|
|
|
push bc |
|
|
|
ld a, b |
|
|
|
call _get_usb_device_config |
|
|
|
ex de, hl |
|
|
|
pop bc |
|
|
|
ld (_keyboard_config), hl |
|
|
|
;source-doc/keyboard/kyb-init.c:19: if (keyboard_config == NULL) |
|
|
|
;source-doc/keyboard/kyb-init.c:20: if (keyboard_config == NULL) |
|
|
|
ld hl,(_keyboard_config) |
|
|
|
ld a,h |
|
|
|
or l |
|
|
|
jr Z,l_keyboard_init_00107 |
|
|
|
;source-doc/keyboard/kyb-init.c:22: const usb_device_type t = keyboard_config->type; |
|
|
|
;source-doc/keyboard/kyb-init.c:23: const usb_device_type t = keyboard_config->type; |
|
|
|
ld hl, (_keyboard_config) |
|
|
|
ld a, (hl) |
|
|
|
and 0x0f |
|
|
|
;source-doc/keyboard/kyb-init.c:24: if (t == USB_IS_KEYBOARD) { |
|
|
|
;source-doc/keyboard/kyb-init.c:25: if (t == USB_IS_KEYBOARD) { |
|
|
|
sub 0x04 |
|
|
|
jr NZ,l_keyboard_init_00106 |
|
|
|
;source-doc/keyboard/kyb-init.c:25: print_string("\r\nUSB: KEYBOARD @ $"); |
|
|
|
;source-doc/keyboard/kyb-init.c:26: print_string("\r\nUSB: KEYBOARD @ $"); |
|
|
|
push bc |
|
|
|
ld hl,kyb_init_str_0 |
|
|
|
call _print_string |
|
|
|
pop bc |
|
|
|
;source-doc/keyboard/kyb-init.c:26: print_uint16(index); |
|
|
|
;source-doc/keyboard/kyb-init.c:27: print_uint16(index); |
|
|
|
ld h,0x00 |
|
|
|
ld l, c |
|
|
|
call _print_uint16 |
|
|
|
;source-doc/keyboard/kyb-init.c:27: print_string(" $"); |
|
|
|
;source-doc/keyboard/kyb-init.c:28: print_string(" $"); |
|
|
|
ld hl,kyb_init_str_1 |
|
|
|
call _print_string |
|
|
|
;source-doc/keyboard/kyb-init.c:29: hid_set_protocol(keyboard_config, 1); |
|
|
|
;source-doc/keyboard/kyb-init.c:30: hid_set_protocol(keyboard_config, 1); |
|
|
|
ld a,0x01 |
|
|
|
push af |
|
|
|
inc sp |
|
|
|
ld hl, (_keyboard_config) |
|
|
|
call _hid_set_protocol |
|
|
|
;source-doc/keyboard/kyb-init.c:30: hid_set_idle(keyboard_config, 0x80); |
|
|
|
;source-doc/keyboard/kyb-init.c:31: hid_set_idle(keyboard_config, 0x80); |
|
|
|
ld a,0x80 |
|
|
|
push af |
|
|
|
inc sp |
|
|
|
ld hl, (_keyboard_config) |
|
|
|
call _hid_set_idle |
|
|
|
;source-doc/keyboard/kyb-init.c:31: return; |
|
|
|
;source-doc/keyboard/kyb-init.c:32: return; |
|
|
|
jr l_keyboard_init_00108 |
|
|
|
l_keyboard_init_00106: |
|
|
|
;source-doc/keyboard/kyb-init.c:33: } while (++index != MAX_NUMBER_OF_DEVICES + 1); |
|
|
|
;source-doc/keyboard/kyb-init.c:34: } while (++index != MAX_NUMBER_OF_DEVICES + 1); |
|
|
|
inc b |
|
|
|
ld a,b |
|
|
|
ld c,b |
|
|
|
sub 0x07 |
|
|
|
jr NZ,l_keyboard_init_00105 |
|
|
|
l_keyboard_init_00107: |
|
|
|
;source-doc/keyboard/kyb-init.c:35: print_string("\r\nUSB: KEYBOARD: NOT FOUND$"); |
|
|
|
;source-doc/keyboard/kyb-init.c:36: print_string("\r\nUSB: KEYBOARD: NOT FOUND$"); |
|
|
|
ld hl,kyb_init_str_2 |
|
|
|
jp _print_string |
|
|
|
l_keyboard_init_00108: |
|
|
|
;source-doc/keyboard/kyb-init.c:36: } |
|
|
|
;source-doc/keyboard/kyb-init.c:37: } |
|
|
|
ret |
|
|
|
kyb_init_str_0: |
|
|
|
DEFB 0x0d |
|
|
|
@ -147,7 +147,7 @@ kyb_init_str_2: |
|
|
|
DEFB 0x0a |
|
|
|
DEFM "USB: KEYBOARD: NOT FOUND$" |
|
|
|
DEFB 0x00 |
|
|
|
;source-doc/keyboard/kyb-init.c:49: |
|
|
|
;source-doc/keyboard/kyb-init.c:50: |
|
|
|
; --------------------------------- |
|
|
|
; Function keyboard_buf_put |
|
|
|
; --------------------------------- |
|
|
|
@ -155,42 +155,42 @@ _keyboard_buf_put: |
|
|
|
push ix |
|
|
|
ld ix,0 |
|
|
|
add ix,sp |
|
|
|
;source-doc/keyboard/kyb-init.c:50: void keyboard_buf_put(const uint8_t modifier_keys, const uint8_t key_code) { |
|
|
|
;source-doc/keyboard/kyb-init.c:51: void keyboard_buf_put(const uint8_t modifier_keys, const uint8_t key_code) { |
|
|
|
ld a,(ix+5) |
|
|
|
sub 0x80 |
|
|
|
jr NC,l_keyboard_buf_put_00112 |
|
|
|
ld a,(ix+5) |
|
|
|
or a |
|
|
|
;source-doc/keyboard/kyb-init.c:51: if (key_code >= 0x80 || key_code == 0) |
|
|
|
;source-doc/keyboard/kyb-init.c:54: // if already reported, just skip it |
|
|
|
;source-doc/keyboard/kyb-init.c:52: if (key_code >= 0x80 || key_code == 0) |
|
|
|
;source-doc/keyboard/kyb-init.c:55: // if already reported, just skip it |
|
|
|
jr Z,l_keyboard_buf_put_00112 |
|
|
|
ld c,0x00 |
|
|
|
l_keyboard_buf_put_00110: |
|
|
|
ld a, c |
|
|
|
sub 0x06 |
|
|
|
jr NC,l_keyboard_buf_put_00106 |
|
|
|
;source-doc/keyboard/kyb-init.c:55: for (uint8_t i = 0; i < 6; i++) |
|
|
|
;source-doc/keyboard/kyb-init.c:56: for (uint8_t i = 0; i < 6; i++) |
|
|
|
ld b,0x00 |
|
|
|
ld hl,_previous_keyCodes |
|
|
|
add hl, bc |
|
|
|
ld a,(ix+5) |
|
|
|
sub (hl) |
|
|
|
;source-doc/keyboard/kyb-init.c:56: if (previous_keyCodes[i] == key_code) |
|
|
|
;source-doc/keyboard/kyb-init.c:57: if (previous_keyCodes[i] == key_code) |
|
|
|
jr Z,l_keyboard_buf_put_00112 |
|
|
|
;source-doc/keyboard/kyb-init.c:54: // if already reported, just skip it |
|
|
|
;source-doc/keyboard/kyb-init.c:55: // if already reported, just skip it |
|
|
|
inc c |
|
|
|
jr l_keyboard_buf_put_00110 |
|
|
|
l_keyboard_buf_put_00106: |
|
|
|
;source-doc/keyboard/kyb-init.c:58: |
|
|
|
;source-doc/keyboard/kyb-init.c:59: |
|
|
|
ld a,(_write_index) |
|
|
|
inc a |
|
|
|
and 0x07 |
|
|
|
ld c, a |
|
|
|
;source-doc/keyboard/kyb-init.c:59: uint8_t next_write_index = (write_index + 1) & KEYBOARD_BUFFER_SIZE_MASK; |
|
|
|
;source-doc/keyboard/kyb-init.c:60: uint8_t next_write_index = (write_index + 1) & KEYBOARD_BUFFER_SIZE_MASK; |
|
|
|
ld a,(_read_index) |
|
|
|
sub c |
|
|
|
jr Z,l_keyboard_buf_put_00112 |
|
|
|
;source-doc/keyboard/kyb-init.c:60: if (next_write_index != read_index) { // Check if buffer is not full |
|
|
|
;source-doc/keyboard/kyb-init.c:61: if (next_write_index != read_index) { // Check if buffer is not full |
|
|
|
ld de,_buffer+0 |
|
|
|
ld hl,(_write_index) |
|
|
|
ld h,0x00 |
|
|
|
@ -198,7 +198,7 @@ l_keyboard_buf_put_00106: |
|
|
|
add hl, de |
|
|
|
ld a,(ix+4) |
|
|
|
ld (hl), a |
|
|
|
;source-doc/keyboard/kyb-init.c:61: buffer[write_index].modifier_keys = modifier_keys; |
|
|
|
;source-doc/keyboard/kyb-init.c:62: buffer[write_index].modifier_keys = modifier_keys; |
|
|
|
ld hl,(_write_index) |
|
|
|
ld h,0x00 |
|
|
|
add hl, hl |
|
|
|
@ -207,30 +207,30 @@ l_keyboard_buf_put_00106: |
|
|
|
inc de |
|
|
|
ld a,(ix+5) |
|
|
|
ld (de), a |
|
|
|
;source-doc/keyboard/kyb-init.c:62: buffer[write_index].key_code = key_code; |
|
|
|
;source-doc/keyboard/kyb-init.c:63: buffer[write_index].key_code = key_code; |
|
|
|
ld hl,_write_index |
|
|
|
ld (hl), c |
|
|
|
l_keyboard_buf_put_00112: |
|
|
|
;source-doc/keyboard/kyb-init.c:64: } |
|
|
|
;source-doc/keyboard/kyb-init.c:65: } |
|
|
|
pop ix |
|
|
|
ret |
|
|
|
;source-doc/keyboard/kyb-init.c:66: |
|
|
|
;source-doc/keyboard/kyb-init.c:67: |
|
|
|
; --------------------------------- |
|
|
|
; Function keyboard_buf_size |
|
|
|
; --------------------------------- |
|
|
|
_keyboard_buf_size: |
|
|
|
;source-doc/keyboard/kyb-init.c:67: uint8_t keyboard_buf_size() __sdcccall(1) { |
|
|
|
;source-doc/keyboard/kyb-init.c:68: uint8_t keyboard_buf_size() __sdcccall(1) { |
|
|
|
ld a,(_write_index) |
|
|
|
ld hl,_read_index |
|
|
|
sub (hl) |
|
|
|
jr C,l_keyboard_buf_size_00102 |
|
|
|
;source-doc/keyboard/kyb-init.c:68: if (write_index >= read_index) |
|
|
|
;source-doc/keyboard/kyb-init.c:69: if (write_index >= read_index) |
|
|
|
ld a,(_write_index) |
|
|
|
ld hl,_read_index |
|
|
|
sub (hl) |
|
|
|
jr l_keyboard_buf_size_00103 |
|
|
|
l_keyboard_buf_size_00102: |
|
|
|
;source-doc/keyboard/kyb-init.c:70: |
|
|
|
;source-doc/keyboard/kyb-init.c:71: |
|
|
|
ld hl,_read_index |
|
|
|
ld c, (hl) |
|
|
|
ld a,0x08 |
|
|
|
@ -239,9 +239,9 @@ l_keyboard_buf_size_00102: |
|
|
|
ld c, (hl) |
|
|
|
add a, c |
|
|
|
l_keyboard_buf_size_00103: |
|
|
|
;source-doc/keyboard/kyb-init.c:71: return KEYBOARD_BUFFER_SIZE - read_index + write_index; |
|
|
|
;source-doc/keyboard/kyb-init.c:72: return KEYBOARD_BUFFER_SIZE - read_index + write_index; |
|
|
|
ret |
|
|
|
;source-doc/keyboard/kyb-init.c:73: |
|
|
|
;source-doc/keyboard/kyb-init.c:74: |
|
|
|
; --------------------------------- |
|
|
|
; Function keyboard_buf_get_next |
|
|
|
; --------------------------------- |
|
|
|
@ -251,41 +251,54 @@ _keyboard_buf_get_next: |
|
|
|
add ix,sp |
|
|
|
push af |
|
|
|
push af |
|
|
|
;source-doc/keyboard/kyb-init.c:74: uint32_t keyboard_buf_get_next() { |
|
|
|
;source-doc/keyboard/kyb-init.c:75: uint32_t keyboard_buf_get_next() { |
|
|
|
ld a,(_write_index) |
|
|
|
ld hl,_read_index |
|
|
|
sub (hl) |
|
|
|
jr NZ,l_keyboard_buf_get_next_00102 |
|
|
|
;source-doc/keyboard/kyb-init.c:75: if (write_index == read_index) // Check if buffer is empty |
|
|
|
;source-doc/keyboard/kyb-init.c:76: if (write_index == read_index) // Check if buffer is empty |
|
|
|
ld hl,0xff00 |
|
|
|
ld e, h |
|
|
|
ld d, h |
|
|
|
jr l_keyboard_buf_get_next_00103 |
|
|
|
jr l_keyboard_buf_get_next_00105 |
|
|
|
l_keyboard_buf_get_next_00102: |
|
|
|
;source-doc/keyboard/kyb-init.c:77: |
|
|
|
;source-doc/keyboard/kyb-init.c:78: |
|
|
|
ld bc,_buffer+0 |
|
|
|
ld hl,(_read_index) |
|
|
|
ld h,0x00 |
|
|
|
add hl, hl |
|
|
|
add hl, bc |
|
|
|
ld b, (hl) |
|
|
|
;source-doc/keyboard/kyb-init.c:78: const uint8_t modifier_key = buffer[read_index].modifier_keys; |
|
|
|
;source-doc/keyboard/kyb-init.c:79: const uint8_t modifier_key = buffer[read_index].modifier_keys; |
|
|
|
inc hl |
|
|
|
ld c, (hl) |
|
|
|
;source-doc/keyboard/kyb-init.c:79: const uint8_t key_code = buffer[read_index].key_code; |
|
|
|
;source-doc/keyboard/kyb-init.c:80: const uint8_t key_code = buffer[read_index].key_code; |
|
|
|
ld hl,_read_index |
|
|
|
ld a, (hl) |
|
|
|
inc a |
|
|
|
and 0x07 |
|
|
|
ld (hl), a |
|
|
|
;source-doc/keyboard/kyb-init.c:80: read_index = (read_index + 1) & KEYBOARD_BUFFER_SIZE_MASK; |
|
|
|
;source-doc/keyboard/kyb-init.c:82: |
|
|
|
ld a, c |
|
|
|
sub 0x39 |
|
|
|
jr NZ,l_keyboard_buf_get_next_00104 |
|
|
|
;source-doc/keyboard/kyb-init.c:83: if (key_code == KEY_CODE_CAPS_LOCK) { |
|
|
|
ld hl,_caps_lock_engaged |
|
|
|
ld a, (hl) |
|
|
|
xor 0x01 |
|
|
|
ld (hl), a |
|
|
|
;source-doc/keyboard/kyb-init.c:84: caps_lock_engaged = !caps_lock_engaged; |
|
|
|
call _keyboard_buf_get_next |
|
|
|
jr l_keyboard_buf_get_next_00105 |
|
|
|
l_keyboard_buf_get_next_00104: |
|
|
|
;source-doc/keyboard/kyb-init.c:87: |
|
|
|
push bc |
|
|
|
ld l, c |
|
|
|
ld a, b |
|
|
|
call _scancode_to_char |
|
|
|
ld e, a |
|
|
|
pop bc |
|
|
|
;source-doc/keyboard/kyb-init.c:82: /* D = modifier, e-> char, H = 0, L=>code */ |
|
|
|
;source-doc/keyboard/kyb-init.c:89: /* D = modifier, e-> char, H = 0, L=>code */ |
|
|
|
xor a |
|
|
|
ld (ix-1),b |
|
|
|
xor a |
|
|
|
@ -301,34 +314,34 @@ l_keyboard_buf_get_next_00102: |
|
|
|
ld (ix-1),a |
|
|
|
pop hl |
|
|
|
push hl |
|
|
|
l_keyboard_buf_get_next_00103: |
|
|
|
;source-doc/keyboard/kyb-init.c:83: return (uint32_t)modifier_key << 24 | (uint32_t)c << 16 | key_code; |
|
|
|
l_keyboard_buf_get_next_00105: |
|
|
|
;source-doc/keyboard/kyb-init.c:90: return (uint32_t)modifier_key << 24 | (uint32_t)c << 16 | key_code; |
|
|
|
ld sp, ix |
|
|
|
pop ix |
|
|
|
ret |
|
|
|
;source-doc/keyboard/kyb-init.c:85: |
|
|
|
;source-doc/keyboard/kyb-init.c:92: |
|
|
|
; --------------------------------- |
|
|
|
; Function keyboard_buf_flush |
|
|
|
; --------------------------------- |
|
|
|
_keyboard_buf_flush: |
|
|
|
;source-doc/keyboard/kyb-init.c:86: void keyboard_buf_flush() { |
|
|
|
;source-doc/keyboard/kyb-init.c:93: void keyboard_buf_flush() { |
|
|
|
ld hl,_write_index |
|
|
|
ld (hl),0x00 |
|
|
|
;source-doc/keyboard/kyb-init.c:87: write_index = 0; |
|
|
|
;source-doc/keyboard/kyb-init.c:94: write_index = 0; |
|
|
|
ld hl,_read_index |
|
|
|
ld (hl),0x00 |
|
|
|
;source-doc/keyboard/kyb-init.c:88: read_index = 0; |
|
|
|
;source-doc/keyboard/kyb-init.c:95: read_index = 0; |
|
|
|
ret |
|
|
|
;source-doc/keyboard/kyb-init.c:94: |
|
|
|
;source-doc/keyboard/kyb-init.c:101: |
|
|
|
; --------------------------------- |
|
|
|
; Function keyboard_tick |
|
|
|
; --------------------------------- |
|
|
|
_keyboard_tick: |
|
|
|
;source-doc/keyboard/kyb-init.c:95: void keyboard_tick(void) { |
|
|
|
;source-doc/keyboard/kyb-init.c:102: void keyboard_tick(void) { |
|
|
|
ld hl,_in_critical_usb_section |
|
|
|
ld a, (hl) |
|
|
|
or a |
|
|
|
;source-doc/keyboard/kyb-init.c:96: if (is_in_critical_section()) |
|
|
|
;source-doc/keyboard/kyb-init.c:103: if (is_in_critical_section()) |
|
|
|
jr NZ,l_keyboard_tick_00111 |
|
|
|
;././source-doc/base-drv//ch376.h:110: #endif |
|
|
|
ld l,0x0b |
|
|
|
@ -341,7 +354,7 @@ _keyboard_tick: |
|
|
|
ld a,0x1f |
|
|
|
ld bc,_CH376_DATA_PORT |
|
|
|
out (c),a |
|
|
|
;source-doc/keyboard/kyb-init.c:99: ch_configure_nak_retry_disable(); |
|
|
|
;source-doc/keyboard/kyb-init.c:106: ch_configure_nak_retry_disable(); |
|
|
|
ld bc,_report+0 |
|
|
|
ld hl, (_keyboard_config) |
|
|
|
ld a,0x08 |
|
|
|
@ -366,10 +379,10 @@ _keyboard_tick: |
|
|
|
ld a,0xdf |
|
|
|
ld bc,_CH376_DATA_PORT |
|
|
|
out (c),a |
|
|
|
;source-doc/keyboard/kyb-init.c:101: ch_configure_nak_retry_3s(); |
|
|
|
;source-doc/keyboard/kyb-init.c:108: ch_configure_nak_retry_3s(); |
|
|
|
ld hl,_result |
|
|
|
ld a, (hl) |
|
|
|
;source-doc/keyboard/kyb-init.c:102: if (result == 0) |
|
|
|
;source-doc/keyboard/kyb-init.c:109: if (result == 0) |
|
|
|
or a |
|
|
|
jr NZ,l_keyboard_tick_00111 |
|
|
|
ld c,a |
|
|
|
@ -377,7 +390,7 @@ l_keyboard_tick_00109: |
|
|
|
ld a, c |
|
|
|
sub 0x06 |
|
|
|
ret NC |
|
|
|
;source-doc/keyboard/kyb-init.c:103: for (uint8_t i = 0; i < 6; i++) { |
|
|
|
;source-doc/keyboard/kyb-init.c:110: for (uint8_t i = 0; i < 6; i++) { |
|
|
|
ld a,+((_report+2) & 0xFF) |
|
|
|
add a, c |
|
|
|
ld e, a |
|
|
|
@ -396,17 +409,17 @@ l_keyboard_tick_00109: |
|
|
|
pop af |
|
|
|
pop de |
|
|
|
pop bc |
|
|
|
;source-doc/keyboard/kyb-init.c:104: keyboard_buf_put(report.bModifierKeys, report.keyCode[i]); |
|
|
|
;source-doc/keyboard/kyb-init.c:111: keyboard_buf_put(report.bModifierKeys, report.keyCode[i]); |
|
|
|
ld b,0x00 |
|
|
|
ld hl,_previous_keyCodes |
|
|
|
add hl, bc |
|
|
|
ld a, (de) |
|
|
|
ld (hl), a |
|
|
|
;source-doc/keyboard/kyb-init.c:102: if (result == 0) |
|
|
|
;source-doc/keyboard/kyb-init.c:109: if (result == 0) |
|
|
|
inc c |
|
|
|
jr l_keyboard_tick_00109 |
|
|
|
l_keyboard_tick_00111: |
|
|
|
;source-doc/keyboard/kyb-init.c:106: } |
|
|
|
;source-doc/keyboard/kyb-init.c:113: } |
|
|
|
ret |
|
|
|
_keyboard_config: |
|
|
|
DEFW +0x0000 |
|
|
|
|