-
Notifications
You must be signed in to change notification settings - Fork 0
/
board.h
121 lines (100 loc) · 4.7 KB
/
board.h
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
#if !defined(__BOARD_H__)
#define __BOARD_H__
#include "pin_mux.h"
#include "rdc.h"
#include "rdc_defs_imx7d.h"
#include "ccm_imx7d.h"
#include "clock_freq.h"
#define VDEV0_VRING_BASE (0x9FF00000U)
#define VDEV1_VRING_BASE (0x9FF10000U)
/* The board name */
#define BOARD_NAME "IMX7D_PICO_M4"
#define DWARF_BOARD (0)
#define BOARD_DOMAIN_ID (1)
/* ADC information for this board */
#define BOARD_ADC_RDC_PDAP rdcPdapAdc1
#define BOARD_ADC_CCM_CCGR ccmCcgrGateAdc
#define BOARD_ADC_BASEADDR ADC1
#define BOARD_ADC_IRQ_NUM ADC1_IRQn
#define BOARD_ADC_HANDLER ADC1_Handler
#define BOARD_ADC_INPUT_CHANNEL (3)
/* WDOG information for this board */
#define BOARD_WDOG_RDC_PDAP rdcPdapWdog3
#define BOARD_WDOG_CCM_ROOT ccmRootWdog
#define BOARD_WDOG_CCM_CCGR ccmCcgrGateWdog3
#define BOARD_WDOG_BASEADDR WDOG3
#define BOARD_WDOG_IRQ_NUM WDOG3_IRQn
#define BOARD_WDOG_HANDLER WDOG3_Handler
/* SEMA4 information for this board */
#define BOARD_SEMA4_RDC_PDAP rdcPdapSemaphoreHs
#define BOARD_SEMA4_CCM_CCGR ccmCcgrGateSemaHs
#define BOARD_SEMA4_BASEADDR SEMA4
#define BOARD_SEMA4_IRQ_NUM SEMA4_HS_M4_IRQn
#define BOARD_SEMA4_HANDLER SEMA4_HS_M4_Handler
/* GPT instance A information for this board */
#define BOARD_GPTA_RDC_PDAP rdcPdapGpt3
#define BOARD_GPTA_CCM_ROOT ccmRootGpt3
#define BOARD_GPTA_CCM_CCGR ccmCcgrGateGpt3
#define BOARD_GPTA_BASEADDR GPT3
#define BOARD_GPTA_IRQ_NUM GPT3_IRQn
#define BOARD_GPTA_HANDLER GPT3_Handler
/* GPT instance B information for this board */
#define BOARD_GPTB_RDC_PDAP rdcPdapGpt4
#define BOARD_GPTB_CCM_ROOT ccmRootGpt4
#define BOARD_GPTB_CCM_CCGR ccmCcgrGateGpt4
#define BOARD_GPTB_BASEADDR GPT4
#define BOARD_GPTB_IRQ_NUM GPT4_IRQn
#define BOARD_GPTB_HANDLER GPT4_Handler
/* GPIO information for this board */
#define BOARD_GPIO_LED_CCM_CCGR ccmCcgrGateGpio2
#define BOARD_GPIO_LED_RDC_PDAP rdcPdapGpio2
#define BOARD_GPIO_LED_CONFIG (&gpioLed)
#if ( DWARF_BOARD == 1 )
#define BOARD_GPIO_SENSOR_CCM_CCGR ccmCcgrGateGpio2
#define BOARD_GPIO_SENSOR_RDC_PDAP rdcPdapGpio2
#define BOARD_GPIO_SENSOR_CONFIG (&gpioSensorInt)
#define BOARD_GPIO_SENSOR_IRQ_NUM GPIO2_INT15_0_IRQn
#define BOARD_GPIO_SENSOR_HANDLER GPIO2_INT15_0_Handler
#define BOARD_GPIO_GYR_CONFIG (&gpioGyrInt)
#define BOARD_GPIO_PRESSURE_CONFIG (&gpioPressureInt)
#endif // #if ( DWARF_BOARD == 1 )
/* Debug UART information for this board */
#define BOARD_DEBUG_UART_RDC_PDAP rdcPdapUart6
#define BOARD_DEBUG_UART_CCM_ROOT ccmRootUart6
#define BOARD_DEBUG_UART_CCM_CCGR ccmCcgrGateUart6
#define BOARD_DEBUG_UART_BASEADDR UART6
#define BOARD_DEBUG_UART_IRQ_NUM UART6_IRQn
#define BOARD_DEBUG_UART_HANDLER UART6_Handler
/* MU information for this board */
#define BOARD_MU_HANDLER MU_M4_Handler
#define BOARD_MU_IRQ_NUM MU_M4_IRQn
#define BOARD_MU_BASE_ADDR MUB
#define BOARD_MU_CCM_CCGR ccmCcgrGateMu
#define BOARD_MU_RDC_PDAP rdcPdapMuB
#if ( DWARF_BOARD == 1 )
/* I2C information for this board */
#define BOARD_I2C_RDC_PDAP rdcPdapI2c1
#define BOARD_I2C_CCM_ROOT ccmRootI2c1
#define BOARD_I2C_CCM_CCGR ccmCcgrGateI2c1
#define BOARD_I2C_BASEADDR I2C1
#define BOARD_I2C_IRQ_NUM I2C1_IRQn
#define BOARD_I2C_HANDLER I2C1_Handler
#define BOARD_I2C_FXAS21002_ADDR (0x21)
#define BOARD_I2C_FXOS8700_ADDR (0x1E)
#endif // #if ( DWARF_BOARD == 1 )
/* GPC information for this board*/
#define BOARD_GPC_BASEADDR GPC
/* SIM_WAKEUP CG information*/
#define BOARD_SIM_WAKEUP_CCGR ccmCcgrGateSimWakeup
#if defined(__cplusplus)
extern "C" {
#endif /* __cplusplus */
void hardware_init(void);
void dbg_uart_init(void);
/* Function to initialize clock base on board configuration. */
void BOARD_ClockInit(void);
void BOARD_RdcInit(void);
#if defined(__cplusplus)
}
#endif /* __cplusplus */
#endif /* __BOARD_H__ */