Project

General

Profile

Statistics
| Revision:

root / lab4 / kbc.h @ 51

History | View | Annotate | Download (2.39 KB)

1 51 up20180655
#ifndef _KBC_H_
2
#define _KBC_H_
3
4
/* KBC IRQ Line */
5
6
#define KBC_IRQ     1 /* @brief KBC Controller IRQ Line */
7
8
/* Delay for KBC */
9
#define DELAY           20000 /* @brief KBC Response Delay */
10
#define KBC_NUM_TRIES   10    /* @brief Number of tries to issue command before timeout */
11
12
/* I/O Ports Addresses */
13
14
#define KBC_CMD     0x64 /* @brief Address to send commands to KBC */
15
#define KBC_CMD_ARG 0x60 /* @brief Address to write KBC Command Arguments */
16
#define STATUS_REG  0x64 /* @brief KBC Status Register address */
17
18
#define OUTPUT_BUF  0x60 /* @brief Address of Output Buffer of KBC */
19
20
/* KBC Commands */
21
#define READ_KBC_CMD    0x20 /* @brief Read KBC Command Byte */
22
#define WRITE_KBC_CMD   0x60 /* @brief Write KBC Command Byte */
23
#define KBC_SELF_TEST   0xAA /* @brief KBC Diagnostic Tests */
24
#define KBC_INT_TEST    0xAB /* @brief Tests Keyboard Clock and Data lines */
25
#define KBC_INT_DISABLE 0xAD /* @brief Disable KBC Interface */
26
#define KBC_INT_ENABLE  0xAE /* @brief Enable KBC Interface */
27
#define MOUSE_DISABLE   0xA7 /* @brief Disable Mouse */
28
#define MOUSE_ENABLE    0xA8 /* @brief Enable Mouse */
29
#define MOUSE_INT_TEST  0xA9 /* @brief Tests Mouse data line */
30
#define MOUSE_WRITE_B   0xD4 /* @brief Write a byte directly to the mouse */
31
32
/* Status Byte Masking */
33
34
#define OUT_BUF_FUL     BIT(0) /* @brief Output Buffer State */
35
#define IN_BUF_FULL     BIT(1) /* @brief Input Buffer State */
36
#define SYS_FLAG        BIT(2) /* @brief System Flag */
37
#define DATA_CMD_WRITE  BIT(3) /* @brief Identifier of type of byte in input buffer */
38
#define INH_FLAG        BIT(4) /* @brief Keyboard inihibited */
39
#define AUX_MOUSE       BIT(5) /* @brief Mouse Data */
40
#define TIME_OUT_REC    BIT(6) /* @brief Time Out Error - Invalid Data */
41
#define PARITY_ERROR    BIT(7) /* @brief Parity Error - Invalid Data */
42
43
/* Scancode Constants */
44
45
#define ESC_BREAK_CODE  0x81    /* @brief ESC Break Code */
46
#define TWO_BYTE_CODE   0xE0    /* @brief First byte of a two byte Scancode */
47
#define BREAK_CODE_BIT  BIT(7)  /* @brief Bit to distinguish between Make code and Break code */
48
49
/* Command byte masks */
50
#define INT_KBD         BIT(0)  /* @brief Enable Keyboard Interrupts */
51
#define INT_MOU         BIT(1)  /* @brief Enable Mouse Interrupts */
52
#define DIS_KBD         BIT(4)  /* @brief Disable Keyboard */
53
#define DIS_MOU         BIT(5)  /* @brief Disable Mouse */
54
55
#endif