Statistics
| Branch: | Tag: | Revision:

amiro-os / modules / NUCLEO-L476RG / module.h @ ded1ded7

History | View | Annotate | Download (13.035 KB)

1 27d0378b Simon Welzel
/*
2
AMiRo-OS is an operating system designed for the Autonomous Mini Robot (AMiRo) platform.
3 96621a83 Thomas Schöpping
Copyright (C) 2016..2020  Thomas Schöpping et al.
4 27d0378b Simon Welzel

5
This program is free software: you can redistribute it and/or modify
6
it under the terms of the GNU General Public License as published by
7
the Free Software Foundation, either version 3 of the License, or
8
(at your option) any later version.
9

10
This program is distributed in the hope that it will be useful,
11
but WITHOUT ANY WARRANTY; without even the implied warranty of
12
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
GNU General Public License for more details.
14

15
You should have received a copy of the GNU General Public License
16
along with this program.  If not, see <http://www.gnu.org/licenses/>.
17
*/
18
19
/**
20
 * @file
21 126ace3c Thomas Schöpping
 * @brief   Structures and constant for the NUCLEO-L476RG module.
22 27d0378b Simon Welzel
 *
23 126ace3c Thomas Schöpping
 * @addtogroup NUCLEO-L476RG_module
24 27d0378b Simon Welzel
 * @{
25
 */
26
27 6ff06bbf Thomas Schöpping
#ifndef AMIROOS_MODULE_H
28
#define AMIROOS_MODULE_H
29 27d0378b Simon Welzel
30 8543d0d9 Thomas Schöpping
#include <amiroos.h>
31
32 ded1ded7 Thomas Schöpping
#if (BOARD_MPU6050_CONNECTED == true)
33
#include <math.h>
34
#endif /* BOARD_MPU6050_CONNECTED == true */
35
36 27d0378b Simon Welzel
/*===========================================================================*/
37
/**
38
 * @name Module specific functions
39
 * @{
40
 */
41
/*===========================================================================*/
42
43
/** @} */
44
45
/*===========================================================================*/
46
/**
47
 * @name ChibiOS/HAL configuration
48
 * @{
49
 */
50
/*===========================================================================*/
51
52
/**
53 8543d0d9 Thomas Schöpping
 * @brief   Serial driver of the programmer interface.
54 27d0378b Simon Welzel
 */
55 8543d0d9 Thomas Schöpping
#define MODULE_HAL_PROGIF                       SD2
56 27d0378b Simon Welzel
57
/**
58 8543d0d9 Thomas Schöpping
 * @brief   Configuration for the programmer serial interface driver.
59 27d0378b Simon Welzel
 */
60 8543d0d9 Thomas Schöpping
extern SerialConfig moduleHalProgIfConfig;
61 27d0378b Simon Welzel
62
/**
63
 * @brief   Real-Time Clock driver.
64
 */
65
#define MODULE_HAL_RTC                          RTCD1
66
67 126ace3c Thomas Schöpping
/**
68 ded1ded7 Thomas Schöpping
 * @brief   Default I2C interface for the NUCLEO I/O.
69 126ace3c Thomas Schöpping
 */
70 ded1ded7 Thomas Schöpping
#define MODULE_HAL_I2C                          I2CD1
71 126ace3c Thomas Schöpping
72
/**
73 ded1ded7 Thomas Schöpping
 * @brief   Configuration for the I2C driver #1.
74 126ace3c Thomas Schöpping
 */
75 ded1ded7 Thomas Schöpping
extern I2CConfig moduleHalI2cConfig;
76 126ace3c Thomas Schöpping
77 27d0378b Simon Welzel
/** @} */
78
79
/*===========================================================================*/
80
/**
81
 * @name GPIO definitions
82
 * @{
83
 */
84
/*===========================================================================*/
85
86
/**
87
 * @brief   LED output signal GPIO.
88
 */
89
extern ROMCONST apalControlGpio_t moduleGpioLed;
90
91
/**
92 8543d0d9 Thomas Schöpping
 * @brief   User button input signal.
93 27d0378b Simon Welzel
 */
94 8543d0d9 Thomas Schöpping
extern ROMCONST apalControlGpio_t moduleGpioUserButton;
95 ded1ded7 Thomas Schöpping
96
#if (BOARD_VL53L1X_CONNECTED == true)
97
98
/**
99
 * @brief   VL53L1X interrupt signal (GPIO1).
100
 */
