Minix 3 在 /drivers/tty/keymaps/ 文件夾下不同的 *.src 文件中定義了 u16_t keymap[NR_SCAN_CODES * MAP_COLS] 數組,
保存了不同的鍵盤中 鍵盤掃描碼加修飾鍵 到 ASCII碼 的映射。
如 us-std.src 中的 keymap 是針對 US MF-2 鍵盤的,japanese.src 中的 keymap 是針對 Japanese 106 鍵盤的。
文件 /drivers/tty/keyboard.c 中,
鍵盤輸入緩存為環形,其定義如下,
#define KB_IN_BYTES 32 /* size of keyboard input buffer */
PRIVATE char ibuf[KB_IN_BYTES]; /* input buffer */
PRIVATE char *ihead = ibuf; /* next free spot in input buffer */
PRIVATE char *itail = ibuf; /* scan code to return to TTY */
PRIVATE int icount; /* # codes in buffer */
還定義了一些IO端口號和跟蹤修飾狀態的變量。
宏 map_key0 可視為函數,使用 keymap ,忽略修飾鍵,將掃描碼映射為 ASCII 碼。
函數map_key() 使用 keymap 進行掃描碼到ASCII碼的完全映射,包括處理和普通字符同時按下的(多重)修飾鍵。
kbd_interrupt() 為鍵盤中斷例程,當一個鍵被按下或釋放時被調用。它調用 scan_keyboard() 獲得按鍵掃描碼,
并將此掃描碼插入鍵盤輸入緩存中。
kb_read() 從鍵盤輸入緩存中取出掃描碼,并把ASCII碼放在它的局部緩沖區中,
緩沖區應足夠大以保存來自數字鍵盤的某些掃描碼產生的轉義序列。
然后它調用硬件無關代碼中的in_process把字符放入輸入隊列。對make_break的調用以整數形式返回ASCII碼。
在HOME和INSRT之間的掃描碼由按下數字鍵盤產生,并且通過numpad_map數組被轉換為三字符轉義序列。
這些序列接著被傳送到in_process中。
更高的掃描碼不傳給in_process,但要檢測ALT-LEFT-ARROW,ALT-RIGHT-ARROW和ALT-F1到ALT-F12這些掃描碼,
并且如果發現其中之一,就調用select_console切換虛擬控制臺。
kb_read() 會持續處理直至鍵盤輸入緩存為空。
make_break() 把掃描碼轉換為ASCII碼然后更新跟蹤修飾鍵狀態的變量。
set_leds() 打開或關閉鍵盤上的 Num Lock,Caps Lock,Scroll Lock 指示燈。
func_key() 被 kb_read() 調用以判斷是否按下了意味著局部處理的特殊鍵。
scan_keyboard() 在硬件接口層工作,從IO端口讀寫字節。