1 /*
2  * Copyright 2017-2023 NXP
3  * All rights reserved.
4  *
5  * SPDX-License-Identifier: BSD-3-Clause
6  */
7 #ifndef FSL_SEMC_H_
8 #define FSL_SEMC_H_
9 
10 #include "fsl_common.h"
11 
12 /*!
13  * @addtogroup semc
14  * @{
15  */
16 
17 /*******************************************************************************
18  * Definitions
19  ******************************************************************************/
20 
21 /*! @name Driver version */
22 /*! @{ */
23 /*! @brief SEMC driver version. */
24 #define FSL_SEMC_DRIVER_VERSION (MAKE_VERSION(2, 7, 0))
25 /*! @} */
26 
27 /*! @brief SEMC status, _semc_status. */
28 enum
29 {
30     kStatus_SEMC_InvalidDeviceType        = MAKE_STATUS(kStatusGroup_SEMC, 0), /*!< Invalid device type. */
31     kStatus_SEMC_IpCommandExecutionError  = MAKE_STATUS(kStatusGroup_SEMC, 1), /*!< IP command execution error. */
32     kStatus_SEMC_AxiCommandExecutionError = MAKE_STATUS(kStatusGroup_SEMC, 2), /*!< AXI command execution error. */
33     kStatus_SEMC_InvalidMemorySize        = MAKE_STATUS(kStatusGroup_SEMC, 3), /*!< Invalid memory sie. */
34     kStatus_SEMC_InvalidIpcmdDataSize     = MAKE_STATUS(kStatusGroup_SEMC, 4), /*!< Invalid IP command data size. */
35     kStatus_SEMC_InvalidAddressPortWidth  = MAKE_STATUS(kStatusGroup_SEMC, 5), /*!< Invalid address port width. */
36     kStatus_SEMC_InvalidDataPortWidth     = MAKE_STATUS(kStatusGroup_SEMC, 6), /*!< Invalid data port width. */
37     kStatus_SEMC_InvalidSwPinmuxSelection = MAKE_STATUS(kStatusGroup_SEMC, 7), /*!< Invalid SW pinmux selection. */
38     kStatus_SEMC_InvalidBurstLength       = MAKE_STATUS(kStatusGroup_SEMC, 8), /*!< Invalid burst length */
39     /*! Invalid column address bit width. */
40     kStatus_SEMC_InvalidColumnAddressBitWidth = MAKE_STATUS(kStatusGroup_SEMC, 9),
41     kStatus_SEMC_InvalidBaseAddress           = MAKE_STATUS(kStatusGroup_SEMC, 10), /*!< Invalid base address. */
42     kStatus_SEMC_InvalidTimerSetting          = MAKE_STATUS(kStatusGroup_SEMC, 11), /*!< Invalid timer setting. */
43 };
44 
45 /*! @brief SEMC memory device type. */
46 typedef enum _semc_mem_type
47 {
48     kSEMC_MemType_SDRAM = 0, /*!< SDRAM */
49     kSEMC_MemType_SRAM,      /*!< SRAM */
50     kSEMC_MemType_NOR,       /*!< NOR */
51     kSEMC_MemType_NAND,      /*!< NAND */
52     kSEMC_MemType_8080       /*!< 8080. */
53 } semc_mem_type_t;
54 
55 /*! @brief SEMC WAIT/RDY polarity. */
56 typedef enum _semc_waitready_polarity
57 {
58     kSEMC_LowActive = 0, /*!< Low active. */
59     kSEMC_HighActive,    /*!< High active. */
60 } semc_waitready_polarity_t;
61 
62 /*! @brief SEMC SDRAM Chip selection . */
63 typedef enum _semc_sdram_cs
64 {
65     kSEMC_SDRAM_CS0 = 0, /*!< SEMC SDRAM CS0. */
66     kSEMC_SDRAM_CS1,     /*!< SEMC SDRAM CS1. */
67     kSEMC_SDRAM_CS2,     /*!< SEMC SDRAM CS2. */
68     kSEMC_SDRAM_CS3      /*!< SEMC SDRAM CS3. */
69 } semc_sdram_cs_t;
70 
71 /*! @brief SEMC SRAM Chip selection . */
72 typedef enum _semc_sram_cs
73 {
74 #if defined(FSL_FEATURE_SEMC_SUPPORT_SRAM_COUNT) && (FSL_FEATURE_SEMC_SUPPORT_SRAM_COUNT == 0x04U)
75     kSEMC_SRAM_CS0 = 0, /*!< SEMC SRAM CS0. */
76     kSEMC_SRAM_CS1,     /*!< SEMC SRAM CS1. */
77     kSEMC_SRAM_CS2,     /*!< SEMC SRAM CS2. */
78     kSEMC_SRAM_CS3      /*!< SEMC SRAM CS3. */
79 #else
80     kSEMC_SRAM_CS0        = 0, /*!< SEMC SRAM CS0. */
81 #endif /* FSL_FEATURE_SEMC_SUPPORT_SRAM_COUNT */
82 } semc_sram_cs_t;
83 
84 /*! @brief SEMC NAND device type. */
85 typedef enum _semc_nand_access_type
86 {
87     kSEMC_NAND_ACCESS_BY_AXI = 0, /*!< Access to NAND flash by AXI bus. */
88     kSEMC_NAND_ACCESS_BY_IPCMD,   /*!< Access to NAND flash by IP bus. */
89 } semc_nand_access_type_t;
90 
91 /*! @brief SEMC interrupts . */
92 typedef enum _semc_interrupt_enable
93 {
94     kSEMC_IPCmdDoneInterrupt = SEMC_INTEN_IPCMDDONEEN_MASK, /*!< Ip command done interrupt. */
95     kSEMC_IPCmdErrInterrupt  = SEMC_INTEN_IPCMDERREN_MASK,  /*!< Ip command error interrupt. */
96     kSEMC_AXICmdErrInterrupt = SEMC_INTEN_AXICMDERREN_MASK, /*!< AXI command error interrupt. */
97     kSEMC_AXIBusErrInterrupt = SEMC_INTEN_AXIBUSERREN_MASK  /*!< AXI bus error interrupt. */
98 } semc_interrupt_enable_t;
99 
100 /*! @brief SEMC IP command data size in bytes. */
101 typedef enum _semc_ipcmd_datasize
102 {
103     kSEMC_IPcmdDataSize_1bytes = 1, /*!< The IP command data size 1 byte. */
104     kSEMC_IPcmdDataSize_2bytes,     /*!< The IP command data size 2 byte. */
105     kSEMC_IPcmdDataSize_3bytes,     /*!< The IP command data size 3 byte. */
106     kSEMC_IPcmdDataSize_4bytes      /*!< The IP command data size 4 byte. */
107 } semc_ipcmd_datasize_t;
108 
109 /*! @brief SEMC auto-refresh timing. */
110 typedef enum _semc_refresh_time
111 {
112     kSEMC_RefreshThreeClocks = 0x0U, /*!< The refresh timing with three bus clocks. */
113     kSEMC_RefreshSixClocks,          /*!< The refresh timing with six bus clocks. */
114     kSEMC_RefreshNineClocks          /*!< The refresh timing with nine bus clocks. */
115 } semc_refresh_time_t;
116 
117 /*! @brief CAS latency */
118 typedef enum _semc_caslatency
119 {
120     kSEMC_LatencyOne = 1, /*!< Latency  1. */
121     kSEMC_LatencyTwo,     /*!< Latency  2. */
122     kSEMC_LatencyThree,   /*!< Latency  3. */
123 } semc_caslatency_t;
124 
125 /*! @brief SEMC sdram column address bit number. */
126 typedef enum _semc_sdram_column_bit_num
127 {
128     kSEMC_SdramColunm_12bit = 0x0U, /*!< 12 bit. */
129     kSEMC_SdramColunm_11bit,        /*!< 11 bit. */
130     kSEMC_SdramColunm_10bit,        /*!< 10 bit. */
131     kSEMC_SdramColunm_9bit,         /*!< 9 bit. */
132 #if defined(FSL_FEATURE_SEMC_SDRAM_SUPPORT_COLUMN_ADDRESS_8BIT) && (FSL_FEATURE_SEMC_SDRAM_SUPPORT_COLUMN_ADDRESS_8BIT)
133     kSEMC_SdramColunm_8bit, /*!< 8 bit. */
134 #endif                      /* FSL_FEATURE_SEMC_SDRAM_SUPPORT_COLUMN_ADDRESS_8BIT */
135 } semc_sdram_column_bit_num_t;
136 
137 /*! @brief SEMC sdram burst length. */
138 typedef enum _semc_sdram_burst_len
139 {
140 /*! According to ERR050577, Auto-refresh command may possibly fail to be triggered during
141     long time back-to-back write (or read) when SDRAM controller's burst length is greater than 1. */
142 #if defined(FSL_FEATURE_SEMC_ERRATA_050577) && (FSL_FEATURE_SEMC_ERRATA_050577 == 0x01U)
143     kSEMC_Sdram_BurstLen1 = 0, /*!< Burst length 1*/
144 #else
145     kSEMC_Sdram_BurstLen1 = 0, /*!< Burst length 1*/
146     kSEMC_Sdram_BurstLen2,     /*!< Burst length 2*/
147     kSEMC_Sdram_BurstLen4,     /*!< Burst length 4*/
148     kSEMC_Sdram_BurstLen8      /*!< Burst length 8*/
149 #endif /* FSL_FEATURE_SEMC_ERRATA_050577 */
150 } sem_sdram_burst_len_t;
151 
152 /*! @brief SEMC nand column address bit number. */
153 typedef enum _semc_nand_column_bit_num
154 {
155     kSEMC_NandColum_16bit = 0x0U, /*!< 16 bit. */
156     kSEMC_NandColum_15bit,        /*!< 15 bit. */
157     kSEMC_NandColum_14bit,        /*!< 14 bit. */
158     kSEMC_NandColum_13bit,        /*!< 13 bit. */
159     kSEMC_NandColum_12bit,        /*!< 12 bit. */
160     kSEMC_NandColum_11bit,        /*!< 11 bit. */
161     kSEMC_NandColum_10bit,        /*!< 10 bit. */
162     kSEMC_NandColum_9bit,         /*!< 9 bit. */
163 } semc_nand_column_bit_num_t;
164 
165 /*! @brief SEMC nand burst length. */
166 typedef enum _semc_nand_burst_len
167 {
168     kSEMC_Nand_BurstLen1 = 0, /*!< Burst length 1*/
169     kSEMC_Nand_BurstLen2,     /*!< Burst length 2*/
170     kSEMC_Nand_BurstLen4,     /*!< Burst length 4*/
171     kSEMC_Nand_BurstLen8,     /*!< Burst length 8*/
172     kSEMC_Nand_BurstLen16,    /*!< Burst length 16*/
173     kSEMC_Nand_BurstLen32,    /*!< Burst length 32*/
174     kSEMC_Nand_BurstLen64     /*!< Burst length 64*/
175 } sem_nand_burst_len_t;
176 
177 /*! @brief SEMC nor/sram column address bit number. */
178 typedef enum _semc_norsram_column_bit_num
179 {
180     kSEMC_NorColum_12bit = 0x0U, /*!< 12 bit. */
181     kSEMC_NorColum_11bit,        /*!< 11 bit. */
182     kSEMC_NorColum_10bit,        /*!< 10 bit. */
183     kSEMC_NorColum_9bit,         /*!< 9 bit. */
184     kSEMC_NorColum_8bit,         /*!< 8 bit. */
185     kSEMC_NorColum_7bit,         /*!< 7 bit. */
186     kSEMC_NorColum_6bit,         /*!< 6 bit. */
187     kSEMC_NorColum_5bit,         /*!< 5 bit. */
188     kSEMC_NorColum_4bit,         /*!< 4 bit. */
189     kSEMC_NorColum_3bit,         /*!< 3 bit. */
190     kSEMC_NorColum_2bit          /*!< 2 bit. */
191 } semc_norsram_column_bit_num_t;
192 
193 /*! @brief SEMC nor/sram burst length. */
194 typedef enum _semc_norsram_burst_len
195 {
196     kSEMC_Nor_BurstLen1 = 0, /*!< Burst length 1*/
197     kSEMC_Nor_BurstLen2,     /*!< Burst length 2*/
198     kSEMC_Nor_BurstLen4,     /*!< Burst length 4*/
199     kSEMC_Nor_BurstLen8,     /*!< Burst length 8*/
200     kSEMC_Nor_BurstLen16,    /*!< Burst length 16*/
201     kSEMC_Nor_BurstLen32,    /*!< Burst length 32*/
202     kSEMC_Nor_BurstLen64     /*!< Burst length 64*/
203 } sem_norsram_burst_len_t;
204 
205 /*! @brief SEMC dbi column address bit number. */
206 typedef enum _semc_dbi_column_bit_num
207 {
208     kSEMC_Dbi_Colum_12bit = 0x0U, /*!< 12 bit. */
209     kSEMC_Dbi_Colum_11bit,        /*!< 11 bit. */
210     kSEMC_Dbi_Colum_10bit,        /*!< 10 bit. */
211     kSEMC_Dbi_Colum_9bit,         /*!< 9 bit. */
212     kSEMC_Dbi_Colum_8bit,         /*!< 8 bit. */
213     kSEMC_Dbi_Colum_7bit,         /*!< 7 bit. */
214     kSEMC_Dbi_Colum_6bit,         /*!< 6 bit. */
215     kSEMC_Dbi_Colum_5bit,         /*!< 5 bit. */
216     kSEMC_Dbi_Colum_4bit,         /*!< 4 bit. */
217     kSEMC_Dbi_Colum_3bit,         /*!< 3 bit. */
218     kSEMC_Dbi_Colum_2bit          /*!< 2 bit. */
219 } semc_dbi_column_bit_num_t;
220 
221 /*! @brief SEMC dbi burst length. */
222 typedef enum _semc_dbi_burst_len
223 {
224     kSEMC_Dbi_BurstLen1 = 0, /*!< Burst length 1*/
225     kSEMC_Dbi_BurstLen2,     /*!< Burst length 2*/
226     kSEMC_Dbi_Dbi_BurstLen4, /*!< Burst length 4*/
227     kSEMC_Dbi_BurstLen8,     /*!< Burst length 8*/
228     kSEMC_Dbi_BurstLen16,    /*!< Burst length 16*/
229     kSEMC_Dbi_BurstLen32,    /*!< Burst length 32*/
230     kSEMC_Dbi_BurstLen64     /*!< Burst length 64*/
231 } sem_dbi_burst_len_t;
232 
233 /*! @brief SEMC IOMUXC. */
234 typedef enum _semc_iomux_pin
235 {
236     kSEMC_MUXA8   = SEMC_IOCR_MUX_A8_SHIFT,   /*!< MUX A8 pin. */
237     kSEMC_MUXCSX0 = SEMC_IOCR_MUX_CSX0_SHIFT, /*!< MUX CSX0 pin */
238     kSEMC_MUXCSX1 = SEMC_IOCR_MUX_CSX1_SHIFT, /*!< MUX CSX1 Pin.*/
239     kSEMC_MUXCSX2 = SEMC_IOCR_MUX_CSX2_SHIFT, /*!< MUX CSX2 Pin. */
240     kSEMC_MUXCSX3 = SEMC_IOCR_MUX_CSX3_SHIFT, /*!< MUX CSX3 Pin. */
241     kSEMC_MUXRDY  = SEMC_IOCR_MUX_RDY_SHIFT   /*!< MUX RDY pin. */
242 } semc_iomux_pin;
243 
244 /*! @brief SEMC NOR/PSRAM Address bit 27 A27. */
245 typedef enum _semc_iomux_nora27_pin
246 {
247     kSEMC_MORA27_NONE    = 0,                        /*!< No NOR/SRAM A27 pin. */
248     kSEMC_NORA27_MUXCSX3 = SEMC_IOCR_MUX_CSX3_SHIFT, /*!< MUX CSX3 Pin. */
249     kSEMC_NORA27_MUXRDY  = SEMC_IOCR_MUX_RDY_SHIFT   /*!< MUX RDY pin. */
250 } semc_iomux_nora27_pin;
251 
252 /*! @brief SEMC port size. */
253 typedef enum _semc_port_size
254 {
255     kSEMC_PortSize8Bit = 0, /*!< 8-Bit port size. */
256     kSEMC_PortSize16Bit,    /*!< 16-Bit port size. */
257 #if defined(FSL_FEATURE_SEMC_SUPPORT_SDRAM_PS_BITWIDTH) && (FSL_FEATURE_SEMC_SUPPORT_SDRAM_PS_BITWIDTH == 0x02U)
258     kSEMC_PortSize32Bit /*!< 32-Bit port size. */
259 #endif                  /* FSL_FEATURE_SEMC_SUPPORT_SDRAM_PS_BITWIDTH */
260 } smec_port_size_t;
261 
262 /*! @brief SEMC address mode. */
263 typedef enum _semc_addr_mode
264 {
265     kSEMC_AddrDataMux = 0, /*!< SEMC address/data mux mode. */
266     kSEMC_AdvAddrdataMux,  /*!< Advanced address/data mux mode. */
267     kSEMC_AddrDataNonMux   /*!< Address/data non-mux mode. */
268 } semc_addr_mode_t;
269 
270 /*! @brief SEMC DQS read strobe mode. */
271 typedef enum _semc_dqs_mode
272 {
273     kSEMC_Loopbackinternal = 0, /*!< Dummy read strobe loopbacked internally. */
274     kSEMC_Loopbackdqspad,       /*!< Dummy read strobe loopbacked from DQS pad. */
275 } semc_dqs_mode_t;
276 
277 /*! @brief SEMC ADV signal active polarity. */
278 typedef enum _semc_adv_polarity
279 {
280     kSEMC_AdvActiveLow = 0, /*!< Adv active low. */
281     kSEMC_AdvActiveHigh,    /*!< Adv active high. */
282 } semc_adv_polarity_t;
283 
284 /*! @brief SEMC sync mode. */
285 typedef enum _semc_sync_mode
286 {
287     kSEMC_AsyncMode = 0, /*!< Async mode. */
288     kSEMC_SyncMode,      /*!< Sync mode. */
289 } semc_sync_mode_t;
290 
291 /*! @brief SEMC ADV signal level control. */
292 typedef enum _semc_adv_level_control
293 {
294     kSEMC_AdvHigh = 0, /*!< Adv is high during address hold state. */
295     kSEMC_AdvLow,      /*!< Adv is low during address hold state. */
296 } semc_adv_level_control_t;
297 
298 /*! @brief SEMC RDY signal active polarity. */
299 typedef enum _semc_rdy_polarity
300 {
301     kSEMC_RdyActiveLow = 0, /*!< Adv active low. */
302     kSEMC_RdyActivehigh,    /*!< Adv active low. */
303 } semc_rdy_polarity_t;
304 
305 /*! @brief SEMC IP command for NAND: address mode. */
306 typedef enum _semc_ipcmd_nand_addrmode
307 {
308     kSEMC_NANDAM_ColumnRow = 0x0U, /*!< Address mode: column and row address(5Byte-CA0/CA1/RA0/RA1/RA2). */
309     kSEMC_NANDAM_ColumnCA0,        /*!< Address mode: column address only(1 Byte-CA0).  */
310     kSEMC_NANDAM_ColumnCA0CA1,     /*!< Address mode: column address only(2 Byte-CA0/CA1). */
311     kSEMC_NANDAM_RawRA0,           /*!< Address mode: row address only(1 Byte-RA0). */
312     kSEMC_NANDAM_RawRA0RA1,        /*!< Address mode: row address only(2 Byte-RA0/RA1). */
313     kSEMC_NANDAM_RawRA0RA1RA2      /*!< Address mode: row address only(3 Byte-RA0).  */
314 } semc_ipcmd_nand_addrmode_t;
315 
316 /*! @brief SEMC IP command for NAND: command mode. */
317 typedef enum _semc_ipcmd_nand_cmdmode
318 {
319     kSEMC_NANDCM_Command = 0x2U,      /*!< command. */
320     kSEMC_NANDCM_CommandHold,         /*!< Command hold. */
321     kSEMC_NANDCM_CommandAddress,      /*!< Command address. */
322     kSEMC_NANDCM_CommandAddressHold,  /*!< Command address hold.  */
323     kSEMC_NANDCM_CommandAddressRead,  /*!< Command address read.  */
324     kSEMC_NANDCM_CommandAddressWrite, /*!< Command address write.  */
325     kSEMC_NANDCM_CommandRead,         /*!< Command read.  */
326     kSEMC_NANDCM_CommandWrite,        /*!< Command write.  */
327     kSEMC_NANDCM_Read,                /*!< Read.  */
328     kSEMC_NANDCM_Write                /*!< Write.  */
329 } semc_ipcmd_nand_cmdmode_t;
330 
331 /*! @brief SEMC NAND address option. */
332 typedef enum _semc_nand_address_option
333 {
334     kSEMC_NandAddrOption_5byte_CA2RA3 = 0U, /*!< CA0+CA1+RA0+RA1+RA2 */
335     kSEMC_NandAddrOption_4byte_CA2RA2 = 2U, /*!< CA0+CA1+RA0+RA1 */
336     kSEMC_NandAddrOption_3byte_CA2RA1 = 4U, /*!< CA0+CA1+RA0 */
337     kSEMC_NandAddrOption_4byte_CA1RA3 = 1U, /*!< CA0+RA0+RA1+RA2 */
338     kSEMC_NandAddrOption_3byte_CA1RA2 = 3U, /*!< CA0+RA0+RA1 */
339     kSEMC_NandAddrOption_2byte_CA1RA1 = 7U, /*!< CA0+RA0 */
340 } semc_nand_address_option_t;
341 
342 /*! @brief SEMC IP command for NOR. */
343 typedef enum _semc_ipcmd_nor_dbi
344 {
345     kSEMC_NORDBICM_Read = 0x2U, /*!< NOR read. */
346     kSEMC_NORDBICM_Write        /*!< NOR write.  */
347 } semc_ipcmd_nor_dbi_t;
348 
349 /*! @brief SEMC IP command for SRAM. */
350 typedef enum _semc_ipcmd_sram
351 {
352     kSEMC_SRAMCM_ArrayRead = 0x2U, /*!< SRAM memory array read. */
353     kSEMC_SRAMCM_ArrayWrite,       /*!< SRAM memory array write. */
354     kSEMC_SRAMCM_RegRead,          /*!< SRAM memory register read. */
355     kSEMC_SRAMCM_RegWrite          /*!< SRAM memory register write. */
356 } semc_ipcmd_sram_t;
357 
358 /*! @brief SEMC IP command for SDARM. */
359 typedef enum _semc_ipcmd_sdram
360 {
361     kSEMC_SDRAMCM_Read = 0x8U, /*!< SDRAM memory read. */
362     kSEMC_SDRAMCM_Write,       /*!< SDRAM memory write. */
363     kSEMC_SDRAMCM_Modeset,     /*!< SDRAM MODE SET. */
364     kSEMC_SDRAMCM_Active,      /*!< SDRAM active. */
365     kSEMC_SDRAMCM_AutoRefresh, /*!< SDRAM auto-refresh. */
366     kSEMC_SDRAMCM_SelfRefresh, /*!< SDRAM self-refresh. */
367     kSEMC_SDRAMCM_Precharge,   /*!< SDRAM precharge. */
368     kSEMC_SDRAMCM_Prechargeall /*!< SDRAM precharge all. */
369 } semc_ipcmd_sdram_t;
370 
371 /*! @brief SEMC SDRAM configuration structure.
372  *
373  * 1. The memory size in the configuration is in the unit of KB. So memsize_kbytes
374  * should be set as 2^2, 2^3, 2^4 .etc which is base 2KB exponential function.
375  * Take refer to BR0~BR3 register in RM for details.
376  * 2. The prescalePeriod_N16Cycle is in unit of 16 clock cycle. It is a exception for prescaleTimer_n16cycle = 0,
377  * it means the prescaler timer period is 256 * 16 clock cycles. For precalerIf precalerTimer_n16cycle not equal to 0,
378  * The  prescaler timer period is prescalePeriod_N16Cycle * 16 clock cycles.
379  * idleTimeout_NprescalePeriod,  refreshUrgThreshold_NprescalePeriod, refreshPeriod_NprescalePeriod are
380  * similar to prescalePeriod_N16Cycle.
381  *
382  */
383 typedef struct _semc_sdram_config
384 {
385     semc_iomux_pin csxPinMux;       /*!< CS pin mux. The kSEMC_MUXA8 is not valid in sdram pin mux setting. */
386     uint32_t address;               /*!< The base address. */
387     uint32_t memsize_kbytes;        /*!< The memory size in unit of kbytes. */
388     smec_port_size_t portSize;      /*!< Port size. */
389     sem_sdram_burst_len_t burstLen; /*!< Burst length. */
390     semc_sdram_column_bit_num_t columnAddrBitNum; /*!< Column address bit number. */
391     semc_caslatency_t casLatency;                 /*!< CAS latency. */
392     uint8_t tPrecharge2Act_Ns;                    /*!< Precharge to active wait time in unit of nanosecond. */
393     uint8_t tAct2ReadWrite_Ns;                    /*!< Act to read/write wait time in unit of nanosecond. */
394     uint8_t tRefreshRecovery_Ns;                  /*!< Refresh recovery time in unit of nanosecond. */
395     uint8_t tWriteRecovery_Ns;                    /*!< write recovery time in unit of nanosecond. */
396     uint8_t tCkeOff_Ns;                           /*!< CKE off minimum time in unit of nanosecond. */
397     uint8_t tAct2Prechage_Ns;                     /*!< Active to precharge in unit of nanosecond. */
398     uint8_t tSelfRefRecovery_Ns;                  /*!< Self refresh recovery time in unit of nanosecond. */
399     uint8_t tRefresh2Refresh_Ns;                  /*!< Refresh to refresh wait time in unit of nanosecond. */
400     uint8_t tAct2Act_Ns;                          /*!< Active to active wait time in unit of nanosecond. */
401     uint32_t tPrescalePeriod_Ns;     /*!< Prescaler timer period should not be larger than 256 * 16 * clock cycle. */
402     uint32_t tIdleTimeout_Ns;        /*!< Idle timeout in unit of prescale time period. */
403     uint32_t refreshPeriod_nsPerRow; /*!< Refresh timer period like 64ms * 1000000/8192 . */
404     uint32_t refreshUrgThreshold;    /*!< Refresh urgent threshold. */
405     uint8_t refreshBurstLen;         /*!< Refresh burst length. */
406 #if defined(FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL) && (FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL)
407     uint8_t delayChain; /*!< Delay chain, which adds delays on DQS clock to compensate timings while DQS is faster than
408                            read data. */
409 #endif                  /* FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL */
410     uint8_t autofreshTimes;          /*!< Auto Refresh cycles times. */
411 } semc_sdram_config_t;
412 
413 /*! @brief SEMC NAND device timing configuration structure. */
414 typedef struct _semc_nand_timing_config
415 {
416     uint8_t tCeSetup_Ns;        /*!< CE setup time: tCS. */
417     uint8_t tCeHold_Ns;         /*!< CE hold time: tCH. */
418     uint8_t tCeInterval_Ns;     /*!< CE interval time:tCEITV. */
419     uint8_t tWeLow_Ns;          /*!< WE low time: tWP. */
420     uint8_t tWeHigh_Ns;         /*!< WE high time: tWH. */
421     uint8_t tReLow_Ns;          /*!< RE low time: tRP. */
422     uint8_t tReHigh_Ns;         /*!< RE high time: tREH. */
423     uint8_t tTurnAround_Ns;     /*!< Turnaround time for async mode: tTA. */
424     uint8_t tWehigh2Relow_Ns;   /*!< WE# high to RE# wait time: tWHR. */
425     uint8_t tRehigh2Welow_Ns;   /*!< RE# high to WE# low wait time: tRHW. */
426     uint8_t tAle2WriteStart_Ns; /*!< ALE to write start wait time: tADL. */
427     uint8_t tReady2Relow_Ns;    /*!< Ready to RE# low min wait time: tRR. */
428     uint8_t tWehigh2Busy_Ns;    /*!< WE# high to busy wait time: tWB. */
429 } semc_nand_timing_config_t;
430 
431 /*! @brief SEMC NAND configuration structure. */
432 typedef struct _semc_nand_config
433 {
434     semc_iomux_pin cePinMux;    /*!< The CE pin mux setting. The kSEMC_MUXRDY is not valid for CE pin setting. */
435     uint32_t axiAddress;        /*!< The base address for AXI nand. */
436     uint32_t axiMemsize_kbytes; /*!< The memory size in unit of kbytes for AXI nand. */
437     uint32_t ipgAddress;        /*!< The base address for IPG nand . */
438     uint32_t ipgMemsize_kbytes; /*!< The memory size in unit of kbytes for IPG nand. */
439     semc_rdy_polarity_t rdyactivePolarity;       /*!< Wait ready polarity. */
440     bool edoModeEnabled;                         /*!< EDO mode enabled. */
441     semc_nand_column_bit_num_t columnAddrBitNum; /*!< Column address bit number. */
442     semc_nand_address_option_t arrayAddrOption;  /*!< Address option. */
443     sem_nand_burst_len_t burstLen;               /*!< Burst length. */
444     smec_port_size_t portSize;                   /*!< Port size. */
445     semc_nand_timing_config_t *timingConfig;     /*!< SEMC nand timing configuration. */
446 } semc_nand_config_t;
447 
448 /*! @brief SEMC NOR configuration structure. */
449 typedef struct _semc_nor_config
450 {
451     semc_iomux_pin cePinMux;                        /*!< The CE# pin mux setting. */
452     semc_iomux_nora27_pin addr27;                   /*!< The Addr bit 27 pin mux setting. */
453     uint32_t address;                               /*!< The base address. */
454     uint32_t memsize_kbytes;                        /*!< The memory size in unit of kbytes. */
455     uint8_t addrPortWidth;                          /*!< The address port width. */
456     semc_rdy_polarity_t rdyactivePolarity;          /*!< Wait ready polarity. */
457     semc_adv_polarity_t advActivePolarity;          /*!< ADV# polarity. */
458     semc_norsram_column_bit_num_t columnAddrBitNum; /*!< Column address bit number. */
459     semc_addr_mode_t addrMode;                      /*!< Address mode. */
460     sem_norsram_burst_len_t burstLen;               /*!< Burst length. */
461     smec_port_size_t portSize;                      /*!< Port size. */
462     uint8_t tCeSetup_Ns;                            /*!< The CE setup time. */
463     uint8_t tCeHold_Ns;                             /*!< The CE hold time. */
464     uint8_t tCeInterval_Ns;                         /*!< CE interval minimum time. */
465     uint8_t tAddrSetup_Ns;                          /*!< The address setup time. */
466     uint8_t tAddrHold_Ns;                           /*!< The address hold time. */
467     uint8_t tWeLow_Ns;                              /*!< WE low time for async mode. */
468     uint8_t tWeHigh_Ns;                             /*!< WE high time for async mode. */
469     uint8_t tReLow_Ns;                              /*!< RE low time for async mode. */
470     uint8_t tReHigh_Ns;                             /*!< RE high time for async mode. */
471     uint8_t tTurnAround_Ns;                         /*!< Turnaround time for async mode. */
472     uint8_t tAddr2WriteHold_Ns;                     /*!< Address to write data hold time for async mode. */
473 #if defined(FSL_FEATURE_SEMC_HAS_NOR_WDS_TIME) && (FSL_FEATURE_SEMC_HAS_NOR_WDS_TIME)
474     uint8_t tWriteSetup_Ns; /*!< Write data setup time for sync mode.*/
475 #endif
476 #if defined(FSL_FEATURE_SEMC_HAS_NOR_WDH_TIME) && (FSL_FEATURE_SEMC_HAS_NOR_WDH_TIME)
477     uint8_t tWriteHold_Ns; /*!< Write hold time for sync mode. */
478 #endif
479 #if defined(FSL_FEATURE_SEMC_HAS_NOR_LC_TIME) && (FSL_FEATURE_SEMC_HAS_NOR_LC_TIME)
480     uint8_t latencyCount; /*!< Latency count for sync mode. */
481 #endif
482 #if defined(FSL_FEATURE_SEMC_HAS_NOR_RD_TIME) && (FSL_FEATURE_SEMC_HAS_NOR_RD_TIME)
483     uint8_t readCycle; /*!< Read cycle time for sync mode. */
484 #endif
485 #if defined(FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL) && (FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL)
486     uint8_t delayChain; /*!< Delay chain, which adds delays on DQS clock to compensate timings while DQS is faster than
487                            read data. */
488 #endif                  /* FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL */
489 } semc_nor_config_t;
490 
491 /*! @brief SEMC SRAM  configuration structure. */
492 typedef struct _semc_sram_config
493 {
494     semc_iomux_pin cePinMux;               /*!< The CE# pin mux setting. */
495     semc_iomux_nora27_pin addr27;          /*!< The Addr bit 27 pin mux setting. */
496     uint32_t address;                      /*!< The base address. */
497     uint32_t memsize_kbytes;               /*!< The memory size in unit of kbytes. */
498     uint8_t addrPortWidth;                 /*!< The address port width. */
499     semc_adv_polarity_t advActivePolarity; /*!< ADV# polarity 1: active high, 0: active low. */
500     semc_addr_mode_t addrMode;             /*!< Address mode. */
501     sem_norsram_burst_len_t burstLen;      /*!< Burst length. */
502     smec_port_size_t portSize;             /*!< Port size. */
503 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_SYNCEN) && (FSL_FEATURE_SEMC_HAS_SRAM_SYNCEN)
504     semc_sync_mode_t syncMode; /*!< Sync mode. */
505 #endif                         /* FSL_FEATURE_SEMC_HAS_SRAM_SYNCEN */
506 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_WAITEN) && (FSL_FEATURE_SEMC_HAS_SRAM_WAITEN)
507     bool waitEnable; /*!< Wait enable. */
508 #endif               /* FSL_FEATURE_SEMC_HAS_SRAM_WAITEN */
509 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_WAITSP) && (FSL_FEATURE_SEMC_HAS_SRAM_WAITSP)
510     uint8_t waitSample; /*!< Wait sample. */
511 #endif                  /* FSL_FEATURE_SEMC_HAS_SRAM_WAITSP */
512 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_ADVH) && (FSL_FEATURE_SEMC_HAS_SRAM_ADVH)
513     semc_adv_level_control_t advLevelCtrl; /*!< ADV# level control during address hold state, 1: low, 0: high. */
514 #endif                                     /* FSL_FEATURE_SEMC_HAS_SRAM_ADVH */
515     uint8_t tCeSetup_Ns;                   /*!< The CE setup time. */
516     uint8_t tCeHold_Ns;                    /*!< The CE hold time. */
517     uint8_t tCeInterval_Ns;                /*!< CE interval minimum time. */
518 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_RDH_TIME) && (FSL_FEATURE_SEMC_HAS_SRAM_RDH_TIME)
519     uint8_t readHoldTime_Ns;    /*!< read hold time. */
520 #endif                          /* FSL_FEATURE_SEMC_HAS_SRAM_RDH_TIME */
521     uint8_t tAddrSetup_Ns;      /*!< The address setup time. */
522     uint8_t tAddrHold_Ns;       /*!< The address hold time. */
523     uint8_t tWeLow_Ns;          /*!< WE low time for async mode. */
524     uint8_t tWeHigh_Ns;         /*!< WE high time for async mode. */
525     uint8_t tReLow_Ns;          /*!< RE low time for async mode. */
526     uint8_t tReHigh_Ns;         /*!< RE high time for async mode. */
527     uint8_t tTurnAround_Ns;     /*!< Turnaround time for async mode. */
528     uint8_t tAddr2WriteHold_Ns; /*!< Address to write data hold time for async mode. */
529 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_WDS_TIME) && (FSL_FEATURE_SEMC_HAS_SRAM_WDS_TIME)
530     uint8_t tWriteSetup_Ns; /*!<Write data setup time for sync mode. */
531 #endif
532 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_WDH_TIME) && (FSL_FEATURE_SEMC_HAS_SRAM_WDH_TIME)
533     uint8_t tWriteHold_Ns; /*!<Write hold time for sync mode. */
534 #endif
535 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_LC_TIME) && (FSL_FEATURE_SEMC_HAS_SRAM_LC_TIME)
536     uint8_t latencyCount; /*!<Latency count for sync mode. */
537 #endif
538 #if defined(FSL_FEATURE_SEMC_HAS_SRAM_RD_TIME) && (FSL_FEATURE_SEMC_HAS_SRAM_RD_TIME)
539     uint8_t readCycle; /*!<Read cycle time for sync mode. */
540 #endif
541 #if defined(FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL) && (FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL)
542     uint8_t delayChain; /*!< Delay chain, which adds delays on DQS clock to compensate timings while DQS is faster than
543                            read data. */
544 #endif                  /* FSL_FEATURE_SEMC_HAS_DELAY_CHAIN_CONTROL */
545 } semc_sram_config_t;
546 
547 /*! @brief SEMC DBI configuration structure. */
548 typedef struct _semc_dbi_config
549 {
550     semc_iomux_pin csxPinMux;                   /*!< The CE# pin mux. */
551     uint32_t address;                           /*!< The base address. */
552     uint32_t memsize_kbytes;                    /*!< The memory size in unit of 4kbytes. */
553     semc_dbi_column_bit_num_t columnAddrBitNum; /*!< Column address bit number. */
554     sem_dbi_burst_len_t burstLen;               /*!< Burst length. */
555     smec_port_size_t portSize;                  /*!< Port size. */
556     uint8_t tCsxSetup_Ns;                       /*!< The CSX setup time. */
557     uint8_t tCsxHold_Ns;                        /*!< The CSX hold time. */
558     uint8_t tWexLow_Ns;                         /*!< WEX low time. */
559     uint8_t tWexHigh_Ns;                        /*!< WEX high time. */
560     uint8_t tRdxLow_Ns;                         /*!< RDX low time. */
561     uint8_t tRdxHigh_Ns;                        /*!< RDX high time. */
562     uint8_t tCsxInterval_Ns;                    /*!< Write data setup time.*/
563 } semc_dbi_config_t;
564 
565 /*! @brief SEMC AXI queue a weight setting structure. */
566 typedef struct _semc_queuea_weight_struct
567 {
568     uint32_t qos : 4;              /*!< weight of qos for queue 0 . */
569     uint32_t aging : 4;            /*!< weight of aging for queue 0.*/
570     uint32_t slaveHitNoswitch : 8; /*!< weight of read/write no switch for queue 0  .*/
571     uint32_t slaveHitSwitch : 8;   /*!< weight of read/write switch for queue 0.*/
572 } semc_queuea_weight_struct_t;
573 
574 /*! @brief SEMC AXI queue a weight setting union. */
575 typedef union _semc_queuea_weight
576 {
577     semc_queuea_weight_struct_t queueaConfig; /*!< Structure configuration for queueA. */
578     uint32_t queueaValue; /*!< Configuration value for queueA which could directly write to the reg. */
579 } semc_queuea_weight_t;
580 
581 /*! @brief SEMC AXI queue b weight setting structure. */
582 typedef struct _semc_queueb_weight_struct
583 {
584     uint32_t qos : 4;              /*!< weight of qos for queue 1. */
585     uint32_t aging : 4;            /*!< weight of aging for queue 1.*/
586     uint32_t weightPagehit : 8;    /*!< weight of page hit for queue 1 only .*/
587     uint32_t slaveHitNoswitch : 8; /*!< weight of read/write no switch for queue 1.*/
588     uint32_t bankRotation : 8;     /*!< weight of bank rotation for queue 1 only .*/
589 } semc_queueb_weight_struct_t;
590 
591 /*! @brief SEMC AXI queue b weight setting union. */
592 typedef union _semc_queueb_weight
593 {
594     semc_queueb_weight_struct_t queuebConfig; /*!< Structure configuration for queueB. */
595     uint32_t queuebValue; /*!< Configuration value for queueB which could directly write to the reg. */
596 } semc_queueb_weight_t;
597 
598 /*! @brief SEMC AXI queue weight setting. */
599 typedef struct _semc_axi_queueweight
600 {
601     bool queueaEnable;                 /*!< Enable queue a. */
602     semc_queuea_weight_t queueaWeight; /*!< Weight settings for queue a. */
603     bool queuebEnable;                 /*!< Enable queue b. */
604     semc_queueb_weight_t queuebWeight; /*!< Weight settings for queue b. */
605 } semc_axi_queueweight_t;
606 
607 /*!
608  * @brief SEMC configuration structure.
609  *
610  * busTimeoutCycles: when busTimeoutCycles is zero, the bus timeout cycle is
611  * 255*1024. otherwise the bus timeout cycles is busTimeoutCycles*1024.
612  * cmdTimeoutCycles: is used for command execution timeout cycles. it's
613  * similar to the busTimeoutCycles.
614  */
615 typedef struct _semc_config_t
616 {
617     semc_dqs_mode_t dqsMode;            /*!< Dummy read strobe mode: use enum in "semc_dqs_mode_t". */
618     uint8_t cmdTimeoutCycles;           /*!< Command execution timeout cycles. */
619     uint8_t busTimeoutCycles;           /*!< Bus timeout cycles. */
620     semc_axi_queueweight_t queueWeight; /*!< AXI queue weight. */
621 } semc_config_t;
622 
623 /*******************************************************************************
624  * API
625  ******************************************************************************/
626 
627 #if defined(__cplusplus)
628 extern "C" {
629 #endif
630 
631 /*!
632  * @name SEMC Initialization and De-initialization
633  * @{
634  */
635 
636 /*!
637  * @brief Gets the SEMC default basic configuration structure.
638  *
639  * The purpose of this API is to get the default SEMC
640  * configure structure for SEMC_Init(). User may use the initialized
641  * structure unchanged in SEMC_Init(), or modify some fields of the
642  * structure before calling SEMC_Init().
643  * Example:
644    @code
645    semc_config_t config;
646    SEMC_GetDefaultConfig(&config);
647    @endcode
648  * @param config The SEMC configuration structure pointer.
649  */
650 void SEMC_GetDefaultConfig(semc_config_t *config);
651 
652 /*!
653  * @brief Initializes SEMC.
654  * This function ungates the SEMC clock and initializes SEMC.
655  * This function must be called before calling any other SEMC driver functions.
656  *
657  * @param base SEMC peripheral base address.
658  * @param configure The SEMC configuration structure pointer.
659  */
660 void SEMC_Init(SEMC_Type *base, semc_config_t *configure);
661 
662 /*!
663  * @brief Deinitializes the SEMC module and gates the clock.
664  *
665  * This function gates the SEMC clock. As a result, the SEMC module doesn't work after
666  * calling this function, for some IDE, calling this API may cause the next downloading
667  * operation failed. so, please call this API cautiously. Additional, users can
668  * using "#define FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL (1)" to disable the clock control
669  * operation in drivers.
670  *
671  * @param base SEMC peripheral base address.
672  */
673 void SEMC_Deinit(SEMC_Type *base);
674 
675 /*! @} */
676 
677 /*!
678  * @name SEMC Configuration Operation For Each Memory Type
679  * @{
680  */
681 
682 /*!
683  * @brief Configures SDRAM controller in SEMC.
684  *
685  * @param base SEMC peripheral base address.
686  * @param cs The chip selection.
687  * @param config The sdram configuration.
688  * @param clkSrc_Hz The SEMC clock frequency.
689  */
690 status_t SEMC_ConfigureSDRAM(SEMC_Type *base, semc_sdram_cs_t cs, semc_sdram_config_t *config, uint32_t clkSrc_Hz);
691 
692 /*!
693  * @brief Configures NAND controller in SEMC.
694  *
695  * @param base SEMC peripheral base address.
696  * @param config The nand configuration.
697  * @param clkSrc_Hz The SEMC clock frequency.
698  */
699 status_t SEMC_ConfigureNAND(SEMC_Type *base, semc_nand_config_t *config, uint32_t clkSrc_Hz);
700 
701 /*!
702  * @brief Configures NOR controller in SEMC.
703  *
704  * @param base SEMC peripheral base address.
705  * @param config The nor configuration.
706  * @param clkSrc_Hz The SEMC clock frequency.
707  */
708 status_t SEMC_ConfigureNOR(SEMC_Type *base, semc_nor_config_t *config, uint32_t clkSrc_Hz);
709 
710 /*!
711  * @brief Configures SRAM controller in SEMC.
712  *
713  * @param base SEMC peripheral base address.
714  * @param cs The chip selection.
715  * @param config The sram configuration.
716  * @param clkSrc_Hz The SEMC clock frequency.
717  */
718 status_t SEMC_ConfigureSRAMWithChipSelection(SEMC_Type *base,
719                                              semc_sram_cs_t cs,
720                                              semc_sram_config_t *config,
721                                              uint32_t clkSrc_Hz);
722 
723 /*!
724  * @brief Configures SRAM controller in SEMC.
725  * @deprecated Do not use this function. It has been superceded by @ref SEMC_ConfigureSRAMWithChipSelection.
726  * @param base SEMC peripheral base address.
727  * @param config The sram configuration.
728  * @param clkSrc_Hz The SEMC clock frequency.
729  */
730 status_t SEMC_ConfigureSRAM(SEMC_Type *base, semc_sram_config_t *config, uint32_t clkSrc_Hz);
731 
732 /*!
733  * @brief Configures DBI controller in SEMC.
734  *
735  * @param base SEMC peripheral base address.
736  * @param config The dbi configuration.
737  * @param clkSrc_Hz The SEMC clock frequency.
738  */
739 status_t SEMC_ConfigureDBI(SEMC_Type *base, semc_dbi_config_t *config, uint32_t clkSrc_Hz);
740 
741 /*! @} */
742 
743 /*!
744  * @name SEMC Interrupt Operation
745  * @{
746  */
747 
748 /*!
749  * @brief Enables the SEMC interrupt.
750  *
751  * This function enables the SEMC interrupts according to the provided mask. The mask
752  * is a logical OR of enumeration members. See @ref semc_interrupt_enable_t.
753  * For example, to enable the IP command done and error interrupt, do the following.
754  * @code
755  *     SEMC_EnableInterrupts(ENET, kSEMC_IPCmdDoneInterrupt | kSEMC_IPCmdErrInterrupt);
756  * @endcode
757  *
758  * @param base  SEMC peripheral base address.
759  * @param mask  SEMC interrupts to enable. This is a logical OR of the
760  *             enumeration :: semc_interrupt_enable_t.
761  */
SEMC_EnableInterrupts(SEMC_Type * base,uint32_t mask)762 static inline void SEMC_EnableInterrupts(SEMC_Type *base, uint32_t mask)
763 {
764     base->INTEN |= mask;
765 }
766 
767 /*!
768  * @brief Disables the SEMC interrupt.
769  *
770  * This function disables the SEMC interrupts according to the provided mask. The mask
771  * is a logical OR of enumeration members. See @ref semc_interrupt_enable_t.
772  * For example, to disable the IP command done and error interrupt, do the following.
773  * @code
774  *     SEMC_DisableInterrupts(ENET, kSEMC_IPCmdDoneInterrupt | kSEMC_IPCmdErrInterrupt);
775  * @endcode
776  *
777  * @param base  SEMC peripheral base address.
778  * @param mask  SEMC interrupts to disable. This is a logical OR of the
779  *             enumeration :: semc_interrupt_enable_t.
780  */
SEMC_DisableInterrupts(SEMC_Type * base,uint32_t mask)781 static inline void SEMC_DisableInterrupts(SEMC_Type *base, uint32_t mask)
782 {
783     base->INTEN &= ~mask;
784 }
785 
786 /*!
787  * @brief Gets the SEMC status.
788  *
789  * This function gets the SEMC interrupts event status.
790  * User can use the a logical OR of enumeration member as a mask.
791  * See @ref semc_interrupt_enable_t.
792  *
793  * @param base  SEMC peripheral base address.
794  * @return status flag, use status flag in semc_interrupt_enable_t to get the related status.
795  */
SEMC_GetStatusFlag(SEMC_Type * base)796 static inline bool SEMC_GetStatusFlag(SEMC_Type *base)
797 {
798     return (base->INTR != 0x00U) ? true : false;
799 }
800 
801 /*!
802  * @brief Clears the SEMC status flag state.
803  *
804  * The following status register flags can be cleared SEMC interrupt status.
805  *
806  * @param base SEMC base pointer
807  * @param mask The status flag mask, a logical OR of enumeration member @ref semc_interrupt_enable_t.
808  */
SEMC_ClearStatusFlags(SEMC_Type * base,uint32_t mask)809 static inline void SEMC_ClearStatusFlags(SEMC_Type *base, uint32_t mask)
810 {
811     base->INTR |= mask;
812 }
813 
814 /*! @} */
815 
816 /*!
817  * @name SEMC Memory Access Operation
818  * @{
819  */
820 
821 /*!
822  * @brief Check if SEMC is in idle.
823  *
824  * @param base  SEMC peripheral base address.
825  * @return  True SEMC is in idle, false is not in idle.
826  */
SEMC_IsInIdle(SEMC_Type * base)827 static inline bool SEMC_IsInIdle(SEMC_Type *base)
828 {
829     return ((base->STS0 & SEMC_STS0_IDLE_MASK) != 0x00U) ? true : false;
830 }
831 
832 /*!
833  * @brief SEMC IP command access.
834  *
835  * @param base  SEMC peripheral base address.
836  * @param memType  SEMC memory type. refer to "semc_mem_type_t"
837  * @param address  SEMC device address.
838  * @param command  SEMC IP command.
839  * For NAND device, we should use the SEMC_BuildNandIPCommand to get the right nand command.
840  * For NOR/DBI device, take refer to "semc_ipcmd_nor_dbi_t".
841  * For SRAM device, take refer to "semc_ipcmd_sram_t".
842  * For SDRAM device, take refer to "semc_ipcmd_sdram_t".
843  * @param write  Data for write access.
844  * @param read   Data pointer for read data out.
845  */
846 status_t SEMC_SendIPCommand(
847     SEMC_Type *base, semc_mem_type_t memType, uint32_t address, uint32_t command, uint32_t write, uint32_t *read);
848 
849 /*!
850  * @brief Build SEMC IP command for NAND.
851  *
852  * This function build SEMC NAND IP command. The command is build of user command code,
853  * SEMC address mode and SEMC command mode.
854  *
855  * @param userCommand  NAND device normal command.
856  * @param addrMode  NAND address mode. Refer to "semc_ipcmd_nand_addrmode_t".
857  * @param cmdMode   NAND command mode. Refer to "semc_ipcmd_nand_cmdmode_t".
858  */
SEMC_BuildNandIPCommand(uint8_t userCommand,semc_ipcmd_nand_addrmode_t addrMode,semc_ipcmd_nand_cmdmode_t cmdMode)859 static inline uint16_t SEMC_BuildNandIPCommand(uint8_t userCommand,
860                                                semc_ipcmd_nand_addrmode_t addrMode,
861                                                semc_ipcmd_nand_cmdmode_t cmdMode)
862 {
863     return ((uint16_t)userCommand << 8U) | ((uint16_t)addrMode << 4U) | ((uint16_t)cmdMode & 0x000FU);
864 }
865 
866 /*!
867  * @brief Check if the NAND device is ready.
868  *
869  * @param base  SEMC peripheral base address.
870  * @return  True NAND is ready, false NAND is not ready.
871  */
SEMC_IsNandReady(SEMC_Type * base)872 static inline bool SEMC_IsNandReady(SEMC_Type *base)
873 {
874     return ((base->STS0 & SEMC_STS0_NARDY_MASK) != 0x00U) ? true : false;
875 }
876 
877 /*!
878  * @brief SEMC NAND device memory write through IP command.
879  *
880  * @param base  SEMC peripheral base address.
881  * @param address  SEMC NAND device address.
882  * @param data  Data for write access.
883  * @param size_bytes   Data length.
884  */
885 status_t SEMC_IPCommandNandWrite(SEMC_Type *base, uint32_t address, uint8_t *data, uint32_t size_bytes);
886 
887 /*!
888  * @brief SEMC NAND device memory read through IP command.
889  *
890  * @param base  SEMC peripheral base address.
891  * @param address  SEMC NAND device address.
892  * @param data  Data pointer for data read out.
893  * @param size_bytes   Data length.
894  */
895 status_t SEMC_IPCommandNandRead(SEMC_Type *base, uint32_t address, uint8_t *data, uint32_t size_bytes);
896 
897 /*!
898  * @brief SEMC NOR device memory write through IP command.
899  *
900  * @param base  SEMC peripheral base address.
901  * @param address  SEMC NOR device address.
902  * @param data  Data for write access.
903  * @param size_bytes   Data length.
904  */
905 status_t SEMC_IPCommandNorWrite(SEMC_Type *base, uint32_t address, uint8_t *data, uint32_t size_bytes);
906 
907 /*!
908  * @brief SEMC NOR device memory read through IP command.
909  *
910  * @param base  SEMC peripheral base address.
911  * @param address  SEMC NOR device address.
912  * @param data  Data pointer for data read out.
913  * @param size_bytes   Data length.
914  */
915 status_t SEMC_IPCommandNorRead(SEMC_Type *base, uint32_t address, uint8_t *data, uint32_t size_bytes);
916 
917 /*! @} */
918 
919 #if defined(__cplusplus)
920 }
921 #endif
922 
923 /*! @}*/
924 
925 #endif /* FSL_SEMC_H_*/
926