1 /*
2  * Copyright 2019 NXP
3  * All rights reserved.
4  *
5  * SPDX-License-Identifier: BSD-3-Clause
6  */
7 
8 #include <stdint.h>
9 #include "board.h"
10 #include "fsl_debug_console.h"
11 #include "fsl_common.h"
12 #include "fsl_port.h"
13 #if defined(SDK_I2C_BASED_COMPONENT_USED) && SDK_I2C_BASED_COMPONENT_USED
14 #include "fsl_i2c.h"
15 #endif /* SDK_I2C_BASED_COMPONENT_USED */
16 
17 /*******************************************************************************
18  * Variables
19  ******************************************************************************/
20 
21 /*******************************************************************************
22  * Code
23  ******************************************************************************/
24 /* Initialize debug console. */
BOARD_InitDebugConsole(void)25 void BOARD_InitDebugConsole(void)
26 {
27     uint32_t uartClkSrcFreq;
28     /* SIM_SOPT2[27:26]:
29      *  00: Clock Disabled
30      *  01: IRC48M
31      *  10: OSCERCLK
32      *  11: MCGIRCCLK
33      */
34     CLOCK_SetLpuart0Clock(1);
35 
36     uartClkSrcFreq = BOARD_DEBUG_UART_CLK_FREQ;
37 
38     DbgConsole_Init(BOARD_DEBUG_UART_INSTANCE, BOARD_DEBUG_UART_BAUDRATE, BOARD_DEBUG_UART_TYPE, uartClkSrcFreq);
39 }
40 #if defined(SDK_I2C_BASED_COMPONENT_USED) && SDK_I2C_BASED_COMPONENT_USED
BOARD_I2C_Init(I2C_Type * base,uint32_t clkSrc_Hz)41 void BOARD_I2C_Init(I2C_Type *base, uint32_t clkSrc_Hz)
42 {
43     i2c_master_config_t i2cConfig = {0};
44 
45     I2C_MasterGetDefaultConfig(&i2cConfig);
46     I2C_MasterInit(base, &i2cConfig, clkSrc_Hz);
47 }
48 
BOARD_I2C_Send(I2C_Type * base,uint8_t deviceAddress,uint32_t subAddress,uint8_t subaddressSize,uint8_t * txBuff,uint8_t txBuffSize)49 status_t BOARD_I2C_Send(I2C_Type *base,
50                         uint8_t deviceAddress,
51                         uint32_t subAddress,
52                         uint8_t subaddressSize,
53                         uint8_t *txBuff,
54                         uint8_t txBuffSize)
55 {
56     i2c_master_transfer_t masterXfer;
57 
58     /* Prepare transfer structure. */
59     masterXfer.slaveAddress   = deviceAddress;
60     masterXfer.direction      = kI2C_Write;
61     masterXfer.subaddress     = subAddress;
62     masterXfer.subaddressSize = subaddressSize;
63     masterXfer.data           = txBuff;
64     masterXfer.dataSize       = txBuffSize;
65     masterXfer.flags          = kI2C_TransferDefaultFlag;
66 
67     return I2C_MasterTransferBlocking(base, &masterXfer);
68 }
69 
BOARD_I2C_Receive(I2C_Type * base,uint8_t deviceAddress,uint32_t subAddress,uint8_t subaddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)70 status_t BOARD_I2C_Receive(I2C_Type *base,
71                            uint8_t deviceAddress,
72                            uint32_t subAddress,
73                            uint8_t subaddressSize,
74                            uint8_t *rxBuff,
75                            uint8_t rxBuffSize)
76 {
77     i2c_master_transfer_t masterXfer;
78 
79     /* Prepare transfer structure. */
80     masterXfer.slaveAddress   = deviceAddress;
81     masterXfer.subaddress     = subAddress;
82     masterXfer.subaddressSize = subaddressSize;
83     masterXfer.data           = rxBuff;
84     masterXfer.dataSize       = rxBuffSize;
85     masterXfer.direction      = kI2C_Read;
86     masterXfer.flags          = kI2C_TransferDefaultFlag;
87 
88     return I2C_MasterTransferBlocking(base, &masterXfer);
89 }
90 
BOARD_Accel_I2C_Init(void)91 void BOARD_Accel_I2C_Init(void)
92 {
93     BOARD_I2C_Init(BOARD_ACCEL_I2C_BASEADDR, BOARD_ACCEL_I2C_CLOCK_FREQ);
94 }
95 
BOARD_Accel_I2C_Send(uint8_t deviceAddress,uint32_t subAddress,uint8_t subaddressSize,uint32_t txBuff)96 status_t BOARD_Accel_I2C_Send(uint8_t deviceAddress, uint32_t subAddress, uint8_t subaddressSize, uint32_t txBuff)
97 {
98     uint8_t data = (uint8_t)txBuff;
99 
100     return BOARD_I2C_Send(BOARD_ACCEL_I2C_BASEADDR, deviceAddress, subAddress, subaddressSize, &data, 1);
101 }
102 
BOARD_Accel_I2C_Receive(uint8_t deviceAddress,uint32_t subAddress,uint8_t subaddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)103 status_t BOARD_Accel_I2C_Receive(
104     uint8_t deviceAddress, uint32_t subAddress, uint8_t subaddressSize, uint8_t *rxBuff, uint8_t rxBuffSize)
105 {
106     return BOARD_I2C_Receive(BOARD_ACCEL_I2C_BASEADDR, deviceAddress, subAddress, subaddressSize, rxBuff, rxBuffSize);
107 }
108 #endif /* SDK_I2C_BASED_COMPONENT_USED */
109 
110 /* SystemInitHook */
SystemInitHook(void)111 void SystemInitHook(void)
112 {
113     /* Disable the PTA1 interrupt to avoid the BOOTROM workaround issue */
114     NVIC_DisableIRQ(PORTA_IRQn);
115 
116     /* Clear pending flag */
117     NVIC_ClearPendingIRQ(PORTA_IRQn);
118 
119     /* Disable the I2C0 interrupt to avoid the BOOTROM workaround issue */
120     NVIC_DisableIRQ(I2C0_IRQn);
121 
122     /* Clear pending flag */
123     NVIC_ClearPendingIRQ(I2C0_IRQn);
124 }
125