root / lab3 / kbc_func.h @ 344
History | View | Annotate | Download (3.52 KB)
1 | 30 | up20180655 | #ifndef _KBC_FUNC_H_
|
---|---|---|---|
2 | #define _KBC_FUNC_H_
|
||
3 | |||
4 | #include <stdint.h> |
||
5 | |||
6 | #define GET 0 /* @brief Argument to get counter without incrementing */ |
||
7 | #define INCREMENT 1 /* @brief Argument for incrementing counter */ |
||
8 | |||
9 | /**
|
||
10 | * @brief Subscribes KBC Interrupts and disables Minix Default Keyboard IH
|
||
11 | * @param interrupt_bit Bit of Interrupt Vector that will be set when KBC Interrupt is pending
|
||
12 | * @param interrupt_id KBC Interrupt ID to specify the KBC Interrupt in other calls
|
||
13 | 265 | up20180655 | * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
|
14 | * @see {_ERRORS_H_::errors}
|
||
15 | 30 | up20180655 | */
|
16 | int (subscribe_kbc_interrupt)(uint8_t interrupt_bit, int *interrupt_id); |
||
17 | |||
18 | /**
|
||
19 | 265 | up20180655 | * @brief Subscribes Mouse Interrupts and disables Minix Default IH
|
20 | * @param interrupt_bit Bit of Interrupt Vector that will be set when Mouse Interrupt is pending
|
||
21 | * @param interrupt_id Mouse Interrupt ID to specify the Mouse Interrupt in other calls
|
||
22 | * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
|
||
23 | * @see {_ERRORS_H_::errors}
|
||
24 | */
|
||
25 | int (subscribe_mouse_interrupt)(uint8_t interrupt_bit, int *interrupt_id); |
||
26 | |||
27 | /**
|
||
28 | 44 | up20180642 | * @brief Unsubcribes Interrupts
|
29 | * @param interrupt_id Interrupt ID, value via arguments on subscription of the interrupt_id
|
||
30 | * @see subscribe_kbc_interrupt, subscribe_timer_interrupt
|
||
31 | 30 | up20180655 | * @return Whether operation was sucessful or not
|
32 | */
|
||
33 | 44 | up20180642 | int (unsubscribe_interrupt)(int *interrupt_id); |
34 | 30 | up20180655 | |
35 | /**
|
||
36 | * @brief KBC Interrupt Handler
|
||
37 | */
|
||
38 | void (kbc_ih)(void); |
||
39 | |||
40 | /**
|
||
41 | 36 | up20180642 | * @brief High-level function that polls keyboard for scancode
|
42 | * High-level function that polls keyboard for scancode of up to 2 bytes. If
|
||
43 | * scancode has only 1 byte, the second byte is set to 0x00.
|
||
44 | * @param bytes Array of at least 2 bytes to store scancode
|
||
45 | * @param size Size of scancode in bytes
|
||
46 | * @return 0 if operation was successful, 1 otherwise
|
||
47 | */
|
||
48 | int (kbd_poll)(uint8_t bytes[], uint8_t *size);
|
||
49 | |||
50 | 39 | up20180642 | /**
|
51 | * @brief High-level function that reads the command byte of the KBC
|
||
52 | * @param cmd Pointer to variable where command byte read from KBC will be stored
|
||
53 | * @return 0 if operation was successful, 1 otherwise
|
||
54 | */
|
||
55 | int (kbc_read_cmd)(uint8_t *cmd);
|
||
56 | 38 | up20180642 | |
57 | 36 | up20180642 | /**
|
58 | 39 | up20180642 | * @brief High-level function that changes the command byte of the KBC
|
59 | * @param cmd New value for command byte of KBC
|
||
60 | * @return 0 if operation was successful, 1 otherwise
|
||
61 | */
|
||
62 | int (kbc_change_cmd)(uint8_t cmd);
|
||
63 | |||
64 | /**
|
||
65 | 43 | up20180642 | * @brief High-level function that restores KBC to normal state
|
66 | * High-level function that restores KBC to normal state, because lcf_start
|
||
67 | * changes the command byte of KBC. If this function is not used, there is a
|
||
68 | * chance that the keyboard and keyboard interrupts remain disabled.
|
||
69 | * @return 1 if operation was successful, 1 otherwise
|
||
70 | */
|
||
71 | int (kbc_restore_kbd)();
|
||
72 | |||
73 | /**
|
||
74 | 39 | up20180642 | * @brief Low-level function to issue a command to keyboard
|
75 | * @param cmd command to be issued
|
||
76 | * @return 0 if operation was successful, 1 otherwise
|
||
77 | */
|
||
78 | int (kbc_issue_cmd)(uint8_t cmd);
|
||
79 | |||
80 | /**
|
||
81 | 50 | up20180655 | * @brief Low-level function to issue an argument of a command
|
82 | * @param cmd argument to be issued
|
||
83 | * @return 0 if operation was successful, 1 otherwise
|
||
84 | */
|
||
85 | int (kbc_issue_arg)(uint8_t arg);
|
||
86 | |||
87 | /**
|
||
88 | 36 | up20180642 | * @brief Low-level function for reading byte from keyboard
|
89 | * Low-level function for reading byte from keyboard. Waits until output buffer
|
||
90 | * is full
|
||
91 | * @param value Pointer to variable where byte read from keyboard will be stored
|
||
92 | * @return 0 if operation was successful, 1 otherwise
|
||
93 | */
|
||
94 | 39 | up20180642 | int (kbc_read_byte)(uint8_t *byte);
|
95 | 36 | up20180642 | |
96 | 38 | up20180642 | |
97 | 30 | up20180655 | #endif |