Mercurial > hg > beaglert
comparison include/Utilities.h @ 101:04f894424a8c
Merge
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Mon, 27 Jul 2015 12:46:55 +0100 |
parents | c529505203ee |
children | f1012082f142 |
comparison
equal
deleted
inserted
replaced
100:b697e82ebb25 | 101:04f894424a8c |
---|---|
13 #ifndef UTILITIES_H_ | 13 #ifndef UTILITIES_H_ |
14 #define UTILITIES_H_ | 14 #define UTILITIES_H_ |
15 | 15 |
16 #include "BeagleRT.h" | 16 #include "BeagleRT.h" |
17 | 17 |
18 /** | |
19 * \defgroup iofunctions I/O functions and constants | |
20 * | |
21 * These functions and macros are used for audio, analog and digital I/O. All the | |
22 * I/O functions require the BeagleRTContext data structure from render() to be passed | |
23 * in. This means that these functions are, by design, \b only usable from within | |
24 * the rendering thread. | |
25 * | |
26 * The naming conventions are loosely derived from the Arduino environment, and the | |
27 * syntax is similar. Unlike Arduino, the I/O functions require the frame number at which | |
28 * the read or write should take place, since all I/O happens synchronously with the | |
29 * audio clock. | |
30 * | |
31 * @{ | |
32 */ | |
33 | |
18 #define HIGH 0x1 | 34 #define HIGH 0x1 |
19 #define LOW 0x0 | 35 #define LOW 0x0 |
20 | 36 |
21 #define INPUT 0x0 | 37 #define INPUT 0x0 |
22 #define OUTPUT 0x1 | 38 #define OUTPUT 0x1 |
23 | 39 |
40 /** @} */ | |
41 | |
42 /** | |
43 * \ingroup wiring | |
44 * | |
45 * @{ | |
46 */ | |
47 | |
24 /// Set the given bit in \c word to 1. | 48 /// Set the given bit in \c word to 1. |
25 #define setBit(word,bit) ((word) | (1 << (bit))) | 49 #define setBit(word,bit) ((word) | (1 << (bit))) |
26 | 50 |
27 /// Clear the given bit in \c word to 0. | 51 /// Clear the given bit in \c word to 0. |
28 #define clearBit(word,bit) ((word) &~ (1 << (bit))) | 52 #define clearBit(word,bit) ((word) &~ (1 << (bit))) |
30 /// Check if the given bit in \c word is 1 (returns nonzero) or 0 (returns zero). | 54 /// Check if the given bit in \c word is 1 (returns nonzero) or 0 (returns zero). |
31 #define getBit(word,bit) (((word) >> (bit)) & 1) | 55 #define getBit(word,bit) (((word) >> (bit)) & 1) |
32 | 56 |
33 /// Set/clear the given bit in \c word to \c value. | 57 /// Set/clear the given bit in \c word to \c value. |
34 #define changeBit(word,bit,value) ((clearBit((word),(bit))) | ((value) << (bit))) | 58 #define changeBit(word,bit,value) ((clearBit((word),(bit))) | ((value) << (bit))) |
59 | |
60 /** @} */ | |
61 | |
62 /** | |
63 * \ingroup iofunctions | |
64 * | |
65 * @{ | |
66 */ | |
35 | 67 |
36 #if 1 | 68 #if 1 |
37 // Note: pinMode(), analogWrite() and digitalWrite() should be able to be called from setup() | 69 // Note: pinMode(), analogWrite() and digitalWrite() should be able to be called from setup() |
38 // Likewise, thread launch should be able to be called from setup() | 70 // Likewise, thread launch should be able to be called from setup() |
39 // Also, make volume change functions callable from render() thread -- as an aux task? | 71 // Also, make volume change functions callable from render() thread -- as an aux task? |
179 * BeagleBone Black are available. See the constants P8_xx and P9_xx defined in | 211 * BeagleBone Black are available. See the constants P8_xx and P9_xx defined in |
180 * digital_gpio_mapping.h. | 212 * digital_gpio_mapping.h. |
181 * \param value Direction of the pin (\c INPUT or \c OUTPUT). | 213 * \param value Direction of the pin (\c INPUT or \c OUTPUT). |
182 */ | 214 */ |
183 void pinModeFrameOnce(BeagleRTContext *context, int frame, int channel, int mode); | 215 void pinModeFrameOnce(BeagleRTContext *context, int frame, int channel, int mode); |
216 | |
217 /** @} */ | |
184 | 218 |
185 #else | 219 #else |
186 | 220 |
187 // Macros for accessing the analog values: usable _only_ within render() | 221 // Macros for accessing the analog values: usable _only_ within render() |
188 | 222 |
217 #define digitalRead(pin, frame) ( getBit(digital[(frame)], pin+16) ) | 251 #define digitalRead(pin, frame) ( getBit(digital[(frame)], pin+16) ) |
218 | 252 |
219 #endif | 253 #endif |
220 | 254 |
221 /** | 255 /** |
256 * \defgroup wiring Wiring language support | |
257 * | |
258 * These are functions found in the Wiring (Arduino) language which are not directly | |
259 * related to I/O but are provided as a convenience. | |
260 * | |
261 * @{ | |
262 */ | |
263 | |
264 /** | |
222 * \brief Linearly rescale a number from one range of values to another. | 265 * \brief Linearly rescale a number from one range of values to another. |
223 * | 266 * |
224 * This function linearly scales values of \c x such that the range in_min to | 267 * This function linearly scales values of \c x such that the range in_min to |
225 * in_max at the input corresponds to the range out_min to out_max | 268 * in_max at the input corresponds to the range out_min to out_max |
226 * at the output. Values outside this range are extrapolated. | 269 * at the output. Values outside this range are extrapolated. |
254 * \param max_val Maximum possible value. | 297 * \param max_val Maximum possible value. |
255 * \return Constrained value. | 298 * \return Constrained value. |
256 */ | 299 */ |
257 float constrain(float x, float min_val, float max_val); | 300 float constrain(float x, float min_val, float max_val); |
258 | 301 |
302 /** @} */ | |
303 | |
259 #endif /* UTILITIES_H_ */ | 304 #endif /* UTILITIES_H_ */ |