aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/boards/NRF52-E73-2G4M04S/board.h
blob: c78909f275d3366c78549b09ec38be70be608842 (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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
/*
    Copyright (C) 2016 Stephane D'Alu

    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_NRF52_EBYTE_E73
#define BOARD_NAME             "nRF52 EBYTE E73-2G4M04S"

/* Board oscillators-related settings. */
#define NRF5_XTAL_VALUE        32000000
#define NRF5_HFCLK_SOURCE      NRF5_HFCLK_HFXO
#define NRF5_LFCLK_SOURCE      NRF5_LFCLK_XTAL

#define NRF5_HFCLK_HFINT       0
#define NRF5_HFCLK_HFXO        1

#define NRF5_LFCLK_RC          0
#define NRF5_LFCLK_XTAL        1
#define NRF5_LFCLK_SYNTH       2

/*
 * GPIO pins. 
 */
/* Defined by board */
#define BTN1           13U
#define BTN2           14U
#define BTN3           15U
#define BTN4           16U
#define LED1           17U
#define LED2           18U
#define LED3           19U
#define LED4           20U
#define UART_RTS        5U
#define UART_TX         6U
#define UART_CTS        7U
#define UART_RX         8U
#define NFC1            9U
#define NFC2           10U
#define I2C_SCL        27U
#define I2C_SDA        26U

/* Our definitions */
#define SPI_SCK        25U
#define SPI_MOSI       24U
#define SPI_MISO       23U
#define SPI_SS         22U

/* Analog input */
#define AIN0            2U
#define AIN1            3U
#define AIN2            4U
#define AIN3            5U
#define AIN4           28U
#define AIN5           29U
#define AIN6           30U
#define AIN7           31U
#define AREF0         AIN0
#define AREF1         AIN1

/*
 * IO pins assignments.
 */
/* Defined by board */
#define IOPORT1_BTN1           13U
#define IOPORT1_BTN2           14U
#define IOPORT1_BTN3           15U
#define IOPORT1_BTN4           16U
#define IOPORT1_LED1           17U
#define IOPORT1_LED2           18U
#define IOPORT1_LED3           19U
#define IOPORT1_LED4           20U
#define IOPORT1_UART_RTS        5U
#define IOPORT1_UART_TX         6U
#define IOPORT1_UART_CTS        7U
#define IOPORT1_UART_RX         8U
#define IOPORT1_NFC1            9U
#define IOPORT1_NFC2           10U
#define IOPORT1_I2C_SCL        27U
#define IOPORT1_I2C_SDA        26U
#define IOPORT1_RESET          21U

/* Our definitions */
#define IOPORT1_SPI_SCK        25U
#define IOPORT1_SPI_MOSI       24U
#define IOPORT1_SPI_MISO       23U
#define IOPORT1_SPI_SS         22U

/* Analog inpupt */
#define IOPORT1_AIN0            2U
#define IOPORT1_AIN1            3U
#define IOPORT1_AIN2            4U
#define IOPORT1_AIN3            5U
#define IOPORT1_AIN4           28U
#define IOPORT1_AIN5           29U
#define IOPORT1_AIN6           30U
#define IOPORT1_AIN7           31U
#define IOPORT1_AREF0           IOPORT1_AIN0
#define IOPORT1_AREF1           IOPORT1_AIN1

/*
 * IO lines assignments.
 */
/* Board defined */
#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_NFC1      PAL_LINE(IOPORT1, IOPORT1_NFC1)
#define LINE_NFC2      PAL_LINE(IOPORT1, IOPORT1_NFC2)
#define LINE_I2C_SCL   PAL_LINE(IOPORT1, IOPORT1_I2C_SCL)
#define LINE_I2C_SDA   PAL_LINE(IOPORT1, IOPORT1_I2C_SDA)

/* Our definitions */
#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)

/* Analog line */
#define LINE_AIN0      PAL_LINE(IOPORT1, IOPORT1_AIN0)
#define LINE_AIN1      PAL_LINE(IOPORT1, IOPORT1_AIN1)
#define LINE_AIN2      PAL_LINE(IOPORT1, IOPORT1_AIN2)
#define LINE_AIN3      PAL_LINE(IOPORT1, IOPORT1_AIN3)
#define LINE_AIN4      PAL_LINE(IOPORT1, IOPORT1_AIN4)
#define LINE_AIN5      PAL_LINE(IOPORT1, IOPORT1_AIN5)
#define LINE_AIN6      PAL_LINE(IOPORT1, IOPORT1_AIN6)
#define LINE_AIN7      PAL_LINE(IOPORT1, IOPORT1_AIN7)
#define LINE_AREF0     PAL_LINE(IOPORT1, IOPORT1_AREF0)
#define LINE_AREF1     PAL_LINE(IOPORT1, IOPORT1_AREF1)

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

#endif /* _BOARD_H_ */