aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/boards/NRF51-DK/board.h
blob: 0f45fce27b1070cab473cbd2c6f68e06f7981ff5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
    Copyright (C) 2015 Fabio Utzig

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.
*/

#ifndef _BOARD_H_
#define _BOARD_H_

/* Board identifier. */
#define BOARD_NRF51_DK
#define BOARD_NAME              "nRF51 DK"

/* Board oscillators-related settings. */
#define NRF51_XTAL_VALUE        16000000
#define NRF51_LFCLK_SOURCE      1

/* GPIO pins. */
#define BTN1           17
#define BTN2           18
#define BTN3           19
#define BTN4           20
#define LED1           21
#define LED2           22
#define LED3           23
#define LED4           24
#define UART_RTS        8
#define UART_TX         9
#define UART_CTS       10
#define UART_RX        11
#define SPI_SCK        29
#define SPI_MOSI       25
#define SPI_MISO       28
#define SPI_SS         24
#define I2C_SCL         7
#define I2C_SDA        30

/*
 * IO pins assignments.
 */
#define IOPORT1_BTN1           17U
#define IOPORT1_BTN2           18U
#define IOPORT1_BTN3           19U
#define IOPORT1_BTN4           20U
#define IOPORT1_LED1           21U
#define IOPORT1_LED2           22U
#define IOPORT1_LED3           23U
#define IOPORT1_LED4           24U
#define IOPORT1_UART_RTS        8U
#define IOPORT1_UART_TX         9U
#define IOPORT1_UART_CTS       10U
#define IOPORT1_UART_RX        11U
#define IOPORT1_SPI_SCK        29U
#define IOPORT1_SPI_MOSI       25U
#define IOPORT1_SPI_MISO       28U
#define IOPORT1_SPI_SS         24U
#define IOPORT1_I2C_SCL         7U
#define IOPORT1_I2C_SDA        30U

/*
 * IO lines assignments.
 */
#define LINE_BTN1      PAL_LINE(IOPORT1, IOPORT1_BTN1)
#define LINE_BTN2      PAL_LINE(IOPORT1, IOPORT1_BTN2)
#define LINE_BTN3      PAL_LINE(IOPORT1, IOPORT1_BTN3)
#define LINE_BTN4      PAL_LINE(IOPORT1, IOPORT1_BTN4)
#define LINE_LED1      PAL_LINE(IOPORT1, IOPORT1_LED1)
#define LINE_LED2      PAL_LINE(IOPORT1, IOPORT1_LED2)
#define LINE_LED3      PAL_LINE(IOPORT1, IOPORT1_LED3)
#define LINE_LED4      PAL_LINE(IOPORT1, IOPORT1_LED4)
#define LINE_UART_RTS  PAL_LINE(IOPORT1, IOPORT1_UART_RTS)
#define LINE_UART_TX   PAL_LINE(IOPORT1, IOPORT1_UART_TX)
#define LINE_UART_CTS  PAL_LINE(IOPORT1, IOPORT1_UART_CTS)
#define LINE_UART_RX   PAL_LINE(IOPORT1, IOPORT1_UART_RX)
#define LINE_SPI_SCK   PAL_LINE(IOPORT1, IOPORT1_SPI_SCK)
#define LINE_SPI_MOSI  PAL_LINE(IOPORT1, IOPORT1_SPI_MOSI)
#define LINE_SPI_MISO  PAL_LINE(IOPORT1, IOPORT1_SPI_MISO)
#define LINE_SPI_SS    PAL_LINE(IOPORT1, IOPORT1_SPI_SS)
#define LINE_I2C_SCL   PAL_LINE(IOPORT1, IOPORT1_I2C_SCL)
#define LINE_I2C_SDA   PAL_LINE(IOPORT1, IOPORT1_I2C_SDA)

#if !defined(_FROM_ASM_)
#ifdef __cplusplus
extern "C" {
#endif
  void boardInit(void);
#ifdef __cplusplus
}
#endif
#endif /* _FROM_ASM_ */

#endif /* _BOARD_H_ */