101 849b383a galberding
extern ROMCONST apalControlGpio_t moduleGpioVl53l1xINT;
102 ded1ded7 Thomas Schöpping
103
/**
104
 * @brief   VL53L1X XSHUT signal.
105
 */
106 849b383a galberding
extern ROMCONST apalControlGpio_t moduleGpioVl53l1xXSHUT;
107 27d0378b Simon Welzel
108 ded1ded7 Thomas Schöpping
#endif /* (BOARD_VL53L1X_CONNECTED == true) */
109
110 8543d0d9 Thomas Schöpping
/** @} */
111 27d0378b Simon Welzel
112 8543d0d9 Thomas Schöpping
/*===========================================================================*/
113 27d0378b Simon Welzel
/**
114 8543d0d9 Thomas Schöpping
 * @name AMiRo-OS core configurations
115
 * @{
116 27d0378b Simon Welzel
 */
117 8543d0d9 Thomas Schöpping
/*===========================================================================*/
118 27d0378b Simon Welzel
119
/**
120 8543d0d9 Thomas Schöpping
 * @brief   Event flag to be set on a USER_BUTTON interrupt.
121 27d0378b Simon Welzel
 */
122 cda14729 Thomas Schöpping
#define MODULE_OS_GPIOEVENTFLAG_USERBUTTON      AOS_GPIOEVENT_FLAG(PAL_PAD(LINE_BUTTON))
123 27d0378b Simon Welzel
124 cda14729 Thomas Schöpping
#if (AMIROOS_CFG_SHELL_ENABLE == true) || defined(__DOXYGEN__)
125 27d0378b Simon Welzel
/**
126 8543d0d9 Thomas Schöpping
 * @brief   Shell prompt text.
127 27d0378b Simon Welzel
 */
128 8543d0d9 Thomas Schöpping
extern ROMCONST char* moduleShellPrompt;
129 cda14729 Thomas Schöpping
#endif /* (AMIROOS_CFG_SHELL_ENABLE == true) */
130 27d0378b Simon Welzel
131
/**
132 8543d0d9 Thomas Schöpping
 * @brief   Interrupt initialization macro.
133 27d0378b Simon Welzel
 */
134 8543d0d9 Thomas Schöpping
#define MODULE_INIT_INTERRUPTS() {                                            \
135
  /* user button */                                                           \
136 cda14729 Thomas Schöpping
  palSetLineCallback(moduleGpioUserButton.gpio->line, aosSysGetStdGpioCallback(), &moduleGpioUserButton.gpio->line);  \
137 56dc4779 Thomas Schöpping
  palEnableLineEvent(moduleGpioUserButton.gpio->line, APAL2CH_EDGE(moduleGpioUserButton.meta.edge));                  \
138 849b383a galberding
  MODULE_INIT_INTERRUPTS_VL53L1X();                                           \
139 8543d0d9 Thomas Schöpping
}
140 27d0378b Simon Welzel
141 849b383a galberding
142
#if (BOARD_VL53L1X_CONNECTED == true)
143
  #define MODULE_INIT_INTERRUPTS_VL53L1X() {                                  \
144
    palSetLineCallback(moduleGpioVl53l1xINT.gpio->line, aosSysGetStdGpioCallback(), &moduleGpioVl53l1xINT.gpio->line);  \
145
    palEnableLineEvent(moduleGpioVl53l1xINT.gpio->line, APAL2CH_EDGE(moduleGpioVl53l1xINT.meta.edge));                  \
146
  }
147
#else /* (BOARD_VL53L1X_CONNECTED == true) */
148
  #define MODULE_INIT_INTERRUPTS_VL53L1X() {}
149
#endif /* (BOARD_VL53L1X_CONNECTED == true) */
150
151 27d0378b Simon Welzel
/**
152 4c72a54c Thomas Schöpping
 * @brief   Test initialization hook.
153 27d0378b Simon Welzel
 */
154 8543d0d9 Thomas Schöpping
#define MODULE_INIT_TESTS() {                                                 \
155 cda14729 Thomas Schöpping
  /* add test commands to shell */                                            \
156 4c72a54c Thomas Schöpping
  aosShellAddCommand(&aos.shell, &moduleTestLedShellCmd);                     \
157
  aosShellAddCommand(&aos.shell, &moduleTestButtonShellCmd);                  \
158 126ace3c Thomas Schöpping
  MODULE_INIT_TEST_MPU6050();                                                 \
159 849b383a galberding
  MODULE_INIT_TEST_VL53L1X();                                                 \
