![]() |
M480 BSP V3.05.006
The Board Support Package for M480 Series
|
#include <spim_reg.h>
Data Fields | |
__IO uint32_t | CTL0 |
__IO uint32_t | CTL1 |
__IO uint32_t | RXCLKDLY |
__I uint32_t | RX [4] |
__IO uint32_t | TX [4] |
__IO uint32_t | SRAMADDR |
__IO uint32_t | DMACNT |
__IO uint32_t | FADDR |
__O uint32_t | KEY1 |
__O uint32_t | KEY2 |
__IO uint32_t | DMMCTL |
__IO uint32_t | CTL2 |
@addtogroup SPIM Serial Peripheral Interface Controller Master Mode (SPIM) Memory Mapped Structure for SPIM Controller
Definition at line 26 of file spim_reg.h.
SPIM_T::CTL0 |
[0x0000] Control and Status Register 0
Bits | Field | Descriptions |
[0] | CIPHOFF | Cipher Disable Control
0 = Cipher function Enabled. 1 = Cipher function Disabled. Note1: If there is not any KEY1(SPIM_KEY1[31:0]) or KEY2(SPIM_KEY2[31:0]) (KEY1 is 0x0000_0000 or KEY2 is 0x0000_0000), the cipher function will be disabled automatically. Note2: When CIPHOFF(SPIM_CTL0[0]) is 0, both of KEY1(SPIM_KEY1[31:0]) and KEY2(SPIM_KEY2[31:0]) do not equal to 0x0000_0000 (i.e. KEY1 != 0x0000_0000 and KEY2 != 0x0000_0000), cipher encryption/decryption is enabled. Note3 : When cipher encryption/decryption is enabled, please set DESELTIM (SPIM_DMMCTL[20:16]) >= 0x10. When cipher encryption/decryption is disabled, please set DESELTIM(SPIM_DMMCTL[20:16]) >= 0x8. |
[2] | BALEN | Balance the AHB Control Time Between Cipher Enable and Disable Control
When cipher is enabled, the AHB control signal will delay some time caused by the encoding or decoding calculation Therefore, if set BALEN to 1, it will make the AHB signal processing time with cipher disabled be equal to that with cipher enabled. Note: Only useful when cipher is disabled. |
[5] | B4ADDREN | 4-byte Address Mode Enable Control
0 = 4-byte address mode is disabled, and 3-byte address mode is enabled. 1 = 4-byte address mode is enabled. Note: Used for DMA write mode, DMA read mode, and DMM mode. |
[6] | IEN | Interrupt Enable Control
0 = SPIM Interrupt Disabled. 1 = SPIM Interrupt Enabled. |
[7] | IF | Interrupt Flag
(1) Write Operation : 0 = No effect. 1 = Write 1 to clear. (2) Read Operation : 0 = The transfer has not finished yet. 1 = The transfer has done. |
[12:8] | DWIDTH | Transmit/Receive Bit Length
This specifies how many bits are transmitted/received in one transmit/receive transaction. 0x7 = 8 bits. 0xF = 16 bits. 0x17 = 24 bits. 0x1F = 32 bits. Others = Incorrect transfer result. Note1: Only used for normal I/O mode. Note2: Only 8, 16, 24, and 32 bits are allowed. Other bit length will result in incorrect transfer. |
[14:13] | BURSTNUM | Transmit/Receive Burst Number
This field specifies how many transmit/receive transactions should be executed continuously in one transfer. 0x0 = Only one transmit/receive transaction will be executed in one transfer. 0x1 = Two successive transmit/receive transactions will be executed in one transfer. 0x2 = Three successive transmit/receive transactions will be executed in one transfer. 0x3 = Four successive transmit/receive transactions will be executed in one transfer. Note: Only used for normal I/O Mode. |
[15] | QDIODIR | SPI Interface Direction Select for Quad/Dual Mode
0 = Interface signals are input. 1 = Interface signals are output. Note: Only used for normal I/O mode. |
[19:16] | SUSPITV | Suspend Interval
These four bits provide the configuration of suspend interval between two successive transmit/receive transactions in a transfer The default value is 0x00 When BURSTNUM = 00, setting this field has no effect on transfer The desired interval is obtained according to the following equation (from the last falling edge of current SPI clock to the first rising edge of next SPI clock): (SUSPITV+2)*period of AHB clock 0x0 = 2 AHB clock cycles. 0x1 = 3 AHB clock cycles. ...... 0xE = 16 AHB clock cycles. 0xF = 17 AHB clock cycles. Note: Only used for normal I/O mode. |
[21:20] | BITMODE | SPI Interface Bit Mode
0x0 = Standard mode. 0x1 = Dual mode. 0x2 = Quad mode. 0x3 = Reserved. Note: Only used for normal I/O mode. |
[23:22] | OPMODE | SPI Function Operation Mode
0x0 = Normal I/O mode. (Note1) (Note3) 0x1 = DMA write mode. (Note2) (Note3) 0x2 = DMA read mode. (Note3) 0x3 = Direct Memory Mapping mode (DMM mode) (Default). (Note4) Note1 : After user uses Normal I/O mode of SPI flash controller to program the content of external SPI flash, please set CDINVAL(SPIM_CTL1[3]) to 0x1 (Set all cache data to be invalid). Note2 : In DMA write mode, hardware will send just one page program command per operation Users must take care of cross-page cases After user uses DMA write mode of SPI flash controller to program the content of external SPI flash, please set CDINVAL(SPIM_CTL1[3]) to 0x1 (Set all cache data to be invalid). Note3 : For external SPI flash with 32 MB, access address range of external SPI flash address is from 0x00000000 to 0x01FFFFFF when user uses Normal I/O mode, DMA write mode, and DMA read mode to write/read external SPI flash data Please user check size of used SPI flash component to know access address range of external SPI flash. Note4 : For external SPI flash with 32 MB, access address range of external SPI flash address is from 0x08000000 to 0x09FFFFFF when user uses Direct Memory mapping mode (DMM mode) to read external SPI flash data Please user check size of used SPI flash component to know access address range of external SPI flash. |
[31:24] | CMDCODE | Page Program Command Code (Note4)
(1) 0x02 = Page program (Used for DMA Write mode). (2) 0x32 = Quad page program with TYPE_1 program flow (Used for DMA Write mode). (Note3) (3) 0x38 = Quad page program with TYPE_2 program flow (Used for DMA Write mode). (Note3) (4) 0x40 = Quad page program with TYPE_3 program flow (Used for DMA Write mode). (Note3) The Others = Reserved. Read Command Code : (1) 0x03 = Standard Read (Used for DMA Read/DMM mode). (2) 0x0B = Fast Read (Used for DMA Read/DMM mode). The fast read command code "0x0B" is similar to command code of standard read "0x03" except it can operate at highest possible frequency (Note2) (3) 0x3B = Fast Read Dual Output (Used for DMA Read/DMM mode). (4) 0xBB = Fast Read Dual I/O (Used for DMA Read/DMM mode). The fast read dual I/O command code "0xBB" is similar to command code of fast read dual output "0x3B" but with capability to input the address bits two bits per clock (Note2) (5) 0xEB = Fast quad read (Used for DMA Read/DMM mode). (6) 0xE7 = Word quad read (Used for DMA Read/DMM mode). The command code of word quad read "0xE7" is similar to command code of fast quad read "0xEB" except that the lowest address bit must equal to 0 and the number of dummy cycles is less than fast quad read (Note2) (7) 0x0D = DTR/DDR Fast read (Used for DMA Read/DMM mode). (8) 0xBD = DTR/DDR dual read (Used for DMA Read/DMM mode). (9) 0xED = DTR/DDR quad read (Used for DMA Read/DMM mode). The Others command codes are Reserved. The DTR/DDR read commands "0x0D,0xBD,0xED" improves throughput by transferring address and data on both the falling and rising edge of SPI flash clock (SPIM_CLK) It is similar to those commands "0x0B, 0xBB, 0xEB" but allows transfer of address and data on rising edge and falling edge of SPI flash output clock (Note2) Note1: Quad mode of SPI Flash must be enabled first by normal I/O mode before using quad page program/quad read commands. Note2: See SPI flash specifications for support items. Note3: For TYPE_1, TYPE_2, and TYPE_3 of page program command code, refer to Figure 7.19-3, Figure 7.19-4, and Figure 7.19-5. Note4: Please disable "continuous read mode" and "burst wrap mode" before DMA write mode of SPI flash controller is used to program data of external SPI flash After user uses DMA write mode of SPI flash controller to program the content of external SPI flash, please set CDINVAL(SPIM_CTL1[3]) to 0x1 (Set all cache data to be invalid). |
Definition at line 862 of file spim_reg.h.
SPIM_T::CTL1 |
[0x0004] Control Register 1
Bits | Field | Descriptions |
[0] | SPIMEN | Go and Busy Status
(1) Write Operation : 0 = No effect. 1 = Start the transfer This bit remains set during the transfer and is automatically cleared after transfer finished. (2) Read Operation : 0 = The transfer has done. 1 = The transfer has not finished yet. Note: All registers should be set before writing 1 to the SPIMEN bit When a transfer is in progress, you should not write to any register of this peripheral. |
[1] | CACHEOFF | Cache Memory Function Disable Control
0 = Cache memory function enable. (Default value) 1 = Cache memory function disable. Note: When CCM mode is enabled, the cache function will be disable by hardware automatically When CCM mode is disabled, the cache function can be enable or disable by user. |
[2] | CCMEN | CCM (Core Coupled Memory) Mode Enable Control
0 = CCM mode disable. (Default value) 1 = CCM mode enable. Note1: When CCM mode is enabled, the cache function will be disable by hardware automatically When CCM mode is disabled, the cache function can be enabled or disabled by user. Note2: When CCM mode is disabled, user accesses the core coupled memory by bus master In this case, the SPI flash controller will send error response via HRESP bus signal to bus master. Note3: When CCM mode needs to be enabled, user sets CCMEN to 1 and needs to read this register to show the current hardware status When reading data of CCMEN is 1, MCU can start to read data from CCM memory space or write data to CCM memory space. |
[3] | CDINVAL | Cache Data Invalid Enable Control
(1) Write Operation: 0 = No effect. 1 = Set all cache data to be invalid. This bit is cleared by hardware automatically. (2) Read Operation : No effect Note: When SPI flash memory is page erasing or whole flash erasing, please set CDINVAL to 0x1 After user uses normal I/O mode or DMA write mode of SPI flash controller to program or erase the content of external SPI flash, please set CDINVAL to 0x1. |
[4] | SS | Slave Select Active Enable Control
0 = SPIM_SS is in active level. 1 = SPIM_SS is in inactive level (Default). Note: This interface can only drive one device/slave at a given time Therefore, the slave selects of the selected device must be set to its active level before starting any read or write transfer Functional description of SSACTPOL(SPIM_CTL1[5]) and SS is shown in Table 2. |
[5] | SSACTPOL | Slave Select Active Level
It defines the active level of device/slave select signal (SPIM_SS), and we show in Table 2. 0 = The SPIM_SS slave select signal is active low. 1 = The SPIM_SS slave select signal is active high. |
[11:8] | IDLETIME | Idle Time Interval
In DMM mode, IDLETIME is set to control the minimum idle time between two SPI Flash accesses. Minimum idle time = (IDLETIME + 1) * AHB clock cycle time. Note1: Only used for DMM mode. Note2 : AHB clock cycle time = 1/AHB clock frequency. |
[31:16] | DIVIDER | Clock Divider Register
The value in this field is the frequency divider of the AHB clock (HCLK) to generate the serial SPI output clock "SCLK" on the output SPIM_CLK pin The desired frequency is obtained according to the following equation: Note1: When set DIVIDER to zero, the frequency of SPIM_CLK will be equal to the frequency of HCLK. Note2: SCLK is serial SPI output clock. Note3: Please check the specification of the used SPI flash component to decide the frequency of SPI flash clock. Note4: For DTR/DDR read commands "0x0D, 0xBD, 0xED", the setting values of DIVIDER are only 1,2,4,8,16,32,..., where n = 0,1,2,3,4, ... |
Definition at line 863 of file spim_reg.h.
SPIM_T::CTL2 |
[0x0048] Control Register 2
Bits | Field | Descriptions |
[16] | USETEN | User Set Value Enable Control
Only for direct memory mapping mode and DMA read mode with read commands 0x03,0x0B,0x3B,0xBB,0xEB,0xE7 0 = Hardware circuit of SPI flash controller will use the following default values of DCNUM(SPIM_CTL2[28:24]) and CRMDAT(SPIM_DMMCTL[15:8]) to configure SPI flash operations automatically. Dummy cycle number (DCNUM) : Dummy cycle number for read command 0x03 : 0x0 Dummy cycle number for read command 0x0B : 0x8 Dummy cycle number for read command 0x3B : 0x8 Dummy cycle number for read command 0xBB : 0x0 Dummy cycle number for read command 0xEB : 0x4 Dummy cycle number for read command 0xE7 : 0x2 Mode bits data for continuous read mode (CRMDAT) : 0x20 1 = If DCNUM(SPIM_CTL2[28:24]) and CRMDAT(SPIM_DMMCTL[15:8]) are not set as above default values, user must set USETEN to 0x1, DCNUM(SPIM_CTL2[28:24]) and CRMDAT(SPIM_DMMCTL[15:8]) to configure SPI flash operations manually. For DTR/DDR command codes 0x0D, 0xBD, and 0xED, please set USETEN to 0x1. |
[20] | DTRMPOFF | Mode Phase OFF for DTR/DDR Command Codes 0x0D, 0xBD, and 0xED
Only for direct memory mapping mode and DMA read mode (Note1) 0 = mode cycle number (or performance enhance cycle number) does not equal to 0x0 in DTR/DDR read command codes 0x0D, 0xBD, and 0xED. 1 = mode cycle number (or performance enhance cycle number) equals to 0x0 in DTR/DDR read command codes 0x0D, 0xBD, and 0xED. Note1 : Please check the used SPI flash specification to know the mode cycle number (or performance enhance cycle number) for DTR/DDR command codes 0x0D, 0xBD, and 0xED. |
[28:24] | DCNUM | Dummy Cycle Number
Only for direct memory mapping mode and DMA read mode (Note1) Set number of dummy cycles (1) For non-DTR/non-DDR command codes 0x03, 0x0B, 0x3B, 0xBB, 0xEB, and 0xE7 : When read command code do not need any dummy cycles (i.e. dummy cycle number = 0x0), user must set DCNUM to 0x0. For command code 0xBB, if both mode cycle number (or performance enhance cycle number) and dummy cycle number do not equal to 0x0 simultaneously, user must set DCNUM to "mode cycle number + dummy cycle number" by used SPI flash specification. For command code 0xBB, if there is only dummy cycle number (i.e. dummy cycle number != 0x0 and mode cycle number = 0x0 (or performance enhance cycle number = 0x0)), user set DCNUM to dummy cycle number by used SPI flash specification. For command codes 0x0B, 0x3B, 0xEB, and 0xE7, user only set DCNUM to dummy cycle number by used SPI flash specification. (2) For DTR/DDR command codes 0x0D, 0xBD, and 0xED : user sets DCNUM to dummy cycle number and DTRMPOFF(SPIM_CTL2[20]) by used SPI flash specification. Note1 : Number of dummy cycles depends on the frequency of SPI output clock, SPI flash vendor, and read command types Please check the used SPI flash specification to know the setting value of this number of dummy cycles. |
Definition at line 876 of file spim_reg.h.
SPIM_T::DMACNT |
[0x0034] DMA Transfer Byte Count Register
Bits | Field | Descriptions |
[23:0] | DMACNT | DMA Transfer Byte Count Register
It indicates the transfer length for DMA process. Note1: The unit for counting is byte. Note2: The number must be the multiple of 4. Note3: Please check specification of used SPI flash to know maximum byte length of page program. |
Definition at line 871 of file spim_reg.h.
SPIM_T::DMMCTL |
[0x0044] Direct Memory Mapping Mode Control Register
Bits | Field | Descriptions |
[15:8] | CRMDAT | Mode bits data for Continuous Read Mode (or performance enhance mode) (Default value = 0)
Only for direct memory mapping mode Set the mode bits data for continuous read mode (or performance enhance mode). When we set this mode bits currently (Note1) and set CREN(SPIM_DMMCTL[25]), this reduces the command phase by eight clocks and allows the read address to be immediately entered after SPIM_SS asserted to active (Note1) Note1 : Please check the used SPI flash specification to know the setting value of this mode bits data, and different SPI flash vendor may use different setting values. Note2 : CRMDAT needs to used with CREN(SPIM_DMMCTL[25]). |
[20:16] | DESELTIM | SPI Flash Deselect Time
Only for direct memory mapping mode Set the minimum time width of SPI flash deselect time (i.e. Minimum SPIM_SS deselect time), and we show in Figure 7.19-8. (1) Cache function disable : Minimum time width of SPIM_SS deselect time = (DESELTIM + 1) * AHB clock cycle time. (2) Cache function enable : Minimum time width of SPIM_SS deselect time = (DESELTIM + 4) * AHB clock cycle time. Note1 : AHB clock cycle time = 1/AHB clock frequency. Note2 : When cipher encryption/decryption is enabled, please set this register value >= 0x10 When cipher encryption/decryption is disabled, please set this register value >= 0x8. Note3 : Please check the used SPI flash specification to know the setting value of this register, and different SPI flash vendor may use different setting values. |
[24] | BWEN | 16 bytes Burst Wrap Mode Enable Control Register (Default value = 0)
Only for WINBOND SPI flash, direct memory mapping mode, Cache enable, and read command code "0xEB, and 0xE7" 0 = Burst Wrap Mode Disable. (Default) 1 = Burst Wrap Mode Enable. In direct memory mapping mode, both of quad read commands "0xEB" and "0xE7" support burst wrap mode for cache application and performance enhance For cache application, the burst wrap mode can be used to fill the cache line quickly (In this SPI flash controller, we use cache data line with 16 bytes size) For performance enhance with direct memory mapping mode and cache enable, when cache data is miss, the burst wrap mode can let MCU get the required SPI flash data quickly. |
[25] | CREN | Continuous Read Mode Enable Control
Only for direct memory mapping mode, read command codes 0xBB, 0xEB, 0xE7, 0x0D, 0xBD, 0xED (Note2) 0 = Continuous Read Mode Disable. (Default) 1 = Continuous Read Mode Enable. For read operations of SPI flash, commands of fast read quad I/O (0xEB), word read quad I/O (0xE7 in Winbond SPI flash), fast read dual I/O (0xBB), DTR/DDR fast read (0x0D), DTR/DDR fast read dual I/O (0xBD), and DTR/DDR fast read quad I/O (0xED) can further reduce command overhead through setting the "continuous read mode" bits (8 bits) after the input address data. Note: When user uses function of continuous read mode and sets USETEN (SPIM_CTL2[16]) to 1, CRMDAT(SPIM_DMMCTL[15:8]) must be set by used SPI flash specifications When user uses function of continuous read mode and sets USETEN(SPIM_CTL2[16]) to 0, CRMDAT(SPIM_DMMCTL[15:8]) is set by default value of WINBOND SPI flash. |
[26] | UACTSCLK | User Sets SPI Flash Active SCLK Time
Only for direct memory mapping mode, DMA write mode, and DMA read mode 0 = According to DIVIDER(SPIM_CTL1[31:16]), ACTSCLKT(SPIM_DMMCTL[31:28]) is set by hardware automatically (Default value) 1 = Set ACTSCLKT(SPIM_DMMCTL[31:28]) by user manually. When user wants to set ACTSCLKT(SPIM_DMMCTL[31:28]) manually, please set UACTSCLK to 1. |
[31:28] | ACTSCLKT | SPI Flash Active SCLK Time
Only for direct memory mapping mode, DMA write mode, and DMA read mode This register sets time interval between SPIM SS active edge and the position edge of the first serial SPI output clock, and we show in Figure 7.19-8. (1) ACTSCLKT = 0 (function disable) :. Time interval = 1 AHB clock cycle time. (2) ACTSCLKT != 0 (function enable) : Time interval = (ACTSCLKT + 3) * AHB clock cycle time. Note1 : AHB clock cycle time = 1/AHB clock frequency. Note2 : SCLK is SPI output clock Note3 : Please check the used SPI flash specification to know the setting value of this register, and different SPI flash vendor may use different setting values. |
Definition at line 875 of file spim_reg.h.
SPIM_T::FADDR |
[0x0038] SPI Flash Address Register
Bits | Field | Descriptions |
[31:0] | ADDR | SPI Flash Address Register
For DMA Read mode, this is the source address for DMA transfer. For DMA Write mode, this is the destination address for DMA transfer. Note 1 : This address must be word-aligned. Note 2 : For external SPI flash with 32 MB, the value of this SPI flash address register "ADDR" is from 0x00000000 to 0x01FFFFFF when user uses DMA write mode and DMA read mode to write/read external SPI flash data Please user check size of used SPI flash component to know access address range of external SPI flash. |
Definition at line 872 of file spim_reg.h.
SPIM_T::KEY1 |
[0x003c] Cipher Key1 Register
Bits | Field | Descriptions |
[31:0] | KEY1 | Cipher Key1 Register
This is the KEY1 data for cipher function. Note1: If there is not any KEY1(SPIM_KEY1[31:0]) or KEY2(SPIM_KEY2[31:0]) (KEY1 is 0x0000_0000 or KEY2 is 0x0000_0000), the cipher function will be disabled automatically. Note2: When CIPHOFF(SPIM_CTL0[0]) is 0, both of KEY1(SPIM_KEY1[31:0]) and KEY2(SPIM_KEY2[31:0]) do not equal to 0x0000_0000 (i.e. KEY1 != 0x0000_0000 and KEY2 != 0x0000_0000), cipher encryption/decryption is enabled. |
Definition at line 873 of file spim_reg.h.
SPIM_T::KEY2 |
[0x0040] Cipher Key2 Register
Bits | Field | Descriptions |
[31:0] | KEY2 | Cipher Key2 Register
This is the KEY2 data for cipher function. Note1: If there is not any KEY1(SPIM_KEY1[31:0]) or KEY2(SPIM_KEY2[31:0]) (KEY1 is 0x0000_0000 or KEY2 is 0x0000_0000), the cipher function will be disabled automatically. Note2: When CIPHOFF(SPIM_CTL0[0]) is 0, both of KEY1(SPIM_KEY1[31:0]) and KEY2(SPIM_KEY2[31:0]) do not equal to 0x0000_0000 (i.e. KEY1 != 0x0000_0000 and KEY2 != 0x0000_0000), cipher encryption/decryption is enabled. |
Definition at line 874 of file spim_reg.h.
SPIM_T::RX[4] |
[0x0010] ~ [0x001C] Data Receive Register 0~3
Bits | Field | Descriptions |
[31:0] | RXDAT | Data Receive Register
The Data Receive Registers hold the received data of the last executed transfer. Number of valid RX registers is specified in SPIM_CTL0[BURSTNUM] If BURSTNUM > 0, received data are held in the most significant RXDAT register first. Number of valid-bit is specified in SPIM_CTL0[DWIDTH] If DWIDTH is 16, 24, or 32, received data are held in the least significant byte of RXDAT register first. In a byte, received data are held in the most significant bit of RXDAT register first. Example 1: If SPIM_CTL0[BURSTNUM] = 0x3 and SPIM_CTL1[DWIDTH] = 0x17, received data will be held in the order SPIM_RX3[23:0], SPIM_RX2[23:0], SPIM_RX1[23:0], SPIM_RX0[23:0]. Example 2: If SPIM_CTL0[BURSTNUM = 0x0 and SPIM_CTL0[DWIDTH] = 0x17, received data will be held in the order SPIM_RX0[7:0], SPIM_RX0[15:8], SPIM_RX0[23:16]. Example 3: If SPIM_CTL0[BURSTNUM = 0x0 and SPIM_CTL0[DWIDTH] = 0x07, received data will be held in the order SPIM_RX0[7], SPIM_RX0[6], ..., SPIM_RX0[0]. |
Definition at line 868 of file spim_reg.h.
SPIM_T::RXCLKDLY |
[0x000c] RX Clock Delay Control Register
Bits | Field | Descriptions |
[7:0] | DWDELSEL | SPI flash deselect time interval of DMA write mode
For DMA write mode only This register sets the deselect time interval of SPI flash (i.e. time interval of inactive level of SPIM_SS) when SPI flash controller operates on DMA write mode (Note1) Deselect time interval of DMA write mode = (DWDELSEL + 1) * AHB clock cycle time (Note2). Note1: Please user check the used external SPI flash component to set this register value In general case, the deselect time interval of SPI flash is greater than 50 ns when SPI flash performs the program operation. Note2: AHB clock cycle time = 1/AHB clock frequency. |
[18:16] | RDDLYSEL | Sampling Clock Delay Selection for Received Data
For Normal I/O mode, DMA read mode, DMA write mode, and direct memory mapping mode Determine the number of inserted delay cycles Used to adjust the sampling clock of received data to latch the correct data. 0x0 : No delay. (Default Value) 0x1 : Delay 1 SPI flash clock. 0x2 : Delay 2 SPI flash clocks. 0x3 : Delay 3 SPI flash clocks. ... 0x7 : Delay 7 SPI flash clocks Note : We can use manufacturer id or device id of external SPI flash component to determine the correct setting value of RDDLYSEL, and we give example as follows. For example, manufacturer id and device id of external SPI flash for some vendor are 0xEF and 0x1234 separately Firstly, we set RDDLYSEL to 0x0, and use read manufacturer id/device id command to read the manufacturer id of external SPI flash by using normal I/O mode (the manufacturer id is 0xEF (1110_1111) in this example). If manufacturer id which reads from external SPI flash is 0xF7 (1111_0111), it denotes that manufacturer id is shifted the right by 1 bit and most significant bit (MSB) of manufacturer id is assigned to 1 According to manufacturer id reads from external SPI flash, we need to set RDDLYSEL to 0x1 to receive SPI flash data correctly. |
[20] | RDEDGE | Sampling Clock Edge Selection for Received Data
For Normal I/O mode, DMA read mode, DMA write mode, and direct memory mapping mode 0 : Use SPI input clock rising edge to sample received data. (Default Value) 1 : Use SPI input clock falling edge to sample received data. |
Definition at line 867 of file spim_reg.h.
SPIM_T::SRAMADDR |
[0x0030] SRAM Memory Address Register
Bits | Field | Descriptions |
[31:0] | ADDR | SRAM Memory Address
For DMA Read mode, this is the destination address for DMA transfer. For DMA Write mode, this is the source address for DMA transfer. Note: This address must be word-aligned. |
Definition at line 870 of file spim_reg.h.
SPIM_T::TX[4] |
[0x0020] ~ [0x002C] Data Transmit Register 0~3
Bits | Field | Descriptions |
[31:0] | TXDAT | Data Transmit Register
The Data Transmit Registers hold the data to be transmitted in next transfer. Number of valid TXDAT registers is specified in SPIM_CTL0[BURSTNUM] If BURSTNUM > 0, data are transmitted in the most significant TXDAT register first. Number of valid-bit is specified in SPIM_CTL0[DWIDTH] If DWIDTH is 16, 24, or 32, data are transmitted in the least significant byte of TXDAT register first. In a byte, data are transmitted in the most significant bit of TXDAT register first. Example 1: If SPIM_CTL0[BURSTNUM] = 0x3 and SPIM_CTL1[DWIDTH] = 0x17, data will be transmitted in the order SPIM_TX3[23:0], SPIM_TX2[23:0], SPIM_TX1[23:0], SPIM_TX0[23:0] in next transfer. Example 2: If SPIM_CTL0[BURSTNUM] = 0x0 and SPIM_CTL0[DWIDTH] = 0x17, data will be transmitted in the order SPIM_TX0[7:0], SPIM_TX0[15:8], SPIM_TX0[23:16] in next transfer. Example 3: If SPIM_CTL0[BURSTNUM] = 0x0 and SPIM_CTL0[DWIDTH] = 0x07, data will be transmitted in the order SPIM_TX0[7], SPIM_TX0[6], ..., SPIM_TX0[0] in next transfer. |
Definition at line 869 of file spim_reg.h.