boards.h 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. /**
  2. * Copyright (c) 2014 - 2017, Nordic Semiconductor ASA
  3. *
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without modification,
  7. * are permitted provided that the following conditions are met:
  8. *
  9. * 1. Redistributions of source code must retain the above copyright notice, this
  10. * list of conditions and the following disclaimer.
  11. *
  12. * 2. Redistributions in binary form, except as embedded into a Nordic
  13. * Semiconductor ASA integrated circuit in a product or a software update for
  14. * such product, must reproduce the above copyright notice, this list of
  15. * conditions and the following disclaimer in the documentation and/or other
  16. * materials provided with the distribution.
  17. *
  18. * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
  19. * contributors may be used to endorse or promote products derived from this
  20. * software without specific prior written permission.
  21. *
  22. * 4. This software, with or without modification, must only be used with a
  23. * Nordic Semiconductor ASA integrated circuit.
  24. *
  25. * 5. Any software provided in binary form under this license must not be reverse
  26. * engineered, decompiled, modified and/or disassembled.
  27. *
  28. * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
  29. * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  30. * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
  31. * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
  32. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  33. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
  34. * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  35. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  36. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  37. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  38. *
  39. */
  40. #ifndef BOARDS_H
  41. #define BOARDS_H
  42. #include "nrf_gpio.h"
  43. #if defined(BOARD_NRF6310)
  44. #include "nrf6310.h"
  45. #elif defined(BOARD_PCA10000)
  46. #include "pca10000.h"
  47. #elif defined(BOARD_PCA10001)
  48. #include "pca10001.h"
  49. #elif defined(BOARD_PCA10002)
  50. #include "pca10000.h"
  51. #elif defined(BOARD_PCA10003)
  52. #include "pca10003.h"
  53. #elif defined(BOARD_PCA20006)
  54. #include "pca20006.h"
  55. #elif defined(BOARD_PCA10028)
  56. #include "pca10028.h"
  57. #elif defined(BOARD_PCA10031)
  58. #include "pca10031.h"
  59. #elif defined(BOARD_PCA10036)
  60. #include "pca10036.h"
  61. #elif defined(BOARD_PCA10040)
  62. #include "pca10040.h"
  63. #elif defined(BOARD_PCA10056)
  64. #include "pca10056.h"
  65. #elif defined(BOARD_WT51822)
  66. #include "wt51822.h"
  67. #elif defined(BOARD_N5DK1)
  68. #include "n5_starterkit.h"
  69. #elif defined (BOARD_D52DK1)
  70. #include "d52_starterkit.h"
  71. #elif defined (BOARD_ARDUINO_PRIMO)
  72. #include "arduino_primo.h"
  73. #elif defined(BOARD_CUSTOM)
  74. #include "custom_board.h"
  75. #else
  76. #error "Board is not defined"
  77. #endif
  78. #ifdef __cplusplus
  79. extern "C" {
  80. #endif
  81. /**
  82. * Function for returning the state of an LED.
  83. *
  84. * @param led_idx LED index (starting from 0), as defined in the board-specific header.
  85. *
  86. * @return True if the LED is turned on.
  87. */
  88. bool bsp_board_led_state_get(uint32_t led_idx);
  89. /**
  90. * Function for turning on an LED.
  91. *
  92. * @param led_idx LED index (starting from 0), as defined in the board-specific header.
  93. */
  94. void bsp_board_led_on(uint32_t led_idx);
  95. /**
  96. * Function for turning off an LED.
  97. *
  98. * @param led_idx LED index (starting from 0), as defined in the board-specific header.
  99. */
  100. void bsp_board_led_off(uint32_t led_idx);
  101. /**
  102. * Function for inverting the state of an LED.
  103. *
  104. * @param led_idx LED index (starting from 0), as defined in the board-specific header.
  105. */
  106. void bsp_board_led_invert(uint32_t led_idx);
  107. /**
  108. * Function for turning off all LEDs.
  109. */
  110. void bsp_board_leds_off(void);
  111. /**
  112. * Function for turning on all LEDs.
  113. */
  114. void bsp_board_leds_on(void);
  115. /**
  116. * Function for initializing LEDs.
  117. */
  118. void bsp_board_leds_init(void);
  119. /**
  120. * Function for converting pin number to LED index.
  121. *
  122. * @param pin_number Pin number.
  123. *
  124. * @return LED index of the given pin or 0xFFFFFFFF if invalid pin provided.
  125. */
  126. uint32_t bsp_board_pin_to_led_idx(uint32_t pin_number);
  127. /**
  128. * Function for converting LED index to pin number.
  129. *
  130. * @param led_idx LED index.
  131. *
  132. * @return Pin number.
  133. */
  134. uint32_t bsp_board_led_idx_to_pin(uint32_t led_idx);
  135. /**
  136. * Function for returning the state of a button.
  137. *
  138. * @param button_idx Button index (starting from 0), as defined in the board-specific header.
  139. *
  140. * @return True if the button is pressed.
  141. */
  142. bool bsp_board_button_state_get(uint32_t button_idx);
  143. /**
  144. * Function for initializing buttons.
  145. */
  146. void bsp_board_buttons_init(void);
  147. /**
  148. * Function for converting pin number to button index.
  149. *
  150. * @param pin_number Pin number.
  151. *
  152. * @return Button index of the given pin or 0xFFFFFFFF if invalid pin provided.
  153. */
  154. uint32_t bsp_board_pin_to_button_idx(uint32_t pin_number);
  155. /**
  156. * Function for converting button index to pin number.
  157. *
  158. * @param button_idx Button index.
  159. *
  160. * @return Pin number.
  161. */
  162. uint32_t bsp_board_button_idx_to_pin(uint32_t button_idx);
  163. #define BSP_BOARD_LED_0 0
  164. #define BSP_BOARD_LED_1 1
  165. #define BSP_BOARD_LED_2 2
  166. #define BSP_BOARD_LED_3 3
  167. #define BSP_BOARD_LED_4 4
  168. #define BSP_BOARD_LED_5 5
  169. #define BSP_BOARD_LED_6 6
  170. #define BSP_BOARD_LED_7 7
  171. #ifdef BSP_LED_0
  172. #define BSP_LED_0_MASK (1<<BSP_LED_0)
  173. #else
  174. #define BSP_LED_0_MASK 0
  175. #endif
  176. #ifdef BSP_LED_1
  177. #define BSP_LED_1_MASK (1<<BSP_LED_1)
  178. #else
  179. #define BSP_LED_1_MASK 0
  180. #endif
  181. #ifdef BSP_LED_2
  182. #define BSP_LED_2_MASK (1<<BSP_LED_2)
  183. #else
  184. #define BSP_LED_2_MASK 0
  185. #endif
  186. #ifdef BSP_LED_3
  187. #define BSP_LED_3_MASK (1<<BSP_LED_3)
  188. #else
  189. #define BSP_LED_3_MASK 0
  190. #endif
  191. #ifdef BSP_LED_4
  192. #define BSP_LED_4_MASK (1<<BSP_LED_4)
  193. #else
  194. #define BSP_LED_4_MASK 0
  195. #endif
  196. #ifdef BSP_LED_5
  197. #define BSP_LED_5_MASK (1<<BSP_LED_5)
  198. #else
  199. #define BSP_LED_5_MASK 0
  200. #endif
  201. #ifdef BSP_LED_6
  202. #define BSP_LED_6_MASK (1<<BSP_LED_6)
  203. #else
  204. #define BSP_LED_6_MASK 0
  205. #endif
  206. #ifdef BSP_LED_7
  207. #define BSP_LED_7_MASK (1<<BSP_LED_7)
  208. #else
  209. #define BSP_LED_7_MASK 0
  210. #endif
  211. #define LEDS_MASK (BSP_LED_0_MASK | BSP_LED_1_MASK | \
  212. BSP_LED_2_MASK | BSP_LED_3_MASK | \
  213. BSP_LED_4_MASK | BSP_LED_5_MASK | \
  214. BSP_LED_6_MASK | BSP_LED_7_MASK)
  215. #define BSP_BOARD_BUTTON_0 0
  216. #define BSP_BOARD_BUTTON_1 1
  217. #define BSP_BOARD_BUTTON_2 2
  218. #define BSP_BOARD_BUTTON_3 3
  219. #define BSP_BOARD_BUTTON_4 4
  220. #define BSP_BOARD_BUTTON_5 5
  221. #define BSP_BOARD_BUTTON_6 6
  222. #define BSP_BOARD_BUTTON_7 7
  223. #ifdef BSP_BUTTON_0
  224. #define BSP_BUTTON_0_MASK (1<<BSP_BUTTON_0)
  225. #else
  226. #define BSP_BUTTON_0_MASK 0
  227. #endif
  228. #ifdef BSP_BUTTON_1
  229. #define BSP_BUTTON_1_MASK (1<<BSP_BUTTON_1)
  230. #else
  231. #define BSP_BUTTON_1_MASK 0
  232. #endif
  233. #ifdef BSP_BUTTON_2
  234. #define BSP_BUTTON_2_MASK (1<<BSP_BUTTON_2)
  235. #else
  236. #define BSP_BUTTON_2_MASK 0
  237. #endif
  238. #ifdef BSP_BUTTON_3
  239. #define BSP_BUTTON_3_MASK (1<<BSP_BUTTON_3)
  240. #else
  241. #define BSP_BUTTON_3_MASK 0
  242. #endif
  243. #ifdef BSP_BUTTON_4
  244. #define BSP_BUTTON_4_MASK (1<<BSP_BUTTON_4)
  245. #else
  246. #define BSP_BUTTON_4_MASK 0
  247. #endif
  248. #ifdef BSP_BUTTON_5
  249. #define BSP_BUTTON_5_MASK (1<<BSP_BUTTON_5)
  250. #else
  251. #define BSP_BUTTON_5_MASK 0
  252. #endif
  253. #ifdef BSP_BUTTON_6
  254. #define BSP_BUTTON_6_MASK (1<<BSP_BUTTON_6)
  255. #else
  256. #define BSP_BUTTON_6_MASK 0
  257. #endif
  258. #ifdef BSP_BUTTON_7
  259. #define BSP_BUTTON_7_MASK (1<<BSP_BUTTON_7)
  260. #else
  261. #define BSP_BUTTON_7_MASK 0
  262. #endif
  263. #define BUTTONS_MASK (BSP_BUTTON_0_MASK | BSP_BUTTON_1_MASK | \
  264. BSP_BUTTON_2_MASK | BSP_BUTTON_3_MASK | \
  265. BSP_BUTTON_4_MASK | BSP_BUTTON_5_MASK | \
  266. BSP_BUTTON_6_MASK | BSP_BUTTON_7_MASK)
  267. #define LEDS_OFF(leds_mask) do { ASSERT(sizeof(leds_mask) == 4); \
  268. NRF_GPIO->OUTSET = (leds_mask) & (LEDS_MASK & LEDS_INV_MASK); \
  269. NRF_GPIO->OUTCLR = (leds_mask) & (LEDS_MASK & ~LEDS_INV_MASK); } while (0)
  270. #define LEDS_ON(leds_mask) do { ASSERT(sizeof(leds_mask) == 4); \
  271. NRF_GPIO->OUTCLR = (leds_mask) & (LEDS_MASK & LEDS_INV_MASK); \
  272. NRF_GPIO->OUTSET = (leds_mask) & (LEDS_MASK & ~LEDS_INV_MASK); } while (0)
  273. #define LED_IS_ON(leds_mask) ((leds_mask) & (NRF_GPIO->OUT ^ LEDS_INV_MASK) )
  274. #define LEDS_INVERT(leds_mask) do { uint32_t gpio_state = NRF_GPIO->OUT; \
  275. ASSERT(sizeof(leds_mask) == 4); \
  276. NRF_GPIO->OUTSET = ((leds_mask) & ~gpio_state); \
  277. NRF_GPIO->OUTCLR = ((leds_mask) & gpio_state); } while (0)
  278. #define LEDS_CONFIGURE(leds_mask) do { uint32_t pin; \
  279. ASSERT(sizeof(leds_mask) == 4); \
  280. for (pin = 0; pin < 32; pin++) \
  281. if ( (leds_mask) & (1 << pin) ) \
  282. nrf_gpio_cfg_output(pin); } while (0)
  283. #ifdef __cplusplus
  284. }
  285. #endif
  286. #endif