160 4c72a54c Thomas Schöpping
  aosShellAddCommand(&aos.shell, &moduleTestAllShellCmd);                     \
161 8543d0d9 Thomas Schöpping
}
162 4c72a54c Thomas Schöpping
#if (BOARD_MPU6050_CONNECTED == true)
163 126ace3c Thomas Schöpping
  #define MODULE_INIT_TEST_MPU6050() {                                        \
164 4c72a54c Thomas Schöpping
    aosShellAddCommand(&aos.shell, &moduleTestMpu6050ShellCmd);               \
165 126ace3c Thomas Schöpping
  }
166 4c72a54c Thomas Schöpping
#else /* (BOARD_MPU6050_CONNECTED == true) */
167 126ace3c Thomas Schöpping
  #define MODULE_INIT_TEST_MPU6050() {}
168 4c72a54c Thomas Schöpping
#endif /* (BOARD_MPU6050_CONNECTED == true) */
169 27d0378b Simon Welzel
170 849b383a galberding
#if (BOARD_VL53L1X_CONNECTED == true)
171
  #define MODULE_INIT_TEST_VL53L1X() {                                        \
172
    aosShellAddCommand(&aos.shell, &moduleTestVL53L1XShellCmd);               \
173
  }
174
#else /* (BOARD_VL53L1X_CONNECTED == true) */
175
  #define MODULE_INIT_TEST_VL53L1X() {}
176
#endif /* (BOARD_VL53L1X_CONNECTED == true) */
177
178 27d0378b Simon Welzel
/**
179 8543d0d9 Thomas Schöpping
 * @brief   Periphery communication interfaces initialization hook.
180 27d0378b Simon Welzel
 */
181 4c72a54c Thomas Schöpping
#define MODULE_INIT_PERIPHERY_IF() {                                          \
182 8543d0d9 Thomas Schöpping
  /* serial driver */                                                         \
183
  sdStart(&MODULE_HAL_PROGIF, &moduleHalProgIfConfig);                        \
184 ded1ded7 Thomas Schöpping
  /* I2C */                                                                   \
185
  uint32_t i2c_freq = 1000000; /* maximum I2C frequency supported for this MCU */ \
186
  MODULE_INIT_PERIPHERY_IF_MPU6050(i2c_freq);                                 \
187
  MODULE_INIT_PERIPHERY_IF_VL53L1X(i2c_freq);                                 \
188
  if (i2c_freq == 100000) /* standard-mode @ 100 kHz */ {                     \
189
    moduleHalI2cConfig.timingr = 0x10909CEC; /* obtained via STM32CubeMX with STM32_I2CxCLK = 80 MHz */ \
190
  } else if (i2c_freq == 400000) /* fast-mode @ 400 kHz */ {                  \
191
    moduleHalI2cConfig.timingr = 0x00702991; /* obtained via STM32CubeMX with STM32_I2CxCLK = 80 MHz */ \
192
  } else if (i2c_freq == 1000000) /* fast-mode-plus @ 10000 kHz */ {          \
193
    moduleHalI2cConfig.timingr = 0x00300F33; /* obtained via STM32CubeMX with STM32_I2CxCLK = 80 MHz */ \
194
  } else {                                                                    \
195
    aosDbgAssertMsg(false, "I2C frequency not supported");                    \
196
  }                                                                           \
197
  i2cStart(&MODULE_HAL_I2C, &moduleHalI2cConfig);                             \
198 8543d0d9 Thomas Schöpping
}
199 27d0378b Simon Welzel
200 ded1ded7 Thomas Schöpping
201
/**
202
 * @brief   Limits I2C frequency to maximum value supported by MPU6050.
203
 */
204
#if (BOARD_MPU6050_CONNECTED == true) || defined(__DOXYGEN__)
205
  #define MODULE_INIT_PERIPHERY_IF_MPU6050(freq) {freq = (MPU6050_LLD_I2C_MAXFREQUENCY < freq) ? MPU6050_LLD_I2C_MAXFREQUENCY : freq;}
206
#else
207
  #define MODULE_INIT_PERIPHERY_IF_MPU6050(freq) {}
208
#endif
209
210
/**
211
 * @brief   Limits I2C frequency to maximum value supported by VL53L1X and configures required GPIOs.
212
 */
213
#if (BOARD_VL53L1X_CONNECTED == true) || defined(__DOXYGEN__)
214
  #define MODULE_INIT_PERIPHERY_IF_VL53L1X(freq) {                            \
215
    freq = (VL53L1X_LLD_I2C_MAXFREQUENCY < freq) ? VL53L1X_LLD_I2C_MAXFREQUENCY : freq; \
216
    chSysLock();                                                              \
217
    /* set XSHUT GPIO as output in open-drain configuration with internal pull-up, but initially pulled-down signal */  \
218
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->OTYPER &= ~(1U << PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line)); \
219
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->OTYPER |= PIN_OTYPE_OPENDRAIN(PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line)); \
220
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->PUPDR &= ~(3U << (PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line) * 2U)); \
221
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->PUPDR |= PIN_PUPDR_PULLUP(PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line)); \
222
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->ODR &= ~(1U << PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line));  \
223
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->ODR |= PIN_ODR_LOW(PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line));  \
224
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->MODER &= ~(3U << (PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line) * 2U)); \
225
    PAL_PORT(moduleLldVl53l1x.Interface.xshut->gpio->line)->MODER |= PIN_MODE_OUTPUT(PAL_PAD(moduleLldVl53l1x.Interface.xshut->gpio->line));  \
226
    /* set GPIO1 (interrupt) GPIO as input with internal pull-up */           \
227
    PAL_PORT(moduleLldVl53l1x.Interface.gpio1->gpio->line)->PUPDR &= ~(3U << (PAL_PAD(moduleLldVl53l1x.Interface.gpio1->gpio->line) * 2U)); \
228
    PAL_PORT(moduleLldVl53l1x.Interface.gpio1->gpio->line)->PUPDR |= PIN_PUPDR_PULLUP(PAL_PAD(moduleLldVl53l1x.Interface.gpio1->gpio->line)); \
229
    PAL_PORT(moduleLldVl53l1x.Interface.gpio1->gpio->line)->MODER &= ~(3U << (PAL_PAD(moduleLldVl53l1x.Interface.gpio1->gpio->line) * 2U)); \
230
    PAL_PORT(moduleLldVl53l1x.Interface.gpio1->gpio->line)->MODER |= PIN_MODE_INPUT(PAL_PAD(moduleLldVl53l1x.Interface.gpio1->gpio->line)); \
231 849b383a galberding
    chSysUnlock();                                                            \
232
  }
233 ded1ded7 Thomas Schöpping
#else
234
  #define MODULE_INIT_PERIPHERY_IF_VL53L1X(freq) {}
235
#endif
236 849b383a galberding
237 27d0378b Simon Welzel
/**
238 8543d0d9 Thomas Schöpping
 * @brief   Periphery communication interface deinitialization hook.
239 27d0378b Simon Welzel
 */
240 4c72a54c Thomas Schöpping
#define MODULE_SHUTDOWN_PERIPHERY_IF() {                                      \
241 ded1ded7 Thomas Schöpping
  /* I2C */                                                                   \
242
  i2cStop(&MODULE_HAL_I2C);                                                   \
243 cda14729 Thomas Schöpping
  /* don't stop the serial driver so messages can still be printed */         \
244 8543d0d9 Thomas Schöpping
}
245 27d0378b Simon Welzel
246
/**
247 8543d0d9 Thomas Schöpping
 * @brief   HOOK to toggle the LEDs when the user button is pressed.
248 27d0378b Simon Welzel
 */
249 cda14729 Thomas Schöpping
#define MODULE_MAIN_LOOP_GPIOEVENT(eventflags) {                              \
250
  if (eventflags & MODULE_OS_GPIOEVENTFLAG_USERBUTTON) {                      \
251 4c72a54c Thomas Schöpping
    button_lld_state_t buttonstate;                                           \
252
    button_lld_get(&moduleLldUserButton, &buttonstate);                       \
253
    led_lld_set(&moduleLldLed, (buttonstate == BUTTON_LLD_STATE_PRESSED) ? LED_LLD_STATE_ON : LED_LLD_STATE_OFF); \
254 8543d0d9 Thomas Schöpping
  }                                                                           \
255
}
256 27d0378b Simon Welzel
257
/** @} */
258
259
/*===========================================================================*/
260
/**
261 8543d0d9 Thomas Schöpping
 * @name Startup Shutdown Synchronization Protocol (SSSP)
262 27d0378b Simon Welzel
 * @{
263
 */
264
/*===========================================================================*/
265
266 cda14729 Thomas Schöpping
#if (AMIROOS_CFG_SSSP_ENABLE == true) || defined(__DOXYGEN__)
267 c53ef0b1 Thomas Schöpping
  #error "SSSP is not supported on this module."
268 cda14729 Thomas Schöpping
#endif /* (AMIROOS_CFG_SSSP_ENABLE == true) */
269
270 8543d0d9 Thomas Schöpping
/** @} */
271 27d0378b Simon Welzel
272 8543d0d9 Thomas Schöpping
/*===========================================================================*/
273 27d0378b Simon Welzel
/**
274 8543d0d9 Thomas Schöpping
 * @name Low-level drivers
275
 * @{
276 27d0378b Simon Welzel
 */
277 8543d0d9 Thomas Schöpping
/*===========================================================================*/
278 4c72a54c Thomas Schöpping
#include <alld_LED.h>
279
#include <alld_button.h>
280 27d0378b Simon Welzel
281 4c72a54c Thomas Schöpping
/**
282
 * @brief   LED driver.
283
 */
284
extern LEDDriver moduleLldLed;
285
286
/**
287
 * @brief   Button driver.
288
 */
289
extern ButtonDriver moduleLldUserButton;
290
291
#if (BOARD_MPU6050_CONNECTED == true) || defined(__DOXYGEN__)
292 126ace3c Thomas Schöpping
293
#include <alld_MPU6050.h>
294
295
/**
296
 * @brief   Accelerometer (MPU6050) driver.
297
 */
298
extern MPU6050Driver moduleLldMpu6050;
299
300 4c72a54c Thomas Schöpping
#endif /* (BOARD_MPU6050_CONNECTED == true) */
301 126ace3c Thomas Schöpping
302 ded1ded7 Thomas Schöpping
#if (BOARD_VL53L1X_CONNECTED == true) || defined(__DOXYGEN__)
303
304
#include <alld_VL53L1X.h>
305
306
/**
307
 * @brief   ToF sensor (VL53L1X) driver.
308
 */
309
extern VL53L1XDriver moduleLldVl53l1x;
310
311
#endif /* (BOARD_VL53L1X_CONNECTED == true) */
312
313 8543d0d9 Thomas Schöpping
/** @} */
314 1678f270 Simon Welzel
315 8543d0d9 Thomas Schöpping
/*===========================================================================*/
316 1678f270 Simon Welzel
/**
317 4c72a54c Thomas Schöpping
 * @name Tests
318 8543d0d9 Thomas Schöpping
 * @{
319 1678f270 Simon Welzel
 */
320 8543d0d9 Thomas Schöpping
/*===========================================================================*/
321
#if (AMIROOS_CFG_TESTS_ENABLE == true) || defined(__DOXYGEN__)
322 1678f270 Simon Welzel
323 4c72a54c Thomas Schöpping
/**
324
 * @brief   LED test command.
325
 */
326
extern aos_shellcommand_t moduleTestLedShellCmd;
327
328
/**
329
 * @brief   User button test command.
330
 */
331
extern aos_shellcommand_t moduleTestButtonShellCmd;
332 126ace3c Thomas Schöpping
333 4c72a54c Thomas Schöpping
#if (BOARD_MPU6050_CONNECTED == true) || defined(__DOXYGEN__)
334 126ace3c Thomas Schöpping
335
/**
336 4c72a54c Thomas Schöpping
 * @brief   MPU6050 (Accelerometer & Gyroscope) test command.
337 126ace3c Thomas Schöpping
 */
338 4c72a54c Thomas Schöpping
extern aos_shellcommand_t moduleTestMpu6050ShellCmd;
339 126ace3c Thomas Schöpping
340 4c72a54c Thomas Schöpping
#endif /* (BOARD_MPU6050_CONNECTED == true) */
341
342 ded1ded7 Thomas Schöpping
#if (BOARD_VL53L1X_CONNECTED == true) || defined(__DOXYGEN__)
343
344
/**
345
 * @brief   VL53L1X (ToF sonsor) test command.
346
 */
347
extern aos_shellcommand_t moduleTestVL53L1XShellCmd;
348
349
#endif /* (BOARD_VL53L1X_CONNECTED == true) */
350
351 4c72a54c Thomas Schöpping
/**
352
 * @brief   Entire module test command.
353
 */
354
extern aos_shellcommand_t moduleTestAllShellCmd;
355 126ace3c Thomas Schöpping
356 7de0cc90 Thomas Schöpping
#endif /* (AMIROOS_CFG_TESTS_ENABLE == true) */
357 8543d0d9 Thomas Schöpping
358
/** @} */
359
360 6ff06bbf Thomas Schöpping
#endif /* AMIROOS_MODULE_H */
361 27d0378b Simon Welzel
362
/** @} */