root / proj / src / libs / utils / include / utils.h @ 384
History | View | Annotate | Download (2.72 KB)
1 | 144 | up20180655 | #ifndef UTILS_H_INCLUDED
|
---|---|---|---|
2 | #define UTILS_H_INCLUDED
|
||
3 | |||
4 | 334 | up20180642 | /**
|
5 | * @defgroup utils utils
|
||
6 | 351 | up20180642 | * @ingroup libs
|
7 | 334 | up20180642 | * @brief Utilities module.
|
8 | *
|
||
9 | * @{
|
||
10 | */
|
||
11 | 234 | up20180655 | |
12 | 334 | up20180642 | /** @brief Get first digit (leftmost digit) of 8-bit BCD */
|
13 | #define BCD_FIRST(n) (n >> 4) |
||
14 | /** @brief Get second digit (rightmost digit) of 8-bit BCD */
|
||
15 | #define BCD_SECOND(n) (n & 0x0F) |
||
16 | |||
17 | 144 | up20180655 | /**
|
18 | * @brief Gets the least significant byte of a 16-bit variable
|
||
19 | * @param val 16-bit variable
|
||
20 | * @param lsb Pointer to a 8-bit variable to store the value of the LSB
|
||
21 | * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
|
||
22 | */
|
||
23 | int(util_get_LSB)(uint16_t val, uint8_t *lsb);
|
||
24 | |||
25 | /**
|
||
26 | * @brief Gets the most significant byte of a 16-bit variable
|
||
27 | * @param val 16-bit variable
|
||
28 | 323 | up20180642 | * @param msb Pointer to a 8-bit variable to store the value of the MSB
|
29 | 144 | up20180655 | * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
|
30 | */
|
||
31 | int(util_get_MSB)(uint16_t val, uint8_t *msb);
|
||
32 | |||
33 | /**
|
||
34 | * @brief sys_inb wrapper
|
||
35 | * @param port Port to read from
|
||
36 | * @param value Pointer to byte to store value read
|
||
37 | * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
|
||
38 | */
|
||
39 | int (util_sys_inb)(int port, uint8_t *value); |
||
40 | |||
41 | /**
|
||
42 | 145 | up20180655 | * @brief Unsubcribes Interrupts
|
43 | * @param interrupt_id Interrupt ID, value via arguments on subscription of the interrupt_id
|
||
44 | * @see subscribe_kbc_interrupt, subscribe_timer_interrupt
|
||
45 | * @return ERROR_CODE code representing the result of the operation, SUCCESS code is returned if everything is OK
|
||
46 | */
|
||
47 | int (unsubscribe_interrupt)(int *interrupt_id); |
||
48 | |||
49 | /**
|
||
50 | 144 | up20180655 | * @brief Gets the minimum value out of two values.
|
51 | * @param a First value
|
||
52 | * @param b Second value
|
||
53 | * @return The minimum of the two values
|
||
54 | */
|
||
55 | 335 | up20180642 | int16_t min_16(int16_t a, int16_t b); |
56 | /// @overload
|
||
57 | uint16_t min_u16(uint16_t a, uint16_t b); |
||
58 | /// @overload
|
||
59 | int32_t min_32(int32_t a, int32_t b); |
||
60 | /// @overload
|
||
61 | double min_d(double a, double b); |
||
62 | 144 | up20180655 | |
63 | /**
|
||
64 | * @brief Gets the maximum value out of two values.
|
||
65 | * @param a First value
|
||
66 | * @param b Second value
|
||
67 | * @return The maximum of the two values
|
||
68 | */
|
||
69 | 335 | up20180642 | int16_t max_16(int16_t a, int16_t b); |
70 | /// @overload
|
||
71 | uint16_t max_u16(uint16_t a, uint16_t b); |
||
72 | /// @overload
|
||
73 | int32_t max_32(int32_t a, int32_t b); |
||
74 | /// @overload
|
||
75 | double max_d(double a, double b); |
||
76 | 144 | up20180655 | |
77 | 334 | up20180642 | /**
|
78 | * @brief Get the absolute value of a double.
|
||
79 | * @param a Argument
|
||
80 | * @return Absolute value of a
|
||
81 | */
|
||
82 | 335 | up20180642 | double abs_d(double a); |
83 | 144 | up20180655 | |
84 | 334 | up20180642 | /**
|
85 | * @brief Compare if two doubles are approximately equal (within 1e-10).
|
||
86 | * @param a First value
|
||
87 | * @param b Second value
|
||
88 | * @return true if the two numbers are approximately equal, false otherwise
|
||
89 | */
|
||
90 | 335 | up20180642 | int eq_d(double a, double b); |
91 | 200 | up20180655 | |
92 | 334 | up20180642 | /**
|
93 | * @}
|
||
94 | */
|
||
95 | |||
96 | 144 | up20180655 | #endif //UTILS_H_INCLUDED |