Project

General

Profile

Statistics
| Revision:

root / lab4 / mouse.h @ 79

History | View | Annotate | Download (2.2 KB)

1 68 up20180642
#ifndef MOUSE_H_INCLUDED
2
#define MOUSE_H_INCLUDED
3 53 up20180655
4 58 up20180642
#include <stdint.h>
5 53 up20180655
6 58 up20180642
/**
7
 * @brief Subscribes Mouse Interrupts and disables Minix Default IH
8
 * @param interrupt_bit Bit of Interrupt Vector that will be set when Mouse Interrupt is pending
9
 * @param interrupt_id Mouse Interrupt ID to specify the Mouse Interrupt in other calls
10
 * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
11
 * @see {_ERRORS_H_::errors}
12
 */
13
int (subscribe_mouse_interrupt)(uint8_t interrupt_bit, int *interrupt_id);
14 53 up20180655
15 58 up20180642
struct packet (mouse_parse_packet)(const uint8_t *packet_bytes);
16 53 up20180655
17 58 up20180642
int (mouse_set_data_report)(int on);
18
19 70 up20180655
/**
20
 * @brief Reads data byte from mouse
21
 * <summary>
22
 * Polls the mouse till data is available for reading
23
 * </summary>
24
 * @param data Pointer to variable where byte read from mouse will be stored
25
 * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
26
 * @see {_ERRORS_H_::errors}
27
 */
28
int (mouse_read_data)(uint8_t *data);
29
30
/**
31
 * @brief Issues command to mouse
32
 * <summary>
33
 * Issues command to mouse, returns error after two consecutive errors reported by the acknowledgment byte
34
 * </summary>
35
 * @param cmd Command to be issued
36
 * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
37
 * @see {_ERRORS_H_::errors}
38
 */
39
int (mouse_issue_cmd)(uint32_t cmd);
40
41
/**
42
 * @brief Reads byte from mouse
43
 * <summary>
44
 * Reads byte from mouse, giving error if exceeds number of tries to read
45 71 up20180655
 * </summary>
46 70 up20180655
 * @param byte Pointer to variable where byte read from mouse will be stored
47
 * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
48
 * @see {_ERRORS_H_::errors}
49
 */
50
int (mouse_read_byte)(uint8_t *byte);
51
52 77 up20180642
int (mouse_read_ack)(uint8_t *byte);
53
54 71 up20180655
/**
55
 * @brief Converts 9-bit number to 16-bit with sign extension
56
 * @param sign_bit  Sign bit identifiying the signal of the number
57
 * @param byte      Least significant byte that will be extended
58
 * @return Extended 9-bit number
59
 */
60
int16_t (sign_extend_byte)(uint8_t sign_bit, uint8_t byte);
61
62 68 up20180642
#endif //MOUSE_H_INCLUDED