1 /*
2 * Copyright 2018-2022 NXP
3 * All rights reserved.
4 *
5 * SPDX-License-Identifier: BSD-3-Clause
6 */
7
8 #include "fsl_common.h"
9 #include "fsl_debug_console.h"
10 #include "board.h"
11 #if defined(SDK_I2C_BASED_COMPONENT_USED) && SDK_I2C_BASED_COMPONENT_USED
12 #include "fsl_lpi2c.h"
13 #endif /* SDK_I2C_BASED_COMPONENT_USED */
14 #include "fsl_iomuxc.h"
15
16 /*******************************************************************************
17 * Variables
18 ******************************************************************************/
19 /*******************************************************************************
20 * Code
21 ******************************************************************************/
22
23 /* Get debug console frequency. */
BOARD_DebugConsoleSrcFreq(void)24 uint32_t BOARD_DebugConsoleSrcFreq(void)
25 {
26 #if DEBUG_CONSOLE_UART_INDEX == 1
27 return CLOCK_GetRootClockFreq(kCLOCK_Root_Lpuart1);
28 #elif DEBUG_CONSOLE_UART_INDEX == 12
29 return CLOCK_GetRootClockFreq(kCLOCK_Root_Lpuart12);
30 #else
31 return CLOCK_GetRootClockFreq(kCLOCK_Root_Lpuart2);
32 #endif
33 }
34
35 /* Initialize debug console. */
BOARD_InitDebugConsole(void)36 void BOARD_InitDebugConsole(void)
37 {
38 uint32_t uartClkSrcFreq = BOARD_DebugConsoleSrcFreq();
39 DbgConsole_Init(BOARD_DEBUG_UART_INSTANCE, BOARD_DEBUG_UART_BAUDRATE, BOARD_DEBUG_UART_TYPE, uartClkSrcFreq);
40 }
41
42 #if defined(SDK_I2C_BASED_COMPONENT_USED) && SDK_I2C_BASED_COMPONENT_USED
BOARD_LPI2C_Init(LPI2C_Type * base,uint32_t clkSrc_Hz)43 void BOARD_LPI2C_Init(LPI2C_Type *base, uint32_t clkSrc_Hz)
44 {
45 lpi2c_master_config_t lpi2cConfig = {0};
46
47 /*
48 * lpi2cConfig.debugEnable = false;
49 * lpi2cConfig.ignoreAck = false;
50 * lpi2cConfig.pinConfig = kLPI2C_2PinOpenDrain;
51 * lpi2cConfig.baudRate_Hz = 100000U;
52 * lpi2cConfig.busIdleTimeout_ns = 0;
53 * lpi2cConfig.pinLowTimeout_ns = 0;
54 * lpi2cConfig.sdaGlitchFilterWidth_ns = 0;
55 * lpi2cConfig.sclGlitchFilterWidth_ns = 0;
56 */
57 LPI2C_MasterGetDefaultConfig(&lpi2cConfig);
58 LPI2C_MasterInit(base, &lpi2cConfig, clkSrc_Hz);
59 }
60
BOARD_LPI2C_Send(LPI2C_Type * base,uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * txBuff,uint8_t txBuffSize)61 status_t BOARD_LPI2C_Send(LPI2C_Type *base,
62 uint8_t deviceAddress,
63 uint32_t subAddress,
64 uint8_t subAddressSize,
65 uint8_t *txBuff,
66 uint8_t txBuffSize)
67 {
68 lpi2c_master_transfer_t xfer;
69
70 xfer.flags = kLPI2C_TransferDefaultFlag;
71 xfer.slaveAddress = deviceAddress;
72 xfer.direction = kLPI2C_Write;
73 xfer.subaddress = subAddress;
74 xfer.subaddressSize = subAddressSize;
75 xfer.data = txBuff;
76 xfer.dataSize = txBuffSize;
77
78 return LPI2C_MasterTransferBlocking(base, &xfer);
79 }
80
BOARD_LPI2C_Receive(LPI2C_Type * base,uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)81 status_t BOARD_LPI2C_Receive(LPI2C_Type *base,
82 uint8_t deviceAddress,
83 uint32_t subAddress,
84 uint8_t subAddressSize,
85 uint8_t *rxBuff,
86 uint8_t rxBuffSize)
87 {
88 lpi2c_master_transfer_t xfer;
89
90 xfer.flags = kLPI2C_TransferDefaultFlag;
91 xfer.slaveAddress = deviceAddress;
92 xfer.direction = kLPI2C_Read;
93 xfer.subaddress = subAddress;
94 xfer.subaddressSize = subAddressSize;
95 xfer.data = rxBuff;
96 xfer.dataSize = rxBuffSize;
97
98 return LPI2C_MasterTransferBlocking(base, &xfer);
99 }
100
BOARD_LPI2C_SendSCCB(LPI2C_Type * base,uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * txBuff,uint8_t txBuffSize)101 status_t BOARD_LPI2C_SendSCCB(LPI2C_Type *base,
102 uint8_t deviceAddress,
103 uint32_t subAddress,
104 uint8_t subAddressSize,
105 uint8_t *txBuff,
106 uint8_t txBuffSize)
107 {
108 lpi2c_master_transfer_t xfer;
109
110 xfer.flags = kLPI2C_TransferDefaultFlag;
111 xfer.slaveAddress = deviceAddress;
112 xfer.direction = kLPI2C_Write;
113 xfer.subaddress = subAddress;
114 xfer.subaddressSize = subAddressSize;
115 xfer.data = txBuff;
116 xfer.dataSize = txBuffSize;
117
118 return LPI2C_MasterTransferBlocking(base, &xfer);
119 }
120
BOARD_LPI2C_ReceiveSCCB(LPI2C_Type * base,uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)121 status_t BOARD_LPI2C_ReceiveSCCB(LPI2C_Type *base,
122 uint8_t deviceAddress,
123 uint32_t subAddress,
124 uint8_t subAddressSize,
125 uint8_t *rxBuff,
126 uint8_t rxBuffSize)
127 {
128 status_t status;
129 lpi2c_master_transfer_t xfer;
130
131 xfer.flags = kLPI2C_TransferDefaultFlag;
132 xfer.slaveAddress = deviceAddress;
133 xfer.direction = kLPI2C_Write;
134 xfer.subaddress = subAddress;
135 xfer.subaddressSize = subAddressSize;
136 xfer.data = NULL;
137 xfer.dataSize = 0;
138
139 status = LPI2C_MasterTransferBlocking(base, &xfer);
140
141 if (kStatus_Success == status)
142 {
143 xfer.subaddressSize = 0;
144 xfer.direction = kLPI2C_Read;
145 xfer.data = rxBuff;
146 xfer.dataSize = rxBuffSize;
147
148 status = LPI2C_MasterTransferBlocking(base, &xfer);
149 }
150
151 return status;
152 }
153
BOARD_Accel_I2C_Init(void)154 void BOARD_Accel_I2C_Init(void)
155 {
156 BOARD_LPI2C_Init(BOARD_ACCEL_I2C_BASEADDR, BOARD_ACCEL_I2C_CLOCK_FREQ);
157 }
158
BOARD_Accel_I2C_Send(uint8_t deviceAddress,uint32_t subAddress,uint8_t subaddressSize,uint32_t txBuff)159 status_t BOARD_Accel_I2C_Send(uint8_t deviceAddress, uint32_t subAddress, uint8_t subaddressSize, uint32_t txBuff)
160 {
161 uint8_t data = (uint8_t)txBuff;
162
163 return BOARD_LPI2C_Send(BOARD_ACCEL_I2C_BASEADDR, deviceAddress, subAddress, subaddressSize, &data, 1);
164 }
165
BOARD_Accel_I2C_Receive(uint8_t deviceAddress,uint32_t subAddress,uint8_t subaddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)166 status_t BOARD_Accel_I2C_Receive(
167 uint8_t deviceAddress, uint32_t subAddress, uint8_t subaddressSize, uint8_t *rxBuff, uint8_t rxBuffSize)
168 {
169 return BOARD_LPI2C_Receive(BOARD_ACCEL_I2C_BASEADDR, deviceAddress, subAddress, subaddressSize, rxBuff, rxBuffSize);
170 }
171
BOARD_Codec_I2C_Init(void)172 void BOARD_Codec_I2C_Init(void)
173 {
174 BOARD_LPI2C_Init(BOARD_CODEC_I2C_BASEADDR, BOARD_CODEC_I2C_CLOCK_FREQ);
175 }
176
BOARD_Codec_I2C_Send(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,const uint8_t * txBuff,uint8_t txBuffSize)177 status_t BOARD_Codec_I2C_Send(
178 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, const uint8_t *txBuff, uint8_t txBuffSize)
179 {
180 return BOARD_LPI2C_Send(BOARD_CODEC_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize, (uint8_t *)txBuff,
181 txBuffSize);
182 }
183
BOARD_Codec_I2C_Receive(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)184 status_t BOARD_Codec_I2C_Receive(
185 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, uint8_t *rxBuff, uint8_t rxBuffSize)
186 {
187 return BOARD_LPI2C_Receive(BOARD_CODEC_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize, rxBuff, rxBuffSize);
188 }
189
BOARD_Camera_I2C_Init(void)190 void BOARD_Camera_I2C_Init(void)
191 {
192 const clock_root_config_t lpi2cClockConfig = {
193 .clockOff = false,
194 .mux = BOARD_CAMERA_I2C_CLOCK_SOURCE,
195 .div = BOARD_CAMERA_I2C_CLOCK_DIVIDER,
196 };
197
198 CLOCK_SetRootClock(BOARD_CAMERA_I2C_CLOCK_ROOT, &lpi2cClockConfig);
199
200 BOARD_LPI2C_Init(BOARD_CAMERA_I2C_BASEADDR, CLOCK_GetRootClockFreq(BOARD_CAMERA_I2C_CLOCK_ROOT));
201 }
202
BOARD_Camera_I2C_Send(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,const uint8_t * txBuff,uint8_t txBuffSize)203 status_t BOARD_Camera_I2C_Send(
204 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, const uint8_t *txBuff, uint8_t txBuffSize)
205 {
206 return BOARD_LPI2C_Send(BOARD_CAMERA_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize, (uint8_t *)txBuff,
207 txBuffSize);
208 }
209
BOARD_Camera_I2C_Receive(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)210 status_t BOARD_Camera_I2C_Receive(
211 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, uint8_t *rxBuff, uint8_t rxBuffSize)
212 {
213 return BOARD_LPI2C_Receive(BOARD_CAMERA_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize, rxBuff,
214 rxBuffSize);
215 }
216
BOARD_Camera_I2C_SendSCCB(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,const uint8_t * txBuff,uint8_t txBuffSize)217 status_t BOARD_Camera_I2C_SendSCCB(
218 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, const uint8_t *txBuff, uint8_t txBuffSize)
219 {
220 return BOARD_LPI2C_SendSCCB(BOARD_CAMERA_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize, (uint8_t *)txBuff,
221 txBuffSize);
222 }
223
BOARD_Camera_I2C_ReceiveSCCB(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)224 status_t BOARD_Camera_I2C_ReceiveSCCB(
225 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, uint8_t *rxBuff, uint8_t rxBuffSize)
226 {
227 return BOARD_LPI2C_ReceiveSCCB(BOARD_CAMERA_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize, rxBuff,
228 rxBuffSize);
229 }
230
BOARD_MIPIPanelTouch_I2C_Init(void)231 void BOARD_MIPIPanelTouch_I2C_Init(void)
232 {
233 const clock_root_config_t lpi2cClockConfig = {
234 .clockOff = false,
235 .mux = BOARD_MIPI_PANEL_TOUCH_I2C_CLOCK_SOURCE,
236 .div = BOARD_MIPI_PANEL_TOUCH_I2C_CLOCK_DIVIDER,
237 };
238
239 CLOCK_SetRootClock(BOARD_MIPI_PANEL_TOUCH_I2C_CLOCK_ROOT, &lpi2cClockConfig);
240
241 BOARD_LPI2C_Init(BOARD_MIPI_PANEL_TOUCH_I2C_BASEADDR,
242 CLOCK_GetRootClockFreq(BOARD_MIPI_PANEL_TOUCH_I2C_CLOCK_ROOT));
243 }
244
BOARD_MIPIPanelTouch_I2C_Send(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,const uint8_t * txBuff,uint8_t txBuffSize)245 status_t BOARD_MIPIPanelTouch_I2C_Send(
246 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, const uint8_t *txBuff, uint8_t txBuffSize)
247 {
248 return BOARD_LPI2C_Send(BOARD_MIPI_PANEL_TOUCH_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize,
249 (uint8_t *)txBuff, txBuffSize);
250 }
251
BOARD_MIPIPanelTouch_I2C_Receive(uint8_t deviceAddress,uint32_t subAddress,uint8_t subAddressSize,uint8_t * rxBuff,uint8_t rxBuffSize)252 status_t BOARD_MIPIPanelTouch_I2C_Receive(
253 uint8_t deviceAddress, uint32_t subAddress, uint8_t subAddressSize, uint8_t *rxBuff, uint8_t rxBuffSize)
254 {
255 return BOARD_LPI2C_Receive(BOARD_MIPI_PANEL_TOUCH_I2C_BASEADDR, deviceAddress, subAddress, subAddressSize, rxBuff,
256 rxBuffSize);
257 }
258 #endif /* SDK_I2C_BASED_COMPONENT_USED */
259
260 /* MPU configuration. */
261 #if __CORTEX_M == 7
BOARD_ConfigMPU(void)262 void BOARD_ConfigMPU(void)
263 {
264 #if defined(__CC_ARM) || defined(__ARMCC_VERSION)
265 extern uint32_t Image$$RW_m_ncache$$Base[];
266 /* RW_m_ncache_unused is a auxiliary region which is used to get the whole size of noncache section */
267 extern uint32_t Image$$RW_m_ncache_unused$$Base[];
268 extern uint32_t Image$$RW_m_ncache_unused$$ZI$$Limit[];
269 uint32_t nonCacheStart = (uint32_t)Image$$RW_m_ncache$$Base;
270 uint32_t size = ((uint32_t)Image$$RW_m_ncache_unused$$Base == nonCacheStart) ?
271 0 :
272 ((uint32_t)Image$$RW_m_ncache_unused$$ZI$$Limit - nonCacheStart);
273 #elif defined(__MCUXPRESSO)
274 #if defined(__USE_SHMEM)
275 extern uint32_t __base_rpmsg_sh_mem;
276 extern uint32_t __top_rpmsg_sh_mem;
277 uint32_t nonCacheStart = (uint32_t)(&__base_rpmsg_sh_mem);
278 uint32_t size = (uint32_t)(&__top_rpmsg_sh_mem) - nonCacheStart;
279 #else
280 extern uint32_t __base_NCACHE_REGION;
281 extern uint32_t __top_NCACHE_REGION;
282 uint32_t nonCacheStart = (uint32_t)(&__base_NCACHE_REGION);
283 uint32_t size = (uint32_t)(&__top_NCACHE_REGION) - nonCacheStart;
284 #endif
285 #elif defined(__ICCARM__) || defined(__GNUC__)
286 extern uint32_t __NCACHE_REGION_START[];
287 extern uint32_t __NCACHE_REGION_SIZE[];
288 uint32_t nonCacheStart = (uint32_t)__NCACHE_REGION_START;
289 uint32_t size = (uint32_t)__NCACHE_REGION_SIZE;
290 #endif
291 volatile uint32_t i = 0;
292
293 #if defined(__ICACHE_PRESENT) && __ICACHE_PRESENT
294 /* Disable I cache and D cache */
295 if (SCB_CCR_IC_Msk == (SCB_CCR_IC_Msk & SCB->CCR))
296 {
297 SCB_DisableICache();
298 }
299 #endif
300 #if defined(__DCACHE_PRESENT) && __DCACHE_PRESENT
301 if (SCB_CCR_DC_Msk == (SCB_CCR_DC_Msk & SCB->CCR))
302 {
303 SCB_DisableDCache();
304 }
305 #endif
306
307 /* Disable MPU */
308 ARM_MPU_Disable();
309
310 /* MPU configure:
311 * Use ARM_MPU_RASR(DisableExec, AccessPermission, TypeExtField, IsShareable, IsCacheable, IsBufferable,
312 * SubRegionDisable, Size)
313 * API in mpu_armv7.h.
314 * param DisableExec Instruction access (XN) disable bit,0=instruction fetches enabled, 1=instruction fetches
315 * disabled.
316 * param AccessPermission Data access permissions, allows you to configure read/write access for User and
317 * Privileged mode.
318 * Use MACROS defined in mpu_armv7.h:
319 * ARM_MPU_AP_NONE/ARM_MPU_AP_PRIV/ARM_MPU_AP_URO/ARM_MPU_AP_FULL/ARM_MPU_AP_PRO/ARM_MPU_AP_RO
320 * Combine TypeExtField/IsShareable/IsCacheable/IsBufferable to configure MPU memory access attributes.
321 * TypeExtField IsShareable IsCacheable IsBufferable Memory Attribute Shareability Cache
322 * 0 x 0 0 Strongly Ordered shareable
323 * 0 x 0 1 Device shareable
324 * 0 0 1 0 Normal not shareable Outer and inner write
325 * through no write allocate
326 * 0 0 1 1 Normal not shareable Outer and inner write
327 * back no write allocate
328 * 0 1 1 0 Normal shareable Outer and inner write
329 * through no write allocate
330 * 0 1 1 1 Normal shareable Outer and inner write
331 * back no write allocate
332 * 1 0 0 0 Normal not shareable outer and inner
333 * noncache
334 * 1 1 0 0 Normal shareable outer and inner
335 * noncache
336 * 1 0 1 1 Normal not shareable outer and inner write
337 * back write/read acllocate
338 * 1 1 1 1 Normal shareable outer and inner write
339 * back write/read acllocate
340 * 2 x 0 0 Device not shareable
341 * Above are normal use settings, if your want to see more details or want to config different inner/outter cache
342 * policy.
343 * please refer to Table 4-55 /4-56 in arm cortex-M7 generic user guide <dui0646b_cortex_m7_dgug.pdf>
344 * param SubRegionDisable Sub-region disable field. 0=sub-region is enabled, 1=sub-region is disabled.
345 * param Size Region size of the region to be configured. use ARM_MPU_REGION_SIZE_xxx MACRO in
346 * mpu_armv7.h.
347 */
348
349 /*
350 * Add default region to deny access to whole address space to workaround speculative prefetch.
351 * Refer to Arm errata 1013783-B for more details.
352 *
353 */
354 /* Region 0 setting: Instruction access disabled, No data access permission. */
355 MPU->RBAR = ARM_MPU_RBAR(0, 0x00000000U);
356 MPU->RASR = ARM_MPU_RASR(1, ARM_MPU_AP_NONE, 0, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_4GB);
357
358 /* Region 1 setting: Memory with Device type, not shareable, non-cacheable. */
359 MPU->RBAR = ARM_MPU_RBAR(1, 0x80000000U);
360 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_512MB);
361
362 /* Region 2 setting: Memory with Device type, not shareable, non-cacheable. */
363 MPU->RBAR = ARM_MPU_RBAR(2, 0x60000000U);
364 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_512MB);
365
366 /* Region 3 setting: Memory with Device type, not shareable, non-cacheable. */
367 MPU->RBAR = ARM_MPU_RBAR(3, 0x00000000U);
368 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_1GB);
369
370 /* Region 4 setting: Memory with Normal type, not shareable, outer/inner write back */
371 MPU->RBAR = ARM_MPU_RBAR(4, 0x00000000U);
372 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 1, 0, ARM_MPU_REGION_SIZE_256KB);
373
374 /* Region 5 setting: Memory with Normal type, not shareable, outer/inner write back */
375 MPU->RBAR = ARM_MPU_RBAR(5, 0x20000000U);
376 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 1, 0, ARM_MPU_REGION_SIZE_256KB);
377
378 #if defined(CACHE_MODE_WRITE_THROUGH) && CACHE_MODE_WRITE_THROUGH
379 /* Region 6 setting: Memory with Normal type, not shareable, write through */
380 MPU->RBAR = ARM_MPU_RBAR(6, 0x20200000U);
381 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 0, 0, ARM_MPU_REGION_SIZE_1MB);
382
383 /* Region 7 setting: Memory with Normal type, not shareable, write trough */
384 MPU->RBAR = ARM_MPU_RBAR(7, 0x20300000U);
385 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 0, 0, ARM_MPU_REGION_SIZE_512KB);
386 #else
387 /* Region 6 setting: Memory with Normal type, not shareable, outer/inner write back */
388 MPU->RBAR = ARM_MPU_RBAR(6, 0x20200000U);
389 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 1, 0, ARM_MPU_REGION_SIZE_1MB);
390
391 /* Region 7 setting: Memory with Normal type, not shareable, outer/inner write back */
392 MPU->RBAR = ARM_MPU_RBAR(7, 0x20300000U);
393 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 1, 0, ARM_MPU_REGION_SIZE_512KB);
394 #endif
395
396 #if defined(XIP_EXTERNAL_FLASH) && (XIP_EXTERNAL_FLASH == 1)
397 /* Region 8 setting: Memory with Normal type, not shareable, outer/inner write back. */
398 MPU->RBAR = ARM_MPU_RBAR(8, 0x30000000U);
399 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_RO, 0, 0, 1, 1, 0, ARM_MPU_REGION_SIZE_16MB);
400 #endif
401
402 #ifdef USE_SDRAM
403 #if defined(CACHE_MODE_WRITE_THROUGH) && CACHE_MODE_WRITE_THROUGH
404 /* Region 9 setting: Memory with Normal type, not shareable, write trough */
405 MPU->RBAR = ARM_MPU_RBAR(9, 0x80000000U);
406 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 0, 0, ARM_MPU_REGION_SIZE_64MB);
407 #else
408 /* Region 9 setting: Memory with Normal type, not shareable, outer/inner write back */
409 MPU->RBAR = ARM_MPU_RBAR(9, 0x80000000U);
410 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 1, 0, ARM_MPU_REGION_SIZE_64MB);
411 #endif
412 #endif
413
414 while ((size >> i) > 0x1U)
415 {
416 i++;
417 }
418
419 if (i != 0)
420 {
421 /* The MPU region size should be 2^N, 5<=N<=32, region base should be multiples of size. */
422 assert(!(nonCacheStart % size));
423 assert(size == (uint32_t)(1 << i));
424 assert(i >= 5);
425
426 /* Region 10 setting: Memory with Normal type, not shareable, non-cacheable */
427 MPU->RBAR = ARM_MPU_RBAR(10, nonCacheStart);
428 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 1, 0, 0, 0, 0, i - 1);
429 }
430
431 /* Region 11 setting: Memory with Device type, not shareable, non-cacheable */
432 MPU->RBAR = ARM_MPU_RBAR(11, 0x40000000);
433 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_16MB);
434
435 /* Region 12 setting: Memory with Device type, not shareable, non-cacheable */
436 MPU->RBAR = ARM_MPU_RBAR(12, 0x41000000);
437 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_2MB);
438
439 /* Region 13 setting: Memory with Device type, not shareable, non-cacheable */
440 MPU->RBAR = ARM_MPU_RBAR(13, 0x41400000);
441 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_1MB);
442
443 /* Region 14 setting: Memory with Device type, not shareable, non-cacheable */
444 MPU->RBAR = ARM_MPU_RBAR(14, 0x41800000);
445 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_2MB);
446
447 /* Region 15 setting: Memory with Device type, not shareable, non-cacheable */
448 MPU->RBAR = ARM_MPU_RBAR(15, 0x42000000);
449 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, ARM_MPU_REGION_SIZE_1MB);
450
451 /* Enable MPU */
452 ARM_MPU_Enable(MPU_CTRL_PRIVDEFENA_Msk | MPU_CTRL_HFNMIENA_Msk);
453
454 /* Enable I cache and D cache */
455 #if defined(__DCACHE_PRESENT) && __DCACHE_PRESENT
456 SCB_EnableDCache();
457 #endif
458 #if defined(__ICACHE_PRESENT) && __ICACHE_PRESENT
459 SCB_EnableICache();
460 #endif
461 }
462 #elif __CORTEX_M == 4
BOARD_ConfigMPU(void)463 void BOARD_ConfigMPU(void)
464 {
465 #if defined(__CC_ARM) || defined(__ARMCC_VERSION)
466 extern uint32_t Image$$RW_m_ncache$$Base[];
467 /* RW_m_ncache_unused is a auxiliary region which is used to get the whole size of noncache section */
468 extern uint32_t Image$$RW_m_ncache_unused$$Base[];
469 extern uint32_t Image$$RW_m_ncache_unused$$ZI$$Limit[];
470 uint32_t nonCacheStart = (uint32_t)Image$$RW_m_ncache$$Base;
471 uint32_t nonCacheSize = ((uint32_t)Image$$RW_m_ncache_unused$$Base == nonCacheStart) ?
472 0 :
473 ((uint32_t)Image$$RW_m_ncache_unused$$ZI$$Limit - nonCacheStart);
474 #elif defined(__MCUXPRESSO)
475 extern uint32_t __base_NCACHE_REGION;
476 extern uint32_t __top_NCACHE_REGION;
477 uint32_t nonCacheStart = (uint32_t)(&__base_NCACHE_REGION);
478 uint32_t nonCacheSize = (uint32_t)(&__top_NCACHE_REGION) - nonCacheStart;
479 #elif defined(__ICCARM__) || defined(__GNUC__)
480 extern uint32_t __NCACHE_REGION_START[];
481 extern uint32_t __NCACHE_REGION_SIZE[];
482 uint32_t nonCacheStart = (uint32_t)__NCACHE_REGION_START;
483 uint32_t nonCacheSize = (uint32_t)__NCACHE_REGION_SIZE;
484 #endif
485 #if defined(__USE_SHMEM)
486 #if defined(__CC_ARM) || defined(__ARMCC_VERSION)
487 extern uint32_t Image$$RPMSG_SH_MEM$$Base[];
488 /* RPMSG_SH_MEM_unused is a auxiliary region which is used to get the whole size of RPMSG_SH_MEM section */
489 extern uint32_t Image$$RPMSG_SH_MEM_unused$$Base[];
490 extern uint32_t Image$$RPMSG_SH_MEM_unused$$ZI$$Limit[];
491 uint32_t rpmsgShmemStart = (uint32_t)Image$$RPMSG_SH_MEM$$Base;
492 uint32_t rpmsgShmemSize = (uint32_t)Image$$RPMSG_SH_MEM_unused$$ZI$$Limit - rpmsgShmemStart;
493 #elif defined(__MCUXPRESSO)
494 extern uint32_t __base_rpmsg_sh_mem;
495 extern uint32_t __top_rpmsg_sh_mem;
496 uint32_t rpmsgShmemStart = (uint32_t)(&__base_rpmsg_sh_mem);
497 uint32_t rpmsgShmemSize = (uint32_t)(&__top_rpmsg_sh_mem) - rpmsgShmemStart;
498 #elif defined(__ICCARM__) || defined(__GNUC__)
499 extern uint32_t __RPMSG_SH_MEM_START[];
500 extern uint32_t __RPMSG_SH_MEM_SIZE[];
501 uint32_t rpmsgShmemStart = (uint32_t)__RPMSG_SH_MEM_START;
502 uint32_t rpmsgShmemSize = (uint32_t)__RPMSG_SH_MEM_SIZE;
503 #endif
504 #endif
505 uint32_t i = 0;
506
507 /* Only config non-cacheable region on system bus */
508 assert(nonCacheStart >= 0x20000000);
509
510 /* Disable code bus cache */
511 if (LMEM_PCCCR_ENCACHE_MASK == (LMEM_PCCCR_ENCACHE_MASK & LMEM->PCCCR))
512 {
513 /* Enable the processor code bus to push all modified lines. */
514 LMEM->PCCCR |= LMEM_PCCCR_PUSHW0_MASK | LMEM_PCCCR_PUSHW1_MASK | LMEM_PCCCR_GO_MASK;
515 /* Wait until the cache command completes. */
516 while ((LMEM->PCCCR & LMEM_PCCCR_GO_MASK) != 0U)
517 {
518 }
519 /* As a precaution clear the bits to avoid inadvertently re-running this command. */
520 LMEM->PCCCR &= ~(LMEM_PCCCR_PUSHW0_MASK | LMEM_PCCCR_PUSHW1_MASK);
521 /* Now disable the cache. */
522 LMEM->PCCCR &= ~LMEM_PCCCR_ENCACHE_MASK;
523 }
524
525 /* Disable system bus cache */
526 if (LMEM_PSCCR_ENCACHE_MASK == (LMEM_PSCCR_ENCACHE_MASK & LMEM->PSCCR))
527 {
528 /* Enable the processor system bus to push all modified lines. */
529 LMEM->PSCCR |= LMEM_PSCCR_PUSHW0_MASK | LMEM_PSCCR_PUSHW1_MASK | LMEM_PSCCR_GO_MASK;
530 /* Wait until the cache command completes. */
531 while ((LMEM->PSCCR & LMEM_PSCCR_GO_MASK) != 0U)
532 {
533 }
534 /* As a precaution clear the bits to avoid inadvertently re-running this command. */
535 LMEM->PSCCR &= ~(LMEM_PSCCR_PUSHW0_MASK | LMEM_PSCCR_PUSHW1_MASK);
536 /* Now disable the cache. */
537 LMEM->PSCCR &= ~LMEM_PSCCR_ENCACHE_MASK;
538 }
539
540 /* Disable MPU */
541 ARM_MPU_Disable();
542
543 #if defined(CACHE_MODE_WRITE_THROUGH) && CACHE_MODE_WRITE_THROUGH
544 /* Region 0 setting: Memory with Normal type, not shareable, write trough */
545 MPU->RBAR = ARM_MPU_RBAR(0, 0x20200000U);
546 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 0, 0, ARM_MPU_REGION_SIZE_1MB);
547
548 /* Region 1 setting: Memory with Normal type, not shareable, write through */
549 MPU->RBAR = ARM_MPU_RBAR(1, 0x20300000U);
550 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 0, 0, ARM_MPU_REGION_SIZE_512KB);
551
552 /* Region 2 setting: Memory with Normal type, not shareable, write through */
553 MPU->RBAR = ARM_MPU_RBAR(2, 0x80000000U);
554 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 0, 0, ARM_MPU_REGION_SIZE_64MB);
555
556 while ((nonCacheSize >> i) > 0x1U)
557 {
558 i++;
559 }
560
561 if (i != 0)
562 {
563 /* The MPU region size should be 2^N, 5<=N<=32, region base should be multiples of size. */
564 assert(!(nonCacheStart % nonCacheSize));
565 assert(nonCacheSize == (uint32_t)(1 << i));
566 assert(i >= 5);
567
568 /* Region 3 setting: Memory with device type, not shareable, non-cacheable */
569 MPU->RBAR = ARM_MPU_RBAR(3, nonCacheStart);
570 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, i - 1);
571 }
572
573 #if defined(__USE_SHMEM)
574 i = 0;
575
576 while ((rpmsgShmemSize >> i) > 0x1U)
577 {
578 i++;
579 }
580
581 if (i != 0)
582 {
583 /* The MPU region size should be 2^N, 5<=N<=32, region base should be multiples of size. */
584 assert(!(rpmsgShmemStart % rpmsgShmemSize));
585 assert(rpmsgShmemSize == (uint32_t)(1 << i));
586 assert(i >= 5);
587
588 /* Region 4 setting: Memory with device type, not shareable, non-cacheable */
589 MPU->RBAR = ARM_MPU_RBAR(4, rpmsgShmemStart);
590 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, i - 1);
591 }
592 #endif
593 #else
594 while ((nonCacheSize >> i) > 0x1U)
595 {
596 i++;
597 }
598
599 if (i != 0)
600 {
601 /* The MPU region size should be 2^N, 5<=N<=32, region base should be multiples of size. */
602 assert(!(nonCacheStart % nonCacheSize));
603 assert(nonCacheSize == (uint32_t)(1 << i));
604 assert(i >= 5);
605
606 /* Region 0 setting: Memory with device type, not shareable, non-cacheable */
607 MPU->RBAR = ARM_MPU_RBAR(0, nonCacheStart);
608 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, i - 1);
609 }
610
611 #if defined(__USE_SHMEM)
612 i = 0;
613
614 while ((rpmsgShmemSize >> i) > 0x1U)
615 {
616 i++;
617 }
618
619 if (i != 0)
620 {
621 /* The MPU region size should be 2^N, 5<=N<=32, region base should be multiples of size. */
622 assert(!(rpmsgShmemStart % rpmsgShmemSize));
623 assert(rpmsgShmemSize == (uint32_t)(1 << i));
624 assert(i >= 5);
625
626 /* Region 1 setting: Memory with device type, not shareable, non-cacheable */
627 MPU->RBAR = ARM_MPU_RBAR(1, rpmsgShmemStart);
628 MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 2, 0, 0, 0, 0, i - 1);
629 }
630 #endif
631 #endif
632
633 /* Enable MPU */
634 ARM_MPU_Enable(MPU_CTRL_PRIVDEFENA_Msk | MPU_CTRL_HFNMIENA_Msk);
635
636 /* Enables the processor system bus to invalidate all lines in both ways.
637 and Initiate the processor system bus cache command. */
638 LMEM->PSCCR |= LMEM_PSCCR_INVW0_MASK | LMEM_PSCCR_INVW1_MASK | LMEM_PSCCR_GO_MASK;
639 /* Wait until the cache command completes */
640 while ((LMEM->PSCCR & LMEM_PSCCR_GO_MASK) != 0U)
641 {
642 }
643 /* As a precaution clear the bits to avoid inadvertently re-running this command. */
644 LMEM->PSCCR &= ~(LMEM_PSCCR_INVW0_MASK | LMEM_PSCCR_INVW1_MASK);
645 /* Now enable the system bus cache. */
646 LMEM->PSCCR |= LMEM_PSCCR_ENCACHE_MASK;
647
648 /* Enables the processor code bus to invalidate all lines in both ways.
649 and Initiate the processor code bus code cache command. */
650 LMEM->PCCCR |= LMEM_PCCCR_INVW0_MASK | LMEM_PCCCR_INVW1_MASK | LMEM_PCCCR_GO_MASK;
651 /* Wait until the cache command completes. */
652 while ((LMEM->PCCCR & LMEM_PCCCR_GO_MASK) != 0U)
653 {
654 }
655 /* As a precaution clear the bits to avoid inadvertently re-running this command. */
656 LMEM->PCCCR &= ~(LMEM_PCCCR_INVW0_MASK | LMEM_PCCCR_INVW1_MASK);
657 /* Now enable the code bus cache. */
658 LMEM->PCCCR |= LMEM_PCCCR_ENCACHE_MASK;
659 }
660 #endif
661
BOARD_SD_Pin_Config(uint32_t speed,uint32_t strength)662 void BOARD_SD_Pin_Config(uint32_t speed, uint32_t strength)
663 {
664 }
665
BOARD_MMC_Pin_Config(uint32_t speed,uint32_t strength)666 void BOARD_MMC_Pin_Config(uint32_t speed, uint32_t strength)
667 {
668 }
669