2021-06-16 18:04:18 +08:00

2242 lines
117 KiB
C

// Copyright 2017-2021 Espressif Systems (Shanghai) PTE LTD
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef _SOC_SPI_MEM_REG_H_
#define _SOC_SPI_MEM_REG_H_
#include "soc.h"
#ifdef __cplusplus
extern "C" {
#endif
#define SPI_MEM_CMD_REG(i) (REG_SPI_MEM_BASE(i) + 0x0)
/* SPI_MEM_FLASH_READ : R/W/SC ;bitpos:[31] ;default: 1'b0 ; */
/*description: Read flash enable. Read flash operation will be triggered when the bit is set. T
he bit will be cleared once the operation done. 1: enable 0: disable. .*/
#define SPI_MEM_FLASH_READ (BIT(31))
#define SPI_MEM_FLASH_READ_M (BIT(31))
#define SPI_MEM_FLASH_READ_V 0x1
#define SPI_MEM_FLASH_READ_S 31
/* SPI_MEM_FLASH_WREN : R/W/SC ;bitpos:[30] ;default: 1'b0 ; */
/*description: Write flash enable. Write enable command will be sent when the bit is set. The
bit will be cleared once the operation done. 1: enable 0: disable. .*/
#define SPI_MEM_FLASH_WREN (BIT(30))
#define SPI_MEM_FLASH_WREN_M (BIT(30))
#define SPI_MEM_FLASH_WREN_V 0x1
#define SPI_MEM_FLASH_WREN_S 30
/* SPI_MEM_FLASH_WRDI : R/W/SC ;bitpos:[29] ;default: 1'b0 ; */
/*description: Write flash disable. Write disable command will be sent when the bit is set. The
bit will be cleared once the operation done. 1: enable 0: disable. .*/
#define SPI_MEM_FLASH_WRDI (BIT(29))
#define SPI_MEM_FLASH_WRDI_M (BIT(29))
#define SPI_MEM_FLASH_WRDI_V 0x1
#define SPI_MEM_FLASH_WRDI_S 29
/* SPI_MEM_FLASH_RDID : R/W/SC ;bitpos:[28] ;default: 1'b0 ; */
/*description: Read JEDEC ID . Read ID command will be sent when the bit is set. The bit will b
e cleared once the operation done. 1: enable 0: disable. .*/
#define SPI_MEM_FLASH_RDID (BIT(28))
#define SPI_MEM_FLASH_RDID_M (BIT(28))
#define SPI_MEM_FLASH_RDID_V 0x1
#define SPI_MEM_FLASH_RDID_S 28
/* SPI_MEM_FLASH_RDSR : R/W/SC ;bitpos:[27] ;default: 1'b0 ; */
/*description: Read status register-1. Read status operation will be triggered when the bit is
set. The bit will be cleared once the operation done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_RDSR (BIT(27))
#define SPI_MEM_FLASH_RDSR_M (BIT(27))
#define SPI_MEM_FLASH_RDSR_V 0x1
#define SPI_MEM_FLASH_RDSR_S 27
/* SPI_MEM_FLASH_WRSR : R/W/SC ;bitpos:[26] ;default: 1'b0 ; */
/*description: Write status register enable. Write status operation will be triggered when t
he bit is set. The bit will be cleared once the operation done.1: enable 0: disa
ble. .*/
#define SPI_MEM_FLASH_WRSR (BIT(26))
#define SPI_MEM_FLASH_WRSR_M (BIT(26))
#define SPI_MEM_FLASH_WRSR_V 0x1
#define SPI_MEM_FLASH_WRSR_S 26
/* SPI_MEM_FLASH_PP : R/W/SC ;bitpos:[25] ;default: 1'b0 ; */
/*description: Page program enable(1 byte ~64 bytes data to be programmed). Page program operat
ion will be triggered when the bit is set. The bit will be cleared once the ope
ration done .1: enable 0: disable. .*/
#define SPI_MEM_FLASH_PP (BIT(25))
#define SPI_MEM_FLASH_PP_M (BIT(25))
#define SPI_MEM_FLASH_PP_V 0x1
#define SPI_MEM_FLASH_PP_S 25
/* SPI_MEM_FLASH_SE : R/W/SC ;bitpos:[24] ;default: 1'b0 ; */
/*description: Sector erase enable(4KB). Sector erase operation will be triggered when the bit
is set. The bit will be cleared once the operation done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_SE (BIT(24))
#define SPI_MEM_FLASH_SE_M (BIT(24))
#define SPI_MEM_FLASH_SE_V 0x1
#define SPI_MEM_FLASH_SE_S 24
/* SPI_MEM_FLASH_BE : R/W/SC ;bitpos:[23] ;default: 1'b0 ; */
/*description: Block erase enable(32KB) . Block erase operation will be triggered when the bit
is set. The bit will be cleared once the operation done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_BE (BIT(23))
#define SPI_MEM_FLASH_BE_M (BIT(23))
#define SPI_MEM_FLASH_BE_V 0x1
#define SPI_MEM_FLASH_BE_S 23
/* SPI_MEM_FLASH_CE : R/W/SC ;bitpos:[22] ;default: 1'b0 ; */
/*description: Chip erase enable. Chip erase operation will be triggered when the bit is set. T
he bit will be cleared once the operation done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_CE (BIT(22))
#define SPI_MEM_FLASH_CE_M (BIT(22))
#define SPI_MEM_FLASH_CE_V 0x1
#define SPI_MEM_FLASH_CE_S 22
/* SPI_MEM_FLASH_DP : R/W/SC ;bitpos:[21] ;default: 1'b0 ; */
/*description: Drive Flash into power down. An operation will be triggered when the bit is set
. The bit will be cleared once the operation done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_DP (BIT(21))
#define SPI_MEM_FLASH_DP_M (BIT(21))
#define SPI_MEM_FLASH_DP_V 0x1
#define SPI_MEM_FLASH_DP_S 21
/* SPI_MEM_FLASH_RES : R/W/SC ;bitpos:[20] ;default: 1'b0 ; */
/*description: This bit combined with SPI_MEM_RESANDRES bit releases Flash from the power-down
state or high performance mode and obtains the devices ID. The bit will be clear
ed once the operation done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_RES (BIT(20))
#define SPI_MEM_FLASH_RES_M (BIT(20))
#define SPI_MEM_FLASH_RES_V 0x1
#define SPI_MEM_FLASH_RES_S 20
/* SPI_MEM_FLASH_HPM : R/W/SC ;bitpos:[19] ;default: 1'b0 ; */
/*description: Drive Flash into high performance mode. The bit will be cleared once the operat
ion done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_HPM (BIT(19))
#define SPI_MEM_FLASH_HPM_M (BIT(19))
#define SPI_MEM_FLASH_HPM_V 0x1
#define SPI_MEM_FLASH_HPM_S 19
/* SPI_MEM_USR : R/W/SC ;bitpos:[18] ;default: 1'b0 ; */
/*description: User define command enable. An operation will be triggered when the bit is set.
The bit will be cleared once the operation done.1: enable 0: disable. .*/
#define SPI_MEM_USR (BIT(18))
#define SPI_MEM_USR_M (BIT(18))
#define SPI_MEM_USR_V 0x1
#define SPI_MEM_USR_S 18
/* SPI_MEM_FLASH_PE : R/W/SC ;bitpos:[17] ;default: 1'b0 ; */
/*description: In user mode, it is set to indicate that program/erase operation will be trigger
ed. The bit is combined with SPI_MEM_USR bit. The bit will be cleared once the o
peration done.1: enable 0: disable. .*/
#define SPI_MEM_FLASH_PE (BIT(17))
#define SPI_MEM_FLASH_PE_M (BIT(17))
#define SPI_MEM_FLASH_PE_V 0x1
#define SPI_MEM_FLASH_PE_S 17
#define SPI_MEM_ADDR_REG(i) (REG_SPI_MEM_BASE(i) + 0x4)
/* SPI_MEM_USR_ADDR_VALUE : R/W ;bitpos:[31:0] ;default: 32'h0 ; */
/*description: In user mode, it is the memory address. other then the bit0-bit23 is the memory
address, the bit24-bit31 are the byte length of a transfer..*/
#define SPI_MEM_USR_ADDR_VALUE 0xFFFFFFFF
#define SPI_MEM_USR_ADDR_VALUE_M ((SPI_MEM_USR_ADDR_VALUE_V)<<(SPI_MEM_USR_ADDR_VALUE_S))
#define SPI_MEM_USR_ADDR_VALUE_V 0xFFFFFFFF
#define SPI_MEM_USR_ADDR_VALUE_S 0
#define SPI_MEM_CTRL_REG(i) (REG_SPI_MEM_BASE(i) + 0x8)
/* SPI_MEM_FREAD_QIO : R/W ;bitpos:[24] ;default: 1'b0 ; */
/*description: In hardware 0xEB read operation, ADDR phase and DIN phase apply 4 signals(4-bit-
mode). 1: enable 0: disable. .*/
#define SPI_MEM_FREAD_QIO (BIT(24))
#define SPI_MEM_FREAD_QIO_M (BIT(24))
#define SPI_MEM_FREAD_QIO_V 0x1
#define SPI_MEM_FREAD_QIO_S 24
/* SPI_MEM_FREAD_DIO : R/W ;bitpos:[23] ;default: 1'b0 ; */
/*description: In hardware 0xBB read operation, ADDR phase and DIN phase apply 2 signals(2-bit-
mode). 1: enable 0: disable. .*/
#define SPI_MEM_FREAD_DIO (BIT(23))
#define SPI_MEM_FREAD_DIO_M (BIT(23))
#define SPI_MEM_FREAD_DIO_V 0x1
#define SPI_MEM_FREAD_DIO_S 23
/* SPI_MEM_WRSR_2B : R/W ;bitpos:[22] ;default: 1'b0 ; */
/*description: Two bytes data will be written to status register when it is set. 1: enable 0: d
isable. .*/
#define SPI_MEM_WRSR_2B (BIT(22))
#define SPI_MEM_WRSR_2B_M (BIT(22))
#define SPI_MEM_WRSR_2B_V 0x1
#define SPI_MEM_WRSR_2B_S 22
/* SPI_MEM_WP_REG : R/W ;bitpos:[21] ;default: 1'b1 ; */
/*description: Write protect signal output when SPI is idle. 1: output high, 0: output low. .*/
#define SPI_MEM_WP_REG (BIT(21))
#define SPI_MEM_WP_REG_M (BIT(21))
#define SPI_MEM_WP_REG_V 0x1
#define SPI_MEM_WP_REG_S 21
/* SPI_MEM_FREAD_QUAD : R/W ;bitpos:[20] ;default: 1'b0 ; */
/*description: In hardware 0x6B read operation, DIN phase apply 4 signals(4-bit-mode). 1: enabl
e 0: disable. .*/
#define SPI_MEM_FREAD_QUAD (BIT(20))
#define SPI_MEM_FREAD_QUAD_M (BIT(20))
#define SPI_MEM_FREAD_QUAD_V 0x1
#define SPI_MEM_FREAD_QUAD_S 20
/* SPI_MEM_D_POL : R/W ;bitpos:[19] ;default: 1'b1 ; */
/*description: The bit is used to set MOSI line polarity, 1: high 0, low.*/
#define SPI_MEM_D_POL (BIT(19))
#define SPI_MEM_D_POL_M (BIT(19))
#define SPI_MEM_D_POL_V 0x1
#define SPI_MEM_D_POL_S 19
/* SPI_MEM_Q_POL : R/W ;bitpos:[18] ;default: 1'b1 ; */
/*description: The bit is used to set MISO line polarity, 1: high 0, low.*/
#define SPI_MEM_Q_POL (BIT(18))
#define SPI_MEM_Q_POL_M (BIT(18))
#define SPI_MEM_Q_POL_V 0x1
#define SPI_MEM_Q_POL_S 18
/* SPI_MEM_RESANDRES : R/W ;bitpos:[15] ;default: 1'b1 ; */
/*description: The Device ID is read out to SPI_MEM_RD_STATUS register, this bit combine with
spi_mem_flash_res bit. 1: enable 0: disable. .*/
#define SPI_MEM_RESANDRES (BIT(15))
#define SPI_MEM_RESANDRES_M (BIT(15))
#define SPI_MEM_RESANDRES_V 0x1
#define SPI_MEM_RESANDRES_S 15
/* SPI_MEM_FREAD_DUAL : R/W ;bitpos:[14] ;default: 1'b0 ; */
/*description: In hardware 0x3B read operation, DIN phase apply 2 signals. 1: enable 0: disable
. .*/
#define SPI_MEM_FREAD_DUAL (BIT(14))
#define SPI_MEM_FREAD_DUAL_M (BIT(14))
#define SPI_MEM_FREAD_DUAL_V 0x1
#define SPI_MEM_FREAD_DUAL_S 14
/* SPI_MEM_FASTRD_MODE : R/W ;bitpos:[13] ;default: 1'b1 ; */
/*description: This bit should be set when SPI_MEM_FREAD_QIO, SPI_MEM_FREAD_DIO, SPI_MEM_FREAD_
QUAD or SPI_MEM_FREAD_DUAL is set..*/
#define SPI_MEM_FASTRD_MODE (BIT(13))
#define SPI_MEM_FASTRD_MODE_M (BIT(13))
#define SPI_MEM_FASTRD_MODE_V 0x1
#define SPI_MEM_FASTRD_MODE_S 13
/* SPI_MEM_TX_CRC_EN : R/W ;bitpos:[11] ;default: 1'b0 ; */
/*description: For SPI1, enable crc32 when writing encrypted data to flash. 1: enable 0:disabl
e.*/
#define SPI_MEM_TX_CRC_EN (BIT(11))
#define SPI_MEM_TX_CRC_EN_M (BIT(11))
#define SPI_MEM_TX_CRC_EN_V 0x1
#define SPI_MEM_TX_CRC_EN_S 11
/* SPI_MEM_FCS_CRC_EN : R/W ;bitpos:[10] ;default: 1'b0 ; */
/*description: For SPI1, initialize crc32 module before writing encrypted data to flash. Activ
e low..*/
#define SPI_MEM_FCS_CRC_EN (BIT(10))
#define SPI_MEM_FCS_CRC_EN_M (BIT(10))
#define SPI_MEM_FCS_CRC_EN_V 0x1
#define SPI_MEM_FCS_CRC_EN_S 10
/* SPI_MEM_FCMD_OCT : R/W ;bitpos:[9] ;default: 1'b0 ; */
/*description: Set this bit to enable 8-bit-mode(8-bm) in CMD phase..*/
#define SPI_MEM_FCMD_OCT (BIT(9))
#define SPI_MEM_FCMD_OCT_M (BIT(9))
#define SPI_MEM_FCMD_OCT_V 0x1
#define SPI_MEM_FCMD_OCT_S 9
/* SPI_MEM_FCMD_QUAD : R/W ;bitpos:[8] ;default: 1'b0 ; */
/*description: Set this bit to enable 4-bit-mode(4-bm) in CMD phase..*/
#define SPI_MEM_FCMD_QUAD (BIT(8))
#define SPI_MEM_FCMD_QUAD_M (BIT(8))
#define SPI_MEM_FCMD_QUAD_V 0x1
#define SPI_MEM_FCMD_QUAD_S 8
/* SPI_MEM_FCMD_DUAL : R/W ;bitpos:[7] ;default: 1'b0 ; */
/*description: Set this bit to enable 2-bit-mode(2-bm) in CMD phase..*/
#define SPI_MEM_FCMD_DUAL (BIT(7))
#define SPI_MEM_FCMD_DUAL_M (BIT(7))
#define SPI_MEM_FCMD_DUAL_V 0x1
#define SPI_MEM_FCMD_DUAL_S 7
/* SPI_MEM_FADDR_OCT : R/W ;bitpos:[6] ;default: 1'b0 ; */
/*description: Set this bit to enable 8-bit-mode(8-bm) in ADDR phase..*/
#define SPI_MEM_FADDR_OCT (BIT(6))
#define SPI_MEM_FADDR_OCT_M (BIT(6))
#define SPI_MEM_FADDR_OCT_V 0x1
#define SPI_MEM_FADDR_OCT_S 6
/* SPI_MEM_FDIN_OCT : R/W ;bitpos:[5] ;default: 1'b0 ; */
/*description: Set this bit to enable 8-bit-mode(8-bm) in DIN phase..*/
#define SPI_MEM_FDIN_OCT (BIT(5))
#define SPI_MEM_FDIN_OCT_M (BIT(5))
#define SPI_MEM_FDIN_OCT_V 0x1
#define SPI_MEM_FDIN_OCT_S 5
/* SPI_MEM_FDOUT_OCT : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: Set this bit to enable 8-bit-mode(8-bm) in DOUT phase..*/
#define SPI_MEM_FDOUT_OCT (BIT(4))
#define SPI_MEM_FDOUT_OCT_M (BIT(4))
#define SPI_MEM_FDOUT_OCT_V 0x1
#define SPI_MEM_FDOUT_OCT_S 4
/* SPI_MEM_FDUMMY_OUT : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: In the DUMMY phase the signal level of SPI bus is output by the SPI0 controller..*/
#define SPI_MEM_FDUMMY_OUT (BIT(3))
#define SPI_MEM_FDUMMY_OUT_M (BIT(3))
#define SPI_MEM_FDUMMY_OUT_V 0x1
#define SPI_MEM_FDUMMY_OUT_S 3
#define SPI_MEM_CTRL1_REG(i) (REG_SPI_MEM_BASE(i) + 0xC)
/* SPI_MEM_RXFIFO_RST : R/W ;bitpos:[30] ;default: 1'b0 ; */
/*description: SPI0 RX FIFO reset signal. Set this bit and clear it before SPI0 transfer starts
..*/
#define SPI_MEM_RXFIFO_RST (BIT(30))
#define SPI_MEM_RXFIFO_RST_M (BIT(30))
#define SPI_MEM_RXFIFO_RST_V 0x1
#define SPI_MEM_RXFIFO_RST_S 30
/* SPI_MEM_CS_HOLD_DLY_RES : R/W ;bitpos:[11:2] ;default: 10'h3ff ; */
/*description: After RES/DP/HPM/PES/PER command is sent, SPI1 may waits (SPI_MEM_CS_HOLD_DELAY_
RES[9:0] * 4 or * 256) SPI_CLK cycles..*/
#define SPI_MEM_CS_HOLD_DLY_RES 0x000003FF
#define SPI_MEM_CS_HOLD_DLY_RES_M ((SPI_MEM_CS_HOLD_DLY_RES_V)<<(SPI_MEM_CS_HOLD_DLY_RES_S))
#define SPI_MEM_CS_HOLD_DLY_RES_V 0x3FF
#define SPI_MEM_CS_HOLD_DLY_RES_S 2
/* SPI_MEM_CLK_MODE : R/W ;bitpos:[1:0] ;default: 2'h0 ; */
/*description: SPI Bus clock (SPI_CLK) mode bits. 0: SPI Bus clock (SPI_CLK) is off when CS ina
ctive 1: SPI_CLK is delayed one cycle after SPI_CS inactive 2: SPI_CLK is delaye
d two cycles after SPI_CS inactive 3: SPI_CLK is always on..*/
#define SPI_MEM_CLK_MODE 0x00000003
#define SPI_MEM_CLK_MODE_M ((SPI_MEM_CLK_MODE_V)<<(SPI_MEM_CLK_MODE_S))
#define SPI_MEM_CLK_MODE_V 0x3
#define SPI_MEM_CLK_MODE_S 0
#define SPI_MEM_CTRL2_REG(i) (REG_SPI_MEM_BASE(i) + 0x10)
/* SPI_MEM_SYNC_RESET : R/W/SC ;bitpos:[31] ;default: 1'b0 ; */
/*description: The FSM will be reset..*/
#define SPI_MEM_SYNC_RESET (BIT(31))
#define SPI_MEM_SYNC_RESET_M (BIT(31))
#define SPI_MEM_SYNC_RESET_V 0x1
#define SPI_MEM_SYNC_RESET_S 31
/* SPI_MEM_CS_HOLD_DELAY : R/W ;bitpos:[30:25] ;default: 6'd0 ; */
/*description: These bits are used to set the minimum CS high time tSHSL between SPI burst tran
sfer when accesses to flash. tSHSL is (SPI_MEM_CS_HOLD_DELAY[5:0] + 1) MSPI core
clock cycles..*/
#define SPI_MEM_CS_HOLD_DELAY 0x0000003F
#define SPI_MEM_CS_HOLD_DELAY_M ((SPI_MEM_CS_HOLD_DELAY_V)<<(SPI_MEM_CS_HOLD_DELAY_S))
#define SPI_MEM_CS_HOLD_DELAY_V 0x3F
#define SPI_MEM_CS_HOLD_DELAY_S 25
/* SPI_MEM_ECC_16TO18_BYTE_EN : R/W ;bitpos:[14] ;default: 1'b0 ; */
/*description: Set this bit to enable MSPI ECC 16 bytes data with 2 ECC bytes mode when accesse
s flash..*/
#define SPI_MEM_ECC_16TO18_BYTE_EN (BIT(14))
#define SPI_MEM_ECC_16TO18_BYTE_EN_M (BIT(14))
#define SPI_MEM_ECC_16TO18_BYTE_EN_V 0x1
#define SPI_MEM_ECC_16TO18_BYTE_EN_S 14
/* SPI_MEM_ECC_SKIP_PAGE_CORNER : R/W ;bitpos:[13] ;default: 1'b1 ; */
/*description: 1: MSPI skips page corner when accesses flash. 0: Not skip page corner when acce
sses flash..*/
#define SPI_MEM_ECC_SKIP_PAGE_CORNER (BIT(13))
#define SPI_MEM_ECC_SKIP_PAGE_CORNER_M (BIT(13))
#define SPI_MEM_ECC_SKIP_PAGE_CORNER_V 0x1
#define SPI_MEM_ECC_SKIP_PAGE_CORNER_S 13
/* SPI_MEM_ECC_CS_HOLD_TIME : R/W ;bitpos:[12:10] ;default: 3'd3 ; */
/*description: SPI_MEM_CS_HOLD_TIME + SPI_MEM_ECC_CS_HOLD_TIME is the SPI_CS hold cycle in ECC
mode when accessed flash..*/
#define SPI_MEM_ECC_CS_HOLD_TIME 0x00000007
#define SPI_MEM_ECC_CS_HOLD_TIME_M ((SPI_MEM_ECC_CS_HOLD_TIME_V)<<(SPI_MEM_ECC_CS_HOLD_TIME_S))
#define SPI_MEM_ECC_CS_HOLD_TIME_V 0x7
#define SPI_MEM_ECC_CS_HOLD_TIME_S 10
/* SPI_MEM_CS_HOLD_TIME : R/W ;bitpos:[9:5] ;default: 5'h1 ; */
/*description: SPI Bus CS (SPI_CS) signal is delayed to inactive by SPI Bus clock (SPI_CLK), wh
ich is the SPI_CS hold time in non-ECC mode. These bits are combined with SPI_ME
M_CS_HOLD bit..*/
#define SPI_MEM_CS_HOLD_TIME 0x0000001F
#define SPI_MEM_CS_HOLD_TIME_M ((SPI_MEM_CS_HOLD_TIME_V)<<(SPI_MEM_CS_HOLD_TIME_S))
#define SPI_MEM_CS_HOLD_TIME_V 0x1F
#define SPI_MEM_CS_HOLD_TIME_S 5
/* SPI_MEM_CS_SETUP_TIME : R/W ;bitpos:[4:0] ;default: 5'h1 ; */
/*description: (cycles-1) of PREP phase by SPI_CLK, which is the SPI_CS setup time. These bits
are combined with SPI_MEM_CS_SETUP bit..*/
#define SPI_MEM_CS_SETUP_TIME 0x0000001F
#define SPI_MEM_CS_SETUP_TIME_M ((SPI_MEM_CS_SETUP_TIME_V)<<(SPI_MEM_CS_SETUP_TIME_S))
#define SPI_MEM_CS_SETUP_TIME_V 0x1F
#define SPI_MEM_CS_SETUP_TIME_S 0
#define SPI_MEM_CLOCK_REG(i) (REG_SPI_MEM_BASE(i) + 0x14)
/* SPI_MEM_CLK_EQU_SYSCLK : R/W ;bitpos:[31] ;default: 1'b0 ; */
/*description: When SPI1 access to flash or Ext_RAM, set this bit in 1-division mode, f_SPI_CLK
= f_MSPI_CORE_CLK..*/
#define SPI_MEM_CLK_EQU_SYSCLK (BIT(31))
#define SPI_MEM_CLK_EQU_SYSCLK_M (BIT(31))
#define SPI_MEM_CLK_EQU_SYSCLK_V 0x1
#define SPI_MEM_CLK_EQU_SYSCLK_S 31
/* SPI_MEM_CLKCNT_N : R/W ;bitpos:[23:16] ;default: 8'h3 ; */
/*description: When SPI1 accesses to flash or Ext_RAM, f_SPI_CLK = f_MSPI_CORE_CLK/(SPI_MEM_CLK
CNT_N+1).*/
#define SPI_MEM_CLKCNT_N 0x000000FF
#define SPI_MEM_CLKCNT_N_M ((SPI_MEM_CLKCNT_N_V)<<(SPI_MEM_CLKCNT_N_S))
#define SPI_MEM_CLKCNT_N_V 0xFF
#define SPI_MEM_CLKCNT_N_S 16
/* SPI_MEM_CLKCNT_H : R/W ;bitpos:[15:8] ;default: 8'h1 ; */
/*description: It must be a floor value of ((SPI_MEM_CLKCNT_N+1)/2-1)..*/
#define SPI_MEM_CLKCNT_H 0x000000FF
#define SPI_MEM_CLKCNT_H_M ((SPI_MEM_CLKCNT_H_V)<<(SPI_MEM_CLKCNT_H_S))
#define SPI_MEM_CLKCNT_H_V 0xFF
#define SPI_MEM_CLKCNT_H_S 8
/* SPI_MEM_CLKCNT_L : R/W ;bitpos:[7:0] ;default: 8'h3 ; */
/*description: It must equal to the value of SPI_MEM_CLKCNT_N. .*/
#define SPI_MEM_CLKCNT_L 0x000000FF
#define SPI_MEM_CLKCNT_L_M ((SPI_MEM_CLKCNT_L_V)<<(SPI_MEM_CLKCNT_L_S))
#define SPI_MEM_CLKCNT_L_V 0xFF
#define SPI_MEM_CLKCNT_L_S 0
#define SPI_MEM_USER_REG(i) (REG_SPI_MEM_BASE(i) + 0x18)
/* SPI_MEM_USR_COMMAND : R/W ;bitpos:[31] ;default: 1'b1 ; */
/*description: Set this bit to enable enable the CMD phase of an operation..*/
#define SPI_MEM_USR_COMMAND (BIT(31))
#define SPI_MEM_USR_COMMAND_M (BIT(31))
#define SPI_MEM_USR_COMMAND_V 0x1
#define SPI_MEM_USR_COMMAND_S 31
/* SPI_MEM_USR_ADDR : R/W ;bitpos:[30] ;default: 1'b0 ; */
/*description: Set this bit to enable enable the ADDR phase of an operation..*/
#define SPI_MEM_USR_ADDR (BIT(30))
#define SPI_MEM_USR_ADDR_M (BIT(30))
#define SPI_MEM_USR_ADDR_V 0x1
#define SPI_MEM_USR_ADDR_S 30
/* SPI_MEM_USR_DUMMY : R/W ;bitpos:[29] ;default: 1'b0 ; */
/*description: Set this bit to enable enable the DUMMY phase of an operation..*/
#define SPI_MEM_USR_DUMMY (BIT(29))
#define SPI_MEM_USR_DUMMY_M (BIT(29))
#define SPI_MEM_USR_DUMMY_V 0x1
#define SPI_MEM_USR_DUMMY_S 29
/* SPI_MEM_USR_MISO : R/W ;bitpos:[28] ;default: 1'b0 ; */
/*description: Set this bit to enable enable the DIN phase of a read-data operation..*/
#define SPI_MEM_USR_MISO (BIT(28))
#define SPI_MEM_USR_MISO_M (BIT(28))
#define SPI_MEM_USR_MISO_V 0x1
#define SPI_MEM_USR_MISO_S 28
/* SPI_MEM_USR_MOSI : R/W ;bitpos:[27] ;default: 1'b0 ; */
/*description: Set this bit to enable the DOUT phase of an write-data operation..*/
#define SPI_MEM_USR_MOSI (BIT(27))
#define SPI_MEM_USR_MOSI_M (BIT(27))
#define SPI_MEM_USR_MOSI_V 0x1
#define SPI_MEM_USR_MOSI_S 27
/* SPI_MEM_USR_DUMMY_IDLE : R/W ;bitpos:[26] ;default: 1'b0 ; */
/*description: SPI_CLK is disabled(No clock edges) in DUMMY phase when the bit is enable..*/
#define SPI_MEM_USR_DUMMY_IDLE (BIT(26))
#define SPI_MEM_USR_DUMMY_IDLE_M (BIT(26))
#define SPI_MEM_USR_DUMMY_IDLE_V 0x1
#define SPI_MEM_USR_DUMMY_IDLE_S 26
/* SPI_MEM_USR_MOSI_HIGHPART : R/W ;bitpos:[25] ;default: 1'b0 ; */
/*description: DOUT phase only access to high-part of the buffer SPI_MEM_W8_REG~SPI_MEM_W15_REG
. 1: enable 0: disable. .*/
#define SPI_MEM_USR_MOSI_HIGHPART (BIT(25))
#define SPI_MEM_USR_MOSI_HIGHPART_M (BIT(25))
#define SPI_MEM_USR_MOSI_HIGHPART_V 0x1
#define SPI_MEM_USR_MOSI_HIGHPART_S 25
/* SPI_MEM_USR_MISO_HIGHPART : R/W ;bitpos:[24] ;default: 1'b0 ; */
/*description: DIN phase only access to high-part of the buffer SPI_MEM_W8_REG~SPI_MEM_W15_REG.
1: enable 0: disable. .*/
#define SPI_MEM_USR_MISO_HIGHPART (BIT(24))
#define SPI_MEM_USR_MISO_HIGHPART_M (BIT(24))
#define SPI_MEM_USR_MISO_HIGHPART_V 0x1
#define SPI_MEM_USR_MISO_HIGHPART_S 24
/* SPI_MEM_FWRITE_QIO : R/W ;bitpos:[15] ;default: 1'b0 ; */
/*description: Set this bit to enable 4-bit-mode(4-bm) in ADDR and DOUT phase in SPI1 write ope
ration..*/
#define SPI_MEM_FWRITE_QIO (BIT(15))
#define SPI_MEM_FWRITE_QIO_M (BIT(15))
#define SPI_MEM_FWRITE_QIO_V 0x1
#define SPI_MEM_FWRITE_QIO_S 15
/* SPI_MEM_FWRITE_DIO : R/W ;bitpos:[14] ;default: 1'b0 ; */
/*description: Set this bit to enable 2-bm in ADDR and DOUT phase in SPI1 write operation..*/
#define SPI_MEM_FWRITE_DIO (BIT(14))
#define SPI_MEM_FWRITE_DIO_M (BIT(14))
#define SPI_MEM_FWRITE_DIO_V 0x1
#define SPI_MEM_FWRITE_DIO_S 14
/* SPI_MEM_FWRITE_QUAD : R/W ;bitpos:[13] ;default: 1'b0 ; */
/*description: Set this bit to enable 4-bm in DOUT phase in SPI1 write operation..*/
#define SPI_MEM_FWRITE_QUAD (BIT(13))
#define SPI_MEM_FWRITE_QUAD_M (BIT(13))
#define SPI_MEM_FWRITE_QUAD_V 0x1
#define SPI_MEM_FWRITE_QUAD_S 13
/* SPI_MEM_FWRITE_DUAL : R/W ;bitpos:[12] ;default: 1'b0 ; */
/*description: Set this bit to enable 2-bm in DOUT phase in SPI1 write operation..*/
#define SPI_MEM_FWRITE_DUAL (BIT(12))
#define SPI_MEM_FWRITE_DUAL_M (BIT(12))
#define SPI_MEM_FWRITE_DUAL_V 0x1
#define SPI_MEM_FWRITE_DUAL_S 12
/* SPI_MEM_CK_OUT_EDGE : R/W ;bitpos:[9] ;default: 1'b0 ; */
/*description: This bit, combined with SPI_MEM_CK_IDLE_EDGE bit, is used to change the clock mo
de 0~3 of SPI_CLK. .*/
#define SPI_MEM_CK_OUT_EDGE (BIT(9))
#define SPI_MEM_CK_OUT_EDGE_M (BIT(9))
#define SPI_MEM_CK_OUT_EDGE_V 0x1
#define SPI_MEM_CK_OUT_EDGE_S 9
/* SPI_MEM_CS_SETUP : R/W ;bitpos:[7] ;default: 1'b0 ; */
/*description: Set this bit to keep SPI_CS low when MSPI is in PREP state..*/
#define SPI_MEM_CS_SETUP (BIT(7))
#define SPI_MEM_CS_SETUP_M (BIT(7))
#define SPI_MEM_CS_SETUP_V 0x1
#define SPI_MEM_CS_SETUP_S 7
/* SPI_MEM_CS_HOLD : R/W ;bitpos:[6] ;default: 1'b0 ; */
/*description: Set this bit to keep SPI_CS low when MSPI is in DONE state..*/
#define SPI_MEM_CS_HOLD (BIT(6))
#define SPI_MEM_CS_HOLD_M (BIT(6))
#define SPI_MEM_CS_HOLD_V 0x1
#define SPI_MEM_CS_HOLD_S 6
#define SPI_MEM_USER1_REG(i) (REG_SPI_MEM_BASE(i) + 0x1C)
/* SPI_MEM_USR_ADDR_BITLEN : R/W ;bitpos:[31:26] ;default: 6'd23 ; */
/*description: The length in bits of ADDR phase. The register value shall be (bit_num-1)..*/
#define SPI_MEM_USR_ADDR_BITLEN 0x0000003F
#define SPI_MEM_USR_ADDR_BITLEN_M ((SPI_MEM_USR_ADDR_BITLEN_V)<<(SPI_MEM_USR_ADDR_BITLEN_S))
#define SPI_MEM_USR_ADDR_BITLEN_V 0x3F
#define SPI_MEM_USR_ADDR_BITLEN_S 26
/* SPI_MEM_USR_DUMMY_CYCLELEN : R/W ;bitpos:[5:0] ;default: 6'd7 ; */
/*description: The SPI_CLK cycle length minus 1 of DUMMY phase..*/
#define SPI_MEM_USR_DUMMY_CYCLELEN 0x0000003F
#define SPI_MEM_USR_DUMMY_CYCLELEN_M ((SPI_MEM_USR_DUMMY_CYCLELEN_V)<<(SPI_MEM_USR_DUMMY_CYCLELEN_S))
#define SPI_MEM_USR_DUMMY_CYCLELEN_V 0x3F
#define SPI_MEM_USR_DUMMY_CYCLELEN_S 0
#define SPI_MEM_USER2_REG(i) (REG_SPI_MEM_BASE(i) + 0x20)
/* SPI_MEM_USR_COMMAND_BITLEN : R/W ;bitpos:[31:28] ;default: 4'd7 ; */
/*description: The length in bits of CMD phase. The register value shall be (bit_num-1).*/
#define SPI_MEM_USR_COMMAND_BITLEN 0x0000000F
#define SPI_MEM_USR_COMMAND_BITLEN_M ((SPI_MEM_USR_COMMAND_BITLEN_V)<<(SPI_MEM_USR_COMMAND_BITLEN_S))
#define SPI_MEM_USR_COMMAND_BITLEN_V 0xF
#define SPI_MEM_USR_COMMAND_BITLEN_S 28
/* SPI_MEM_USR_COMMAND_VALUE : R/W ;bitpos:[15:0] ;default: 16'b0 ; */
/*description: The value of user defined(USR) command..*/
#define SPI_MEM_USR_COMMAND_VALUE 0x0000FFFF
#define SPI_MEM_USR_COMMAND_VALUE_M ((SPI_MEM_USR_COMMAND_VALUE_V)<<(SPI_MEM_USR_COMMAND_VALUE_S))
#define SPI_MEM_USR_COMMAND_VALUE_V 0xFFFF
#define SPI_MEM_USR_COMMAND_VALUE_S 0
#define SPI_MEM_MOSI_DLEN_REG(i) (REG_SPI_MEM_BASE(i) + 0x24)
/* SPI_MEM_USR_MOSI_DBITLEN : R/W ;bitpos:[9:0] ;default: 10'h0 ; */
/*description: The length in bits of DOUT phase. The register value shall be (bit_num-1)..*/
#define SPI_MEM_USR_MOSI_DBITLEN 0x000003FF
#define SPI_MEM_USR_MOSI_DBITLEN_M ((SPI_MEM_USR_MOSI_DBITLEN_V)<<(SPI_MEM_USR_MOSI_DBITLEN_S))
#define SPI_MEM_USR_MOSI_DBITLEN_V 0x3FF
#define SPI_MEM_USR_MOSI_DBITLEN_S 0
#define SPI_MEM_MISO_DLEN_REG(i) (REG_SPI_MEM_BASE(i) + 0x28)
/* SPI_MEM_USR_MISO_DBITLEN : R/W ;bitpos:[9:0] ;default: 10'h0 ; */
/*description: The length in bits of DIN phase. The register value shall be (bit_num-1)..*/
#define SPI_MEM_USR_MISO_DBITLEN 0x000003FF
#define SPI_MEM_USR_MISO_DBITLEN_M ((SPI_MEM_USR_MISO_DBITLEN_V)<<(SPI_MEM_USR_MISO_DBITLEN_S))
#define SPI_MEM_USR_MISO_DBITLEN_V 0x3FF
#define SPI_MEM_USR_MISO_DBITLEN_S 0
#define SPI_MEM_RD_STATUS_REG(i) (REG_SPI_MEM_BASE(i) + 0x2C)
/* SPI_MEM_WB_MODE : R/W ;bitpos:[23:16] ;default: 8'h00 ; */
/*description: Mode bits in the flash fast read mode it is combined with SPI_MEM_FASTRD_MODE b
it..*/
#define SPI_MEM_WB_MODE 0x000000FF
#define SPI_MEM_WB_MODE_M ((SPI_MEM_WB_MODE_V)<<(SPI_MEM_WB_MODE_S))
#define SPI_MEM_WB_MODE_V 0xFF
#define SPI_MEM_WB_MODE_S 16
/* SPI_MEM_STATUS : R/W/SS ;bitpos:[15:0] ;default: 16'b0 ; */
/*description: The value is stored when set SPI_MEM_FLASH_RDSR bit and SPI_MEM_FLASH_RES bit..*/
#define SPI_MEM_STATUS 0x0000FFFF
#define SPI_MEM_STATUS_M ((SPI_MEM_STATUS_V)<<(SPI_MEM_STATUS_S))
#define SPI_MEM_STATUS_V 0xFFFF
#define SPI_MEM_STATUS_S 0
#define SPI_MEM_EXT_ADDR_REG(i) (REG_SPI_MEM_BASE(i) + 0x30)
/* SPI_MEM_EXT_ADDR : R/W ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: The register are the higher 32bits in the 64 bits address mode..*/
#define SPI_MEM_EXT_ADDR 0xFFFFFFFF
#define SPI_MEM_EXT_ADDR_M ((SPI_MEM_EXT_ADDR_V)<<(SPI_MEM_EXT_ADDR_S))
#define SPI_MEM_EXT_ADDR_V 0xFFFFFFFF
#define SPI_MEM_EXT_ADDR_S 0
#define SPI_MEM_MISC_REG(i) (REG_SPI_MEM_BASE(i) + 0x34)
/* SPI_MEM_AUTO_PER : R/W ;bitpos:[11] ;default: 1'b0 ; */
/*description: Set this bit to enable auto PER function. Hardware will sent out PER command if
PES command is sent..*/
#define SPI_MEM_AUTO_PER (BIT(11))
#define SPI_MEM_AUTO_PER_M (BIT(11))
#define SPI_MEM_AUTO_PER_V 0x1
#define SPI_MEM_AUTO_PER_S 11
/* SPI_MEM_CS_KEEP_ACTIVE : R/W ;bitpos:[10] ;default: 1'b0 ; */
/*description: SPI_CS line keep low when the bit is set..*/
#define SPI_MEM_CS_KEEP_ACTIVE (BIT(10))
#define SPI_MEM_CS_KEEP_ACTIVE_M (BIT(10))
#define SPI_MEM_CS_KEEP_ACTIVE_V 0x1
#define SPI_MEM_CS_KEEP_ACTIVE_S 10
/* SPI_MEM_CK_IDLE_EDGE : R/W ;bitpos:[9] ;default: 1'b0 ; */
/*description: 1: SPI_CLK line is high when MSPI is idle. 0: SPI_CLK line is low when MSPI is i
dle..*/
#define SPI_MEM_CK_IDLE_EDGE (BIT(9))
#define SPI_MEM_CK_IDLE_EDGE_M (BIT(9))
#define SPI_MEM_CK_IDLE_EDGE_V 0x1
#define SPI_MEM_CK_IDLE_EDGE_S 9
/* SPI_MEM_SSUB_PIN : R/W ;bitpos:[8] ;default: 1'b0 ; */
/*description: Ext_RAM is connected to SPI SUBPIN bus..*/
#define SPI_MEM_SSUB_PIN (BIT(8))
#define SPI_MEM_SSUB_PIN_M (BIT(8))
#define SPI_MEM_SSUB_PIN_V 0x1
#define SPI_MEM_SSUB_PIN_S 8
/* SPI_MEM_FSUB_PIN : R/W ;bitpos:[7] ;default: 1'b0 ; */
/*description: Flash is connected to SPI SUBPIN bus..*/
#define SPI_MEM_FSUB_PIN (BIT(7))
#define SPI_MEM_FSUB_PIN_M (BIT(7))
#define SPI_MEM_FSUB_PIN_V 0x1
#define SPI_MEM_FSUB_PIN_S 7
/* SPI_MEM_CS1_DIS : R/W ;bitpos:[1] ;default: 1'b1 ; */
/*description: Set this bit to raise high SPI_CS1 pin, which means that the SPI device(Ext_RAM)
connected to SPI_CS1 is in low level when SPI1 transfer starts..*/
#define SPI_MEM_CS1_DIS (BIT(1))
#define SPI_MEM_CS1_DIS_M (BIT(1))
#define SPI_MEM_CS1_DIS_V 0x1
#define SPI_MEM_CS1_DIS_S 1
/* SPI_MEM_CS0_DIS : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to raise high SPI_CS pin, which means that the SPI device(flash) co
nnected to SPI_CS is in low level when SPI1 transfer starts..*/
#define SPI_MEM_CS0_DIS (BIT(0))
#define SPI_MEM_CS0_DIS_M (BIT(0))
#define SPI_MEM_CS0_DIS_V 0x1
#define SPI_MEM_CS0_DIS_S 0
#define SPI_MEM_TX_CRC_REG(i) (REG_SPI_MEM_BASE(i) + 0x38)
/* SPI_MEM_TX_CRC_DATA : RO ;bitpos:[31:0] ;default: 32'hffffffff ; */
/*description: For SPI1, the value of crc32..*/
#define SPI_MEM_TX_CRC_DATA 0xFFFFFFFF
#define SPI_MEM_TX_CRC_DATA_M ((SPI_MEM_TX_CRC_DATA_V)<<(SPI_MEM_TX_CRC_DATA_S))
#define SPI_MEM_TX_CRC_DATA_V 0xFFFFFFFF
#define SPI_MEM_TX_CRC_DATA_S 0
#define SPI_MEM_CACHE_FCTRL_REG(i) (REG_SPI_MEM_BASE(i) + 0x3C)
/* SPI_MEM_FADDR_QUAD : R/W ;bitpos:[8] ;default: 1'b0 ; */
/*description: When SPI1 accesses to flash or Ext_RAM, set this bit to enable 4-bm in ADDR phas
e..*/
#define SPI_MEM_FADDR_QUAD (BIT(8))
#define SPI_MEM_FADDR_QUAD_M (BIT(8))
#define SPI_MEM_FADDR_QUAD_V 0x1
#define SPI_MEM_FADDR_QUAD_S 8
/* SPI_MEM_FDOUT_QUAD : R/W ;bitpos:[7] ;default: 1'b0 ; */
/*description: When SPI1 accesses to flash or Ext_RAM, set this bit to enable 4-bm in DOUT phas
e..*/
#define SPI_MEM_FDOUT_QUAD (BIT(7))
#define SPI_MEM_FDOUT_QUAD_M (BIT(7))
#define SPI_MEM_FDOUT_QUAD_V 0x1
#define SPI_MEM_FDOUT_QUAD_S 7
/* SPI_MEM_FDIN_QUAD : R/W ;bitpos:[6] ;default: 1'b0 ; */
/*description: When SPI1 accesses to flash or Ext_RAM, set this bit to enable 4-bm in DIN phase
..*/
#define SPI_MEM_FDIN_QUAD (BIT(6))
#define SPI_MEM_FDIN_QUAD_M (BIT(6))
#define SPI_MEM_FDIN_QUAD_V 0x1
#define SPI_MEM_FDIN_QUAD_S 6
/* SPI_MEM_FADDR_DUAL : R/W ;bitpos:[5] ;default: 1'b0 ; */
/*description: When SPI1 accesses to flash or Ext_RAM, set this bit to enable 2-bm in ADDR phas
e..*/
#define SPI_MEM_FADDR_DUAL (BIT(5))
#define SPI_MEM_FADDR_DUAL_M (BIT(5))
#define SPI_MEM_FADDR_DUAL_V 0x1
#define SPI_MEM_FADDR_DUAL_S 5
/* SPI_MEM_FDOUT_DUAL : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: When SPI1 accesses to flash or Ext_RAM, set this bit to enable 2-bm in DOUT phas
e..*/
#define SPI_MEM_FDOUT_DUAL (BIT(4))
#define SPI_MEM_FDOUT_DUAL_M (BIT(4))
#define SPI_MEM_FDOUT_DUAL_V 0x1
#define SPI_MEM_FDOUT_DUAL_S 4
/* SPI_MEM_FDIN_DUAL : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: When SPI1 accesses to flash or Ext_RAM, set this bit to enable 2-bm in DIN phase
..*/
#define SPI_MEM_FDIN_DUAL (BIT(3))
#define SPI_MEM_FDIN_DUAL_M (BIT(3))
#define SPI_MEM_FDIN_DUAL_V 0x1
#define SPI_MEM_FDIN_DUAL_S 3
/* SPI_MEM_CACHE_FLASH_USR_CMD : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: 1: The command value of SPI0 reads flash is SPI_MEM_USR_COMMAND_VALUE. 0: Hardwa
re read command value, controlled by SPI_MEM_FREAD_QIO, SPI_MEM_FREAD_DIO, SPI_M
EM_FREAD_QUAD, SPI_MEM_FREAD_DUAL and SPI_MEM_FASTRD_MODE bits..*/
#define SPI_MEM_CACHE_FLASH_USR_CMD (BIT(2))
#define SPI_MEM_CACHE_FLASH_USR_CMD_M (BIT(2))
#define SPI_MEM_CACHE_FLASH_USR_CMD_V 0x1
#define SPI_MEM_CACHE_FLASH_USR_CMD_S 2
/* SPI_MEM_CACHE_USR_CMD_4BYTE : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set this bit to enable SPI1 transfer with 32 bits address. The value of SPI_MEM_
USR_ADDR_BITLEN should be 31..*/
#define SPI_MEM_CACHE_USR_CMD_4BYTE (BIT(1))
#define SPI_MEM_CACHE_USR_CMD_4BYTE_M (BIT(1))
#define SPI_MEM_CACHE_USR_CMD_4BYTE_V 0x1
#define SPI_MEM_CACHE_USR_CMD_4BYTE_S 1
/* SPI_MEM_CACHE_REQ_EN : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to enable Cache's access and SPI0's transfer..*/
#define SPI_MEM_CACHE_REQ_EN (BIT(0))
#define SPI_MEM_CACHE_REQ_EN_M (BIT(0))
#define SPI_MEM_CACHE_REQ_EN_V 0x1
#define SPI_MEM_CACHE_REQ_EN_S 0
#define SPI_MEM_CACHE_SCTRL_REG(i) (REG_SPI_MEM_BASE(i) + 0x40)
/* SPI_MEM_SRAM_WDUMMY_CYCLELEN : R/W ;bitpos:[27:22] ;default: 6'b1 ; */
/*description: When SPI0 accesses to Ext_RAM, it is the SPI_CLK cycles minus 1 of DUMMY phase i
n write data transfer..*/
#define SPI_MEM_SRAM_WDUMMY_CYCLELEN 0x0000003F
#define SPI_MEM_SRAM_WDUMMY_CYCLELEN_M ((SPI_MEM_SRAM_WDUMMY_CYCLELEN_V)<<(SPI_MEM_SRAM_WDUMMY_CYCLELEN_S))
#define SPI_MEM_SRAM_WDUMMY_CYCLELEN_V 0x3F
#define SPI_MEM_SRAM_WDUMMY_CYCLELEN_S 22
/* SPI_MEM_SRAM_OCT : R/W ;bitpos:[21] ;default: 1'b0 ; */
/*description: Set the bit to enable OPI mode in all SPI0 Ext_RAM transfer..*/
#define SPI_MEM_SRAM_OCT (BIT(21))
#define SPI_MEM_SRAM_OCT_M (BIT(21))
#define SPI_MEM_SRAM_OCT_V 0x1
#define SPI_MEM_SRAM_OCT_S 21
/* SPI_MEM_CACHE_SRAM_USR_WCMD : R/W ;bitpos:[20] ;default: 1'b1 ; */
/*description: 1: The command value of SPI0 write Ext_RAM is SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALU
E. 0: The value is 0x3..*/
#define SPI_MEM_CACHE_SRAM_USR_WCMD (BIT(20))
#define SPI_MEM_CACHE_SRAM_USR_WCMD_M (BIT(20))
#define SPI_MEM_CACHE_SRAM_USR_WCMD_V 0x1
#define SPI_MEM_CACHE_SRAM_USR_WCMD_S 20
/* SPI_MEM_SRAM_ADDR_BITLEN : R/W ;bitpos:[19:14] ;default: 6'd23 ; */
/*description: When SPI0 accesses to Ext_RAM, it is the length in bits of ADDR phase. The regis
ter value shall be (bit_num-1)..*/
#define SPI_MEM_SRAM_ADDR_BITLEN 0x0000003F
#define SPI_MEM_SRAM_ADDR_BITLEN_M ((SPI_MEM_SRAM_ADDR_BITLEN_V)<<(SPI_MEM_SRAM_ADDR_BITLEN_S))
#define SPI_MEM_SRAM_ADDR_BITLEN_V 0x3F
#define SPI_MEM_SRAM_ADDR_BITLEN_S 14
/* SPI_MEM_SRAM_RDUMMY_CYCLELEN : R/W ;bitpos:[11:6] ;default: 6'b1 ; */
/*description: When SPI0 accesses to Ext_RAM, it is the SPI_CLK cycles minus 1 of DUMMY phase i
n read data transfer..*/
#define SPI_MEM_SRAM_RDUMMY_CYCLELEN 0x0000003F
#define SPI_MEM_SRAM_RDUMMY_CYCLELEN_M ((SPI_MEM_SRAM_RDUMMY_CYCLELEN_V)<<(SPI_MEM_SRAM_RDUMMY_CYCLELEN_S))
#define SPI_MEM_SRAM_RDUMMY_CYCLELEN_V 0x3F
#define SPI_MEM_SRAM_RDUMMY_CYCLELEN_S 6
/* SPI_MEM_CACHE_SRAM_USR_RCMD : R/W ;bitpos:[5] ;default: 1'b1 ; */
/*description: 1: The command value of SPI0 read Ext_RAM is SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE
. 0: The value is 0x2..*/
#define SPI_MEM_CACHE_SRAM_USR_RCMD (BIT(5))
#define SPI_MEM_CACHE_SRAM_USR_RCMD_M (BIT(5))
#define SPI_MEM_CACHE_SRAM_USR_RCMD_V 0x1
#define SPI_MEM_CACHE_SRAM_USR_RCMD_S 5
/* SPI_MEM_USR_RD_SRAM_DUMMY : R/W ;bitpos:[4] ;default: 1'b1 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable DUMMY phase in read operat
ions..*/
#define SPI_MEM_USR_RD_SRAM_DUMMY (BIT(4))
#define SPI_MEM_USR_RD_SRAM_DUMMY_M (BIT(4))
#define SPI_MEM_USR_RD_SRAM_DUMMY_V 0x1
#define SPI_MEM_USR_RD_SRAM_DUMMY_S 4
/* SPI_MEM_USR_WR_SRAM_DUMMY : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable DUMMY phase in write opera
tions..*/
#define SPI_MEM_USR_WR_SRAM_DUMMY (BIT(3))
#define SPI_MEM_USR_WR_SRAM_DUMMY_M (BIT(3))
#define SPI_MEM_USR_WR_SRAM_DUMMY_V 0x1
#define SPI_MEM_USR_WR_SRAM_DUMMY_S 3
/* SPI_MEM_USR_SRAM_QIO : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: Set the bit to enable QPI mode in all SPI0 Ext_RAM transfer..*/
#define SPI_MEM_USR_SRAM_QIO (BIT(2))
#define SPI_MEM_USR_SRAM_QIO_M (BIT(2))
#define SPI_MEM_USR_SRAM_QIO_V 0x1
#define SPI_MEM_USR_SRAM_QIO_S 2
/* SPI_MEM_USR_SRAM_DIO : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set the bit to enable 2-bm in all the phases of SPI0 Ext_RAM transfer..*/
#define SPI_MEM_USR_SRAM_DIO (BIT(1))
#define SPI_MEM_USR_SRAM_DIO_M (BIT(1))
#define SPI_MEM_USR_SRAM_DIO_V 0x1
#define SPI_MEM_USR_SRAM_DIO_S 1
/* SPI_MEM_CACHE_USR_SCMD_4BYTE : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to enable SPI0 read Ext_RAM with 32 bits address. The value of SPI_
MEM_SRAM_ADDR_BITLEN should be 31..*/
#define SPI_MEM_CACHE_USR_SCMD_4BYTE (BIT(0))
#define SPI_MEM_CACHE_USR_SCMD_4BYTE_M (BIT(0))
#define SPI_MEM_CACHE_USR_SCMD_4BYTE_V 0x1
#define SPI_MEM_CACHE_USR_SCMD_4BYTE_S 0
#define SPI_MEM_SRAM_CMD_REG(i) (REG_SPI_MEM_BASE(i) + 0x44)
/* SPI_MEM_SDUMMY_OUT : R/W ;bitpos:[22] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, in the DUMMY phase the signal level of SPI bus is
output by the SPI0 controller..*/
#define SPI_MEM_SDUMMY_OUT (BIT(22))
#define SPI_MEM_SDUMMY_OUT_M (BIT(22))
#define SPI_MEM_SDUMMY_OUT_V 0x1
#define SPI_MEM_SDUMMY_OUT_S 22
/* SPI_MEM_SCMD_OCT : R/W ;bitpos:[21] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 8-bm in CMD phase..*/
#define SPI_MEM_SCMD_OCT (BIT(21))
#define SPI_MEM_SCMD_OCT_M (BIT(21))
#define SPI_MEM_SCMD_OCT_V 0x1
#define SPI_MEM_SCMD_OCT_S 21
/* SPI_MEM_SADDR_OCT : R/W ;bitpos:[20] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 8-bm in ADDR phase..*/
#define SPI_MEM_SADDR_OCT (BIT(20))
#define SPI_MEM_SADDR_OCT_M (BIT(20))
#define SPI_MEM_SADDR_OCT_V 0x1
#define SPI_MEM_SADDR_OCT_S 20
/* SPI_MEM_SDOUT_OCT : R/W ;bitpos:[19] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 8-bm in DOUT phase..*/
#define SPI_MEM_SDOUT_OCT (BIT(19))
#define SPI_MEM_SDOUT_OCT_M (BIT(19))
#define SPI_MEM_SDOUT_OCT_V 0x1
#define SPI_MEM_SDOUT_OCT_S 19
/* SPI_MEM_SDIN_OCT : R/W ;bitpos:[18] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 8-bm in DIN phase..*/
#define SPI_MEM_SDIN_OCT (BIT(18))
#define SPI_MEM_SDIN_OCT_M (BIT(18))
#define SPI_MEM_SDIN_OCT_V 0x1
#define SPI_MEM_SDIN_OCT_S 18
/* SPI_MEM_SCMD_QUAD : R/W ;bitpos:[17] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 4-bm in CMD phase..*/
#define SPI_MEM_SCMD_QUAD (BIT(17))
#define SPI_MEM_SCMD_QUAD_M (BIT(17))
#define SPI_MEM_SCMD_QUAD_V 0x1
#define SPI_MEM_SCMD_QUAD_S 17
/* SPI_MEM_SADDR_QUAD : R/W ;bitpos:[16] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 4-bm in ADDR phase..*/
#define SPI_MEM_SADDR_QUAD (BIT(16))
#define SPI_MEM_SADDR_QUAD_M (BIT(16))
#define SPI_MEM_SADDR_QUAD_V 0x1
#define SPI_MEM_SADDR_QUAD_S 16
/* SPI_MEM_SDOUT_QUAD : R/W ;bitpos:[15] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 4-bm in DOUT phase..*/
#define SPI_MEM_SDOUT_QUAD (BIT(15))
#define SPI_MEM_SDOUT_QUAD_M (BIT(15))
#define SPI_MEM_SDOUT_QUAD_V 0x1
#define SPI_MEM_SDOUT_QUAD_S 15
/* SPI_MEM_SDIN_QUAD : R/W ;bitpos:[14] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 4-bm in DIN phase..*/
#define SPI_MEM_SDIN_QUAD (BIT(14))
#define SPI_MEM_SDIN_QUAD_M (BIT(14))
#define SPI_MEM_SDIN_QUAD_V 0x1
#define SPI_MEM_SDIN_QUAD_S 14
/* SPI_MEM_SCMD_DUAL : R/W ;bitpos:[13] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 2-bm in CMD phase..*/
#define SPI_MEM_SCMD_DUAL (BIT(13))
#define SPI_MEM_SCMD_DUAL_M (BIT(13))
#define SPI_MEM_SCMD_DUAL_V 0x1
#define SPI_MEM_SCMD_DUAL_S 13
/* SPI_MEM_SADDR_DUAL : R/W ;bitpos:[12] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 2-bm in ADDR phase..*/
#define SPI_MEM_SADDR_DUAL (BIT(12))
#define SPI_MEM_SADDR_DUAL_M (BIT(12))
#define SPI_MEM_SADDR_DUAL_V 0x1
#define SPI_MEM_SADDR_DUAL_S 12
/* SPI_MEM_SDOUT_DUAL : R/W ;bitpos:[11] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 2-bm in DOUT phase..*/
#define SPI_MEM_SDOUT_DUAL (BIT(11))
#define SPI_MEM_SDOUT_DUAL_M (BIT(11))
#define SPI_MEM_SDOUT_DUAL_V 0x1
#define SPI_MEM_SDOUT_DUAL_S 11
/* SPI_MEM_SDIN_DUAL : R/W ;bitpos:[10] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit to enable 2-bm in DIN phase..*/
#define SPI_MEM_SDIN_DUAL (BIT(10))
#define SPI_MEM_SDIN_DUAL_M (BIT(10))
#define SPI_MEM_SDIN_DUAL_V 0x1
#define SPI_MEM_SDIN_DUAL_S 10
/* SPI_MEM_SWB_MODE : R/W ;bitpos:[9:2] ;default: 8'b0 ; */
/*description: Mode bits when SPI0 accesses to Ext_RAM..*/
#define SPI_MEM_SWB_MODE 0x000000FF
#define SPI_MEM_SWB_MODE_M ((SPI_MEM_SWB_MODE_V)<<(SPI_MEM_SWB_MODE_S))
#define SPI_MEM_SWB_MODE_V 0xFF
#define SPI_MEM_SWB_MODE_S 2
/* SPI_MEM_SCLK_MODE : R/W ;bitpos:[1:0] ;default: 2'd0 ; */
/*description: SPI_CLK mode bits when SPI0 accesses to Ext_RAM. 0: SPI_CLK is off when CS inac
tive 1: SPI_CLK is delayed one cycle after CS inactive 2: SPI_CLK is delayed two
cycles after CS inactive 3: SPI_CLK is always on..*/
#define SPI_MEM_SCLK_MODE 0x00000003
#define SPI_MEM_SCLK_MODE_M ((SPI_MEM_SCLK_MODE_V)<<(SPI_MEM_SCLK_MODE_S))
#define SPI_MEM_SCLK_MODE_V 0x3
#define SPI_MEM_SCLK_MODE_S 0
#define SPI_MEM_SRAM_DRD_CMD_REG(i) (REG_SPI_MEM_BASE(i) + 0x48)
/* SPI_MEM_CACHE_SRAM_USR_RD_CMD_BITLEN : R/W ;bitpos:[31:28] ;default: 4'h0 ; */
/*description: When SPI0 reads Ext_RAM, it is the length in bits of CMD phase. The register val
ue shall be (bit_num-1)..*/
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_BITLEN 0x0000000F
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_BITLEN_M ((SPI_MEM_CACHE_SRAM_USR_RD_CMD_BITLEN_V)<<(SPI_MEM_CACHE_SRAM_USR_RD_CMD_BITLEN_S))
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_BITLEN_V 0xF
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_BITLEN_S 28
/* SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALUE : R/W ;bitpos:[15:0] ;default: 16'h0 ; */
/*description: When SPI0 reads Ext_RAM, it is the command value of CMD phase..*/
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALUE 0x0000FFFF
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALUE_M ((SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALUE_V)<<(SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALUE_S))
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALUE_V 0xFFFF
#define SPI_MEM_CACHE_SRAM_USR_RD_CMD_VALUE_S 0
#define SPI_MEM_SRAM_DWR_CMD_REG(i) (REG_SPI_MEM_BASE(i) + 0x4C)
/* SPI_MEM_CACHE_SRAM_USR_WR_CMD_BITLEN : R/W ;bitpos:[31:28] ;default: 4'h0 ; */
/*description: When SPI0 writes Ext_RAM, it is the length in bits of CMD phase. The register va
lue shall be (bit_num-1)..*/
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_BITLEN 0x0000000F
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_BITLEN_M ((SPI_MEM_CACHE_SRAM_USR_WR_CMD_BITLEN_V)<<(SPI_MEM_CACHE_SRAM_USR_WR_CMD_BITLEN_S))
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_BITLEN_V 0xF
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_BITLEN_S 28
/* SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE : R/W ;bitpos:[15:0] ;default: 16'h0 ; */
/*description: When SPI0 writes Ext_RAM, it is the command value of CMD phase..*/
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE 0x0000FFFF
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE_M ((SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE_V)<<(SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE_S))
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE_V 0xFFFF
#define SPI_MEM_CACHE_SRAM_USR_WR_CMD_VALUE_S 0
#define SPI_MEM_SRAM_CLK_REG(i) (REG_SPI_MEM_BASE(i) + 0x50)
/* SPI_MEM_SCLK_EQU_SYSCLK : R/W ;bitpos:[31] ;default: 1'b0 ; */
/*description: When SPI0 accesses to Ext_RAM, set this bit in 1-division mode, f_SPI_CLK = f_MS
PI_CORE_CLK..*/
#define SPI_MEM_SCLK_EQU_SYSCLK (BIT(31))
#define SPI_MEM_SCLK_EQU_SYSCLK_M (BIT(31))
#define SPI_MEM_SCLK_EQU_SYSCLK_V 0x1
#define SPI_MEM_SCLK_EQU_SYSCLK_S 31
/* SPI_MEM_SCLKCNT_N : R/W ;bitpos:[23:16] ;default: 8'h3 ; */
/*description: When SPI0 accesses to Ext_RAM, f_SPI_CLK = f_MSPI_CORE_CLK/(SPI_MEM_SCLKCNT_N+1).*/
#define SPI_MEM_SCLKCNT_N 0x000000FF
#define SPI_MEM_SCLKCNT_N_M ((SPI_MEM_SCLKCNT_N_V)<<(SPI_MEM_SCLKCNT_N_S))
#define SPI_MEM_SCLKCNT_N_V 0xFF
#define SPI_MEM_SCLKCNT_N_S 16
/* SPI_MEM_SCLKCNT_H : R/W ;bitpos:[15:8] ;default: 8'h1 ; */
/*description: It must be a floor value of ((SPI_MEM_SCLKCNT_N+1)/2-1)..*/
#define SPI_MEM_SCLKCNT_H 0x000000FF
#define SPI_MEM_SCLKCNT_H_M ((SPI_MEM_SCLKCNT_H_V)<<(SPI_MEM_SCLKCNT_H_S))
#define SPI_MEM_SCLKCNT_H_V 0xFF
#define SPI_MEM_SCLKCNT_H_S 8
/* SPI_MEM_SCLKCNT_L : R/W ;bitpos:[7:0] ;default: 8'h3 ; */
/*description: It must equal to the value of SPI_MEM_SCLKCNT_N. .*/
#define SPI_MEM_SCLKCNT_L 0x000000FF
#define SPI_MEM_SCLKCNT_L_M ((SPI_MEM_SCLKCNT_L_V)<<(SPI_MEM_SCLKCNT_L_S))
#define SPI_MEM_SCLKCNT_L_V 0xFF
#define SPI_MEM_SCLKCNT_L_S 0
#define SPI_MEM_FSM_REG(i) (REG_SPI_MEM_BASE(i) + 0x54)
/* SPI_MEM_ST : RO ;bitpos:[2:0] ;default: 3'b0 ; */
/*description: The status of SPI1 state machine. 0: idle state(IDLE), 1: preparation state(PREP
), 2: send command state(CMD), 3: send address state(ADDR), 4: red data state(DI
N), 5:write data state(DOUT), 6: wait state(DUMMY), 7: done state(DONE)..*/
#define SPI_MEM_ST 0x00000007
#define SPI_MEM_ST_M ((SPI_MEM_ST_V)<<(SPI_MEM_ST_S))
#define SPI_MEM_ST_V 0x7
#define SPI_MEM_ST_S 0
#define SPI_MEM_W0_REG(i) (REG_SPI_MEM_BASE(i) + 0x58)
/* SPI_MEM_BUF0 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF0 0xFFFFFFFF
#define SPI_MEM_BUF0_M ((SPI_MEM_BUF0_V)<<(SPI_MEM_BUF0_S))
#define SPI_MEM_BUF0_V 0xFFFFFFFF
#define SPI_MEM_BUF0_S 0
#define SPI_MEM_W1_REG(i) (REG_SPI_MEM_BASE(i) + 0x5C)
/* SPI_MEM_BUF1 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF1 0xFFFFFFFF
#define SPI_MEM_BUF1_M ((SPI_MEM_BUF1_V)<<(SPI_MEM_BUF1_S))
#define SPI_MEM_BUF1_V 0xFFFFFFFF
#define SPI_MEM_BUF1_S 0
#define SPI_MEM_W2_REG(i) (REG_SPI_MEM_BASE(i) + 0x60)
/* SPI_MEM_BUF2 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF2 0xFFFFFFFF
#define SPI_MEM_BUF2_M ((SPI_MEM_BUF2_V)<<(SPI_MEM_BUF2_S))
#define SPI_MEM_BUF2_V 0xFFFFFFFF
#define SPI_MEM_BUF2_S 0
#define SPI_MEM_W3_REG(i) (REG_SPI_MEM_BASE(i) + 0x64)
/* SPI_MEM_BUF3 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF3 0xFFFFFFFF
#define SPI_MEM_BUF3_M ((SPI_MEM_BUF3_V)<<(SPI_MEM_BUF3_S))
#define SPI_MEM_BUF3_V 0xFFFFFFFF
#define SPI_MEM_BUF3_S 0
#define SPI_MEM_W4_REG(i) (REG_SPI_MEM_BASE(i) + 0x68)
/* SPI_MEM_BUF4 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF4 0xFFFFFFFF
#define SPI_MEM_BUF4_M ((SPI_MEM_BUF4_V)<<(SPI_MEM_BUF4_S))
#define SPI_MEM_BUF4_V 0xFFFFFFFF
#define SPI_MEM_BUF4_S 0
#define SPI_MEM_W5_REG(i) (REG_SPI_MEM_BASE(i) + 0x6C)
/* SPI_MEM_BUF5 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF5 0xFFFFFFFF
#define SPI_MEM_BUF5_M ((SPI_MEM_BUF5_V)<<(SPI_MEM_BUF5_S))
#define SPI_MEM_BUF5_V 0xFFFFFFFF
#define SPI_MEM_BUF5_S 0
#define SPI_MEM_W6_REG(i) (REG_SPI_MEM_BASE(i) + 0x70)
/* SPI_MEM_BUF6 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF6 0xFFFFFFFF
#define SPI_MEM_BUF6_M ((SPI_MEM_BUF6_V)<<(SPI_MEM_BUF6_S))
#define SPI_MEM_BUF6_V 0xFFFFFFFF
#define SPI_MEM_BUF6_S 0
#define SPI_MEM_W7_REG(i) (REG_SPI_MEM_BASE(i) + 0x74)
/* SPI_MEM_BUF7 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF7 0xFFFFFFFF
#define SPI_MEM_BUF7_M ((SPI_MEM_BUF7_V)<<(SPI_MEM_BUF7_S))
#define SPI_MEM_BUF7_V 0xFFFFFFFF
#define SPI_MEM_BUF7_S 0
#define SPI_MEM_W8_REG(i) (REG_SPI_MEM_BASE(i) + 0x78)
/* SPI_MEM_BUF8 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF8 0xFFFFFFFF
#define SPI_MEM_BUF8_M ((SPI_MEM_BUF8_V)<<(SPI_MEM_BUF8_S))
#define SPI_MEM_BUF8_V 0xFFFFFFFF
#define SPI_MEM_BUF8_S 0
#define SPI_MEM_W9_REG(i) (REG_SPI_MEM_BASE(i) + 0x7C)
/* SPI_MEM_BUF9 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF9 0xFFFFFFFF
#define SPI_MEM_BUF9_M ((SPI_MEM_BUF9_V)<<(SPI_MEM_BUF9_S))
#define SPI_MEM_BUF9_V 0xFFFFFFFF
#define SPI_MEM_BUF9_S 0
#define SPI_MEM_W10_REG(i) (REG_SPI_MEM_BASE(i) + 0x80)
/* SPI_MEM_BUF10 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF10 0xFFFFFFFF
#define SPI_MEM_BUF10_M ((SPI_MEM_BUF10_V)<<(SPI_MEM_BUF10_S))
#define SPI_MEM_BUF10_V 0xFFFFFFFF
#define SPI_MEM_BUF10_S 0
#define SPI_MEM_W11_REG(i) (REG_SPI_MEM_BASE(i) + 0x84)
/* SPI_MEM_BUF11 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF11 0xFFFFFFFF
#define SPI_MEM_BUF11_M ((SPI_MEM_BUF11_V)<<(SPI_MEM_BUF11_S))
#define SPI_MEM_BUF11_V 0xFFFFFFFF
#define SPI_MEM_BUF11_S 0
#define SPI_MEM_W12_REG(i) (REG_SPI_MEM_BASE(i) + 0x88)
/* SPI_MEM_BUF12 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF12 0xFFFFFFFF
#define SPI_MEM_BUF12_M ((SPI_MEM_BUF12_V)<<(SPI_MEM_BUF12_S))
#define SPI_MEM_BUF12_V 0xFFFFFFFF
#define SPI_MEM_BUF12_S 0
#define SPI_MEM_W13_REG(i) (REG_SPI_MEM_BASE(i) + 0x8C)
/* SPI_MEM_BUF13 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF13 0xFFFFFFFF
#define SPI_MEM_BUF13_M ((SPI_MEM_BUF13_V)<<(SPI_MEM_BUF13_S))
#define SPI_MEM_BUF13_V 0xFFFFFFFF
#define SPI_MEM_BUF13_S 0
#define SPI_MEM_W14_REG(i) (REG_SPI_MEM_BASE(i) + 0x90)
/* SPI_MEM_BUF14 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF14 0xFFFFFFFF
#define SPI_MEM_BUF14_M ((SPI_MEM_BUF14_V)<<(SPI_MEM_BUF14_S))
#define SPI_MEM_BUF14_V 0xFFFFFFFF
#define SPI_MEM_BUF14_S 0
#define SPI_MEM_W15_REG(i) (REG_SPI_MEM_BASE(i) + 0x94)
/* SPI_MEM_BUF15 : R/W/SS ;bitpos:[31:0] ;default: 32'b0 ; */
/*description: data buffer.*/
#define SPI_MEM_BUF15 0xFFFFFFFF
#define SPI_MEM_BUF15_M ((SPI_MEM_BUF15_V)<<(SPI_MEM_BUF15_S))
#define SPI_MEM_BUF15_V 0xFFFFFFFF
#define SPI_MEM_BUF15_S 0
#define SPI_MEM_FLASH_WAITI_CTRL_REG(i) (REG_SPI_MEM_BASE(i) + 0x98)
/* SPI_MEM_WAITI_DUMMY_CYCLELEN : R/W ;bitpos:[15:10] ;default: 6'h0 ; */
/*description: The dummy cycle length when wait flash idle(RDSR)..*/
#define SPI_MEM_WAITI_DUMMY_CYCLELEN 0x0000003F
#define SPI_MEM_WAITI_DUMMY_CYCLELEN_M ((SPI_MEM_WAITI_DUMMY_CYCLELEN_V)<<(SPI_MEM_WAITI_DUMMY_CYCLELEN_S))
#define SPI_MEM_WAITI_DUMMY_CYCLELEN_V 0x3F
#define SPI_MEM_WAITI_DUMMY_CYCLELEN_S 10
/* SPI_MEM_WAITI_CMD : R/W ;bitpos:[9:2] ;default: 8'h05 ; */
/*description: The command value of auto wait flash idle transfer(RDSR)..*/
#define SPI_MEM_WAITI_CMD 0x000000FF
#define SPI_MEM_WAITI_CMD_M ((SPI_MEM_WAITI_CMD_V)<<(SPI_MEM_WAITI_CMD_S))
#define SPI_MEM_WAITI_CMD_V 0xFF
#define SPI_MEM_WAITI_CMD_S 2
/* SPI_MEM_WAITI_DUMMY : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set this bit to enable DUMMY phase in auto wait flash idle transfer(RDSR)..*/
#define SPI_MEM_WAITI_DUMMY (BIT(1))
#define SPI_MEM_WAITI_DUMMY_M (BIT(1))
#define SPI_MEM_WAITI_DUMMY_V 0x1
#define SPI_MEM_WAITI_DUMMY_S 1
/* SPI_MEM_WAITI_EN : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to enable auto-waiting flash idle operation when PP/SE/BE/CE/WRSR/P
ES command is sent..*/
#define SPI_MEM_WAITI_EN (BIT(0))
#define SPI_MEM_WAITI_EN_M (BIT(0))
#define SPI_MEM_WAITI_EN_V 0x1
#define SPI_MEM_WAITI_EN_S 0
#define SPI_MEM_FLASH_SUS_CMD_REG(i) (REG_SPI_MEM_BASE(i) + 0x9C)
/* SPI_MEM_PESR_IDLE_EN : R/W ;bitpos:[5] ;default: 1'b0 ; */
/*description: 1: Separate PER flash wait idle and PES flash wait idle. 0: Not separate..*/
#define SPI_MEM_PESR_IDLE_EN (BIT(5))
#define SPI_MEM_PESR_IDLE_EN_M (BIT(5))
#define SPI_MEM_PESR_IDLE_EN_V 0x1
#define SPI_MEM_PESR_IDLE_EN_S 5
/* SPI_MEM_PES_PER_EN : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: Set this bit to enable PES transfer trigger PES transfer option..*/
#define SPI_MEM_PES_PER_EN (BIT(4))
#define SPI_MEM_PES_PER_EN_M (BIT(4))
#define SPI_MEM_PES_PER_EN_V 0x1
#define SPI_MEM_PES_PER_EN_S 4
/* SPI_MEM_FLASH_PES_WAIT_EN : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: Set this bit to add delay time after program erase suspend(PES) command is sent..*/
#define SPI_MEM_FLASH_PES_WAIT_EN (BIT(3))
#define SPI_MEM_FLASH_PES_WAIT_EN_M (BIT(3))
#define SPI_MEM_FLASH_PES_WAIT_EN_V 0x1
#define SPI_MEM_FLASH_PES_WAIT_EN_S 3
/* SPI_MEM_FLASH_PER_WAIT_EN : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: Set this bit to add delay time after program erase resume(PER) is sent..*/
#define SPI_MEM_FLASH_PER_WAIT_EN (BIT(2))
#define SPI_MEM_FLASH_PER_WAIT_EN_M (BIT(2))
#define SPI_MEM_FLASH_PER_WAIT_EN_V 0x1
#define SPI_MEM_FLASH_PER_WAIT_EN_S 2
/* SPI_MEM_FLASH_PES : R/W/SS/SC ;bitpos:[1] ;default: 1'b0 ; */
/*description: program erase suspend bit, program erase suspend operation will be triggered whe
n the bit is set. The bit will be cleared once the operation done.1: enable 0: d
isable. .*/
#define SPI_MEM_FLASH_PES (BIT(1))
#define SPI_MEM_FLASH_PES_M (BIT(1))
#define SPI_MEM_FLASH_PES_V 0x1
#define SPI_MEM_FLASH_PES_S 1
/* SPI_MEM_FLASH_PER : R/W/SS/SC ;bitpos:[0] ;default: 1'b0 ; */
/*description: program erase resume bit, program erase suspend operation will be triggered when
the bit is set. The bit will be cleared once the operation done.1: enable 0: di
sable. .*/
#define SPI_MEM_FLASH_PER (BIT(0))
#define SPI_MEM_FLASH_PER_M (BIT(0))
#define SPI_MEM_FLASH_PER_V 0x1
#define SPI_MEM_FLASH_PER_S 0
#define SPI_MEM_FLASH_SUS_CTRL_REG(i) (REG_SPI_MEM_BASE(i) + 0xA0)
/* SPI_MEM_FLASH_PES_COMMAND : R/W ;bitpos:[16:9] ;default: 8'h75 ; */
/*description: Program/Erase suspend command value..*/
#define SPI_MEM_FLASH_PES_COMMAND 0x000000FF
#define SPI_MEM_FLASH_PES_COMMAND_M ((SPI_MEM_FLASH_PES_COMMAND_V)<<(SPI_MEM_FLASH_PES_COMMAND_S))
#define SPI_MEM_FLASH_PES_COMMAND_V 0xFF
#define SPI_MEM_FLASH_PES_COMMAND_S 9
/* SPI_MEM_FLASH_PER_COMMAND : R/W ;bitpos:[8:1] ;default: 8'h7a ; */
/*description: Program/Erase resume command value..*/
#define SPI_MEM_FLASH_PER_COMMAND 0x000000FF
#define SPI_MEM_FLASH_PER_COMMAND_M ((SPI_MEM_FLASH_PER_COMMAND_V)<<(SPI_MEM_FLASH_PER_COMMAND_S))
#define SPI_MEM_FLASH_PER_COMMAND_V 0xFF
#define SPI_MEM_FLASH_PER_COMMAND_S 1
/* SPI_MEM_FLASH_PES_EN : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to enable auto-suspend function..*/
#define SPI_MEM_FLASH_PES_EN (BIT(0))
#define SPI_MEM_FLASH_PES_EN_M (BIT(0))
#define SPI_MEM_FLASH_PES_EN_V 0x1
#define SPI_MEM_FLASH_PES_EN_S 0
#define SPI_MEM_SUS_STATUS_REG(i) (REG_SPI_MEM_BASE(i) + 0xA4)
/* SPI_MEM_FLASH_PES_DLY_256 : R/W ;bitpos:[6] ;default: 1'b0 ; */
/*description: Valid when SPI_MEM_FLASH_PES_WAIT_EN is 1. 1: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_
RES[9:0] * 256) SPI_CLK cycles after PES command is sent. 0: SPI1 waits (SPI_MEM
_CS_HOLD_DELAY_RES[9:0] * 4) SPI_CLK cycles after PES command is sent..*/
#define SPI_MEM_FLASH_PES_DLY_256 (BIT(6))
#define SPI_MEM_FLASH_PES_DLY_256_M (BIT(6))
#define SPI_MEM_FLASH_PES_DLY_256_V 0x1
#define SPI_MEM_FLASH_PES_DLY_256_S 6
/* SPI_MEM_FLASH_PER_DLY_256 : R/W ;bitpos:[5] ;default: 1'b0 ; */
/*description: Valid when SPI_MEM_FLASH_PER_WAIT_EN is 1. 1: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_
RES[9:0] * 256) SPI_CLK cycles after PER command is sent. 0: SPI1 waits (SPI_MEM
_CS_HOLD_DELAY_RES[9:0] * 4) SPI_CLK cycles after PER command is sent..*/
#define SPI_MEM_FLASH_PER_DLY_256 (BIT(5))
#define SPI_MEM_FLASH_PER_DLY_256_M (BIT(5))
#define SPI_MEM_FLASH_PER_DLY_256_V 0x1
#define SPI_MEM_FLASH_PER_DLY_256_S 5
/* SPI_MEM_FLASH_DP_DLY_256 : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: 1: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_RES[9:0] * 256) SPI_CLK cycles after DP com
mand is sent. 0: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_RES[9:0] * 4) SPI_CLK cycles
after DP command is sent..*/
#define SPI_MEM_FLASH_DP_DLY_256 (BIT(4))
#define SPI_MEM_FLASH_DP_DLY_256_M (BIT(4))
#define SPI_MEM_FLASH_DP_DLY_256_V 0x1
#define SPI_MEM_FLASH_DP_DLY_256_S 4
/* SPI_MEM_FLASH_RES_DLY_256 : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: 1: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_RES[9:0] * 256) SPI_CLK cycles after RES co
mmand is sent. 0: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_RES[9:0] * 4) SPI_CLK cycles
after RES command is sent..*/
#define SPI_MEM_FLASH_RES_DLY_256 (BIT(3))
#define SPI_MEM_FLASH_RES_DLY_256_M (BIT(3))
#define SPI_MEM_FLASH_RES_DLY_256_V 0x1
#define SPI_MEM_FLASH_RES_DLY_256_S 3
/* SPI_MEM_FLASH_HPM_DLY_256 : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: 1: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_RES[9:0] * 256) SPI_CLK cycles after HPM co
mmand is sent. 0: SPI1 waits (SPI_MEM_CS_HOLD_DELAY_RES[9:0] * 4) SPI_CLK cycles
after HPM command is sent..*/
#define SPI_MEM_FLASH_HPM_DLY_256 (BIT(2))
#define SPI_MEM_FLASH_HPM_DLY_256_M (BIT(2))
#define SPI_MEM_FLASH_HPM_DLY_256_V 0x1
#define SPI_MEM_FLASH_HPM_DLY_256_S 2
/* SPI_MEM_FLASH_SUS : R/W/SS/SC ;bitpos:[0] ;default: 1'h0 ; */
/*description: The status of flash suspend. This bit is set when PES command is sent, and clear
ed when PER is sent. Only used in SPI1..*/
#define SPI_MEM_FLASH_SUS (BIT(0))
#define SPI_MEM_FLASH_SUS_M (BIT(0))
#define SPI_MEM_FLASH_SUS_V 0x1
#define SPI_MEM_FLASH_SUS_S 0
#define SPI_MEM_TIMING_CALI_REG(i) (REG_SPI_MEM_BASE(i) + 0xA8)
/* SPI_MEM_EXTRA_DUMMY_CYCLELEN : R/W ;bitpos:[4:2] ;default: 3'd0 ; */
/*description: Extra SPI_CLK cycles added in DUMMY phase for timing compensation. Active when S
PI_MEM_TIMING_CALI bit is set..*/
#define SPI_MEM_EXTRA_DUMMY_CYCLELEN 0x00000007
#define SPI_MEM_EXTRA_DUMMY_CYCLELEN_M ((SPI_MEM_EXTRA_DUMMY_CYCLELEN_V)<<(SPI_MEM_EXTRA_DUMMY_CYCLELEN_S))
#define SPI_MEM_EXTRA_DUMMY_CYCLELEN_V 0x7
#define SPI_MEM_EXTRA_DUMMY_CYCLELEN_S 2
/* SPI_MEM_TIMING_CALI : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set this bit to add extra SPI_CLK cycles in DUMMY phase for all reading operatio
ns..*/
#define SPI_MEM_TIMING_CALI (BIT(1))
#define SPI_MEM_TIMING_CALI_M (BIT(1))
#define SPI_MEM_TIMING_CALI_V 0x1
#define SPI_MEM_TIMING_CALI_S 1
/* SPI_MEM_TIMING_CLK_ENA : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to power on HCLK. When PLL is powered on, the frequency of HCLK equ
als to that of PLL. Otherwise, the frequency equals to that of XTAL..*/
#define SPI_MEM_TIMING_CLK_ENA (BIT(0))
#define SPI_MEM_TIMING_CLK_ENA_M (BIT(0))
#define SPI_MEM_TIMING_CLK_ENA_V 0x1
#define SPI_MEM_TIMING_CLK_ENA_S 0
#define SPI_MEM_DIN_MODE_REG(i) (REG_SPI_MEM_BASE(i) + 0xAC)
/* SPI_MEM_DINS_MODE : R/W ;bitpos:[26:24] ;default: 3'h0 ; */
/*description: SPI_DQS input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DINS_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DINS_NUM+1) cycles at HCLK
positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI_M
EM_DINS_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK negat
ive edge. 4: Delay for (SPI_MEM_DINS_NUM+1) cycles at HCLK negative edge and one
cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DINS_NUM+1) cycles
at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DINS_MODE 0x00000007
#define SPI_MEM_DINS_MODE_M ((SPI_MEM_DINS_MODE_V)<<(SPI_MEM_DINS_MODE_S))
#define SPI_MEM_DINS_MODE_V 0x7
#define SPI_MEM_DINS_MODE_S 24
/* SPI_MEM_DIN7_MODE : R/W ;bitpos:[23:21] ;default: 3'h0 ; */
/*description: SPI_IO7 input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HC
LK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI
_MEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK ne
gative edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and
one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cy
cles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN7_MODE 0x00000007
#define SPI_MEM_DIN7_MODE_M ((SPI_MEM_DIN7_MODE_V)<<(SPI_MEM_DIN7_MODE_S))
#define SPI_MEM_DIN7_MODE_V 0x7
#define SPI_MEM_DIN7_MODE_S 21
/* SPI_MEM_DIN6_MODE : R/W ;bitpos:[20:18] ;default: 3'h0 ; */
/*description: SPI_IO6 input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HC
LK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI
_MEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK ne
gative edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and
one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cy
cles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN6_MODE 0x00000007
#define SPI_MEM_DIN6_MODE_M ((SPI_MEM_DIN6_MODE_V)<<(SPI_MEM_DIN6_MODE_S))
#define SPI_MEM_DIN6_MODE_V 0x7
#define SPI_MEM_DIN6_MODE_S 18
/* SPI_MEM_DIN5_MODE : R/W ;bitpos:[17:15] ;default: 3'h0 ; */
/*description: SPI_IO5 input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HC
LK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI
_MEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK ne
gative edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and
one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cy
cles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN5_MODE 0x00000007
#define SPI_MEM_DIN5_MODE_M ((SPI_MEM_DIN5_MODE_V)<<(SPI_MEM_DIN5_MODE_S))
#define SPI_MEM_DIN5_MODE_V 0x7
#define SPI_MEM_DIN5_MODE_S 15
/* SPI_MEM_DIN4_MODE : R/W ;bitpos:[14:12] ;default: 3'h0 ; */
/*description: SPI_IO4 input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HC
LK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI
_MEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK ne
gative edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and
one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cy
cles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN4_MODE 0x00000007
#define SPI_MEM_DIN4_MODE_M ((SPI_MEM_DIN4_MODE_V)<<(SPI_MEM_DIN4_MODE_S))
#define SPI_MEM_DIN4_MODE_V 0x7
#define SPI_MEM_DIN4_MODE_S 12
/* SPI_MEM_DIN3_MODE : R/W ;bitpos:[11:9] ;default: 3'h0 ; */
/*description: SPI_HD input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCL
K positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI_
MEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK neg
ative edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and
one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cyc
les at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN3_MODE 0x00000007
#define SPI_MEM_DIN3_MODE_M ((SPI_MEM_DIN3_MODE_V)<<(SPI_MEM_DIN3_MODE_S))
#define SPI_MEM_DIN3_MODE_V 0x7
#define SPI_MEM_DIN3_MODE_S 9
/* SPI_MEM_DIN2_MODE : R/W ;bitpos:[8:6] ;default: 3'h0 ; */
/*description: SPI_WP input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCL
K positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI_
MEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK neg
ative edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and
one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cyc
les at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN2_MODE 0x00000007
#define SPI_MEM_DIN2_MODE_M ((SPI_MEM_DIN2_MODE_V)<<(SPI_MEM_DIN2_MODE_S))
#define SPI_MEM_DIN2_MODE_V 0x7
#define SPI_MEM_DIN2_MODE_S 6
/* SPI_MEM_DIN1_MODE : R/W ;bitpos:[5:3] ;default: 3'h0 ; */
/*description: SPI_Q input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles a
t MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK
positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI_M
EM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK nega
tive edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and o
ne cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cycl
es at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN1_MODE 0x00000007
#define SPI_MEM_DIN1_MODE_M ((SPI_MEM_DIN1_MODE_V)<<(SPI_MEM_DIN1_MODE_S))
#define SPI_MEM_DIN1_MODE_V 0x7
#define SPI_MEM_DIN1_MODE_S 3
/* SPI_MEM_DIN0_MODE : R/W ;bitpos:[2:0] ;default: 3'h0 ; */
/*description: SPI_D input delay mode. 0: No delay. 1: Delay for (SPI_MEM_DIN$n_NUM+1) cycles a
t MSPI_CORE_CLK negative edge. 2: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK
positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI_M
EM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK nega
tive edge. 4: Delay for (SPI_MEM_DIN$n_NUM+1) cycles at HCLK negative edge and o
ne cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_MEM_DIN$n_NUM+1) cycl
es at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_DIN0_MODE 0x00000007
#define SPI_MEM_DIN0_MODE_M ((SPI_MEM_DIN0_MODE_V)<<(SPI_MEM_DIN0_MODE_S))
#define SPI_MEM_DIN0_MODE_V 0x7
#define SPI_MEM_DIN0_MODE_S 0
#define SPI_MEM_DIN_NUM_REG(i) (REG_SPI_MEM_BASE(i) + 0xB0)
/* SPI_MEM_DINS_NUM : R/W ;bitpos:[17:16] ;default: 2'h0 ; */
/*description: SPI_DQS input delay number..*/
#define SPI_MEM_DINS_NUM 0x00000003
#define SPI_MEM_DINS_NUM_M ((SPI_MEM_DINS_NUM_V)<<(SPI_MEM_DINS_NUM_S))
#define SPI_MEM_DINS_NUM_V 0x3
#define SPI_MEM_DINS_NUM_S 16
/* SPI_MEM_DIN7_NUM : R/W ;bitpos:[15:14] ;default: 2'h0 ; */
/*description: SPI_IO7 input delay number..*/
#define SPI_MEM_DIN7_NUM 0x00000003
#define SPI_MEM_DIN7_NUM_M ((SPI_MEM_DIN7_NUM_V)<<(SPI_MEM_DIN7_NUM_S))
#define SPI_MEM_DIN7_NUM_V 0x3
#define SPI_MEM_DIN7_NUM_S 14
/* SPI_MEM_DIN6_NUM : R/W ;bitpos:[13:12] ;default: 2'h0 ; */
/*description: SPI_IO6 input delay number..*/
#define SPI_MEM_DIN6_NUM 0x00000003
#define SPI_MEM_DIN6_NUM_M ((SPI_MEM_DIN6_NUM_V)<<(SPI_MEM_DIN6_NUM_S))
#define SPI_MEM_DIN6_NUM_V 0x3
#define SPI_MEM_DIN6_NUM_S 12
/* SPI_MEM_DIN5_NUM : R/W ;bitpos:[11:10] ;default: 2'h0 ; */
/*description: SPI_IO5 input delay number..*/
#define SPI_MEM_DIN5_NUM 0x00000003
#define SPI_MEM_DIN5_NUM_M ((SPI_MEM_DIN5_NUM_V)<<(SPI_MEM_DIN5_NUM_S))
#define SPI_MEM_DIN5_NUM_V 0x3
#define SPI_MEM_DIN5_NUM_S 10
/* SPI_MEM_DIN4_NUM : R/W ;bitpos:[9:8] ;default: 2'h0 ; */
/*description: SPI_IO4 input delay number..*/
#define SPI_MEM_DIN4_NUM 0x00000003
#define SPI_MEM_DIN4_NUM_M ((SPI_MEM_DIN4_NUM_V)<<(SPI_MEM_DIN4_NUM_S))
#define SPI_MEM_DIN4_NUM_V 0x3
#define SPI_MEM_DIN4_NUM_S 8
/* SPI_MEM_DIN3_NUM : R/W ;bitpos:[7:6] ;default: 2'h0 ; */
/*description: SPI_HD input delay number..*/
#define SPI_MEM_DIN3_NUM 0x00000003
#define SPI_MEM_DIN3_NUM_M ((SPI_MEM_DIN3_NUM_V)<<(SPI_MEM_DIN3_NUM_S))
#define SPI_MEM_DIN3_NUM_V 0x3
#define SPI_MEM_DIN3_NUM_S 6
/* SPI_MEM_DIN2_NUM : R/W ;bitpos:[5:4] ;default: 2'h0 ; */
/*description: SPI_WP input delay number..*/
#define SPI_MEM_DIN2_NUM 0x00000003
#define SPI_MEM_DIN2_NUM_M ((SPI_MEM_DIN2_NUM_V)<<(SPI_MEM_DIN2_NUM_S))
#define SPI_MEM_DIN2_NUM_V 0x3
#define SPI_MEM_DIN2_NUM_S 4
/* SPI_MEM_DIN1_NUM : R/W ;bitpos:[3:2] ;default: 2'h0 ; */
/*description: SPI_Q input delay number..*/
#define SPI_MEM_DIN1_NUM 0x00000003
#define SPI_MEM_DIN1_NUM_M ((SPI_MEM_DIN1_NUM_V)<<(SPI_MEM_DIN1_NUM_S))
#define SPI_MEM_DIN1_NUM_V 0x3
#define SPI_MEM_DIN1_NUM_S 2
/* SPI_MEM_DIN0_NUM : R/W ;bitpos:[1:0] ;default: 2'h0 ; */
/*description: SPI_D input delay number..*/
#define SPI_MEM_DIN0_NUM 0x00000003
#define SPI_MEM_DIN0_NUM_M ((SPI_MEM_DIN0_NUM_V)<<(SPI_MEM_DIN0_NUM_S))
#define SPI_MEM_DIN0_NUM_V 0x3
#define SPI_MEM_DIN0_NUM_S 0
#define SPI_MEM_DOUT_MODE_REG(i) (REG_SPI_MEM_BASE(i) + 0xB4)
/* SPI_MEM_DOUTS_MODE : R/W ;bitpos:[8] ;default: 1'h0 ; */
/*description: SPI_DQS output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_DOUTS_MODE (BIT(8))
#define SPI_MEM_DOUTS_MODE_M (BIT(8))
#define SPI_MEM_DOUTS_MODE_V 0x1
#define SPI_MEM_DOUTS_MODE_S 8
/* SPI_MEM_DOUT7_MODE : R/W ;bitpos:[7] ;default: 1'h0 ; */
/*description: SPI_IO7 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_DOUT7_MODE (BIT(7))
#define SPI_MEM_DOUT7_MODE_M (BIT(7))
#define SPI_MEM_DOUT7_MODE_V 0x1
#define SPI_MEM_DOUT7_MODE_S 7
/* SPI_MEM_DOUT6_MODE : R/W ;bitpos:[6] ;default: 1'h0 ; */
/*description: SPI_IO6 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_DOUT6_MODE (BIT(6))
#define SPI_MEM_DOUT6_MODE_M (BIT(6))
#define SPI_MEM_DOUT6_MODE_V 0x1
#define SPI_MEM_DOUT6_MODE_S 6
/* SPI_MEM_DOUT5_MODE : R/W ;bitpos:[5] ;default: 1'h0 ; */
/*description: SPI_IO5 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_DOUT5_MODE (BIT(5))
#define SPI_MEM_DOUT5_MODE_M (BIT(5))
#define SPI_MEM_DOUT5_MODE_V 0x1
#define SPI_MEM_DOUT5_MODE_S 5
/* SPI_MEM_DOUT4_MODE : R/W ;bitpos:[4] ;default: 1'h0 ; */
/*description: SPI_IO4 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_DOUT4_MODE (BIT(4))
#define SPI_MEM_DOUT4_MODE_M (BIT(4))
#define SPI_MEM_DOUT4_MODE_V 0x1
#define SPI_MEM_DOUT4_MODE_S 4
/* SPI_MEM_DOUT3_MODE : R/W ;bitpos:[3] ;default: 1'h0 ; */
/*description: SPI_HD output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negat
ive edge..*/
#define SPI_MEM_DOUT3_MODE (BIT(3))
#define SPI_MEM_DOUT3_MODE_M (BIT(3))
#define SPI_MEM_DOUT3_MODE_V 0x1
#define SPI_MEM_DOUT3_MODE_S 3
/* SPI_MEM_DOUT2_MODE : R/W ;bitpos:[2] ;default: 1'h0 ; */
/*description: SPI_WP output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negat
ive edge..*/
#define SPI_MEM_DOUT2_MODE (BIT(2))
#define SPI_MEM_DOUT2_MODE_M (BIT(2))
#define SPI_MEM_DOUT2_MODE_V 0x1
#define SPI_MEM_DOUT2_MODE_S 2
/* SPI_MEM_DOUT1_MODE : R/W ;bitpos:[1] ;default: 1'h0 ; */
/*description: SPI_Q output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negati
ve edge..*/
#define SPI_MEM_DOUT1_MODE (BIT(1))
#define SPI_MEM_DOUT1_MODE_M (BIT(1))
#define SPI_MEM_DOUT1_MODE_V 0x1
#define SPI_MEM_DOUT1_MODE_S 1
/* SPI_MEM_DOUT0_MODE : R/W ;bitpos:[0] ;default: 1'h0 ; */
/*description: SPI_D output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negati
ve edge..*/
#define SPI_MEM_DOUT0_MODE (BIT(0))
#define SPI_MEM_DOUT0_MODE_M (BIT(0))
#define SPI_MEM_DOUT0_MODE_V 0x1
#define SPI_MEM_DOUT0_MODE_S 0
#define SPI_MEM_SPI_SMEM_TIMING_CALI_REG(i) (REG_SPI_MEM_BASE(i) + 0xBC)
/* SPI_MEM_SPI_SMEM_EXTRA_DUMMY_CYCLELEN : R/W ;bitpos:[4:2] ;default: 3'd0 ; */
/*description: Extra SPI_CLK cycles added in DUMMY phase for timing compensation, when SPI0 acc
esses to Ext_RAM. Active when SPI_SMEM_TIMING_CALI bit is set..*/
#define SPI_MEM_SPI_SMEM_EXTRA_DUMMY_CYCLELEN 0x00000007
#define SPI_MEM_SPI_SMEM_EXTRA_DUMMY_CYCLELEN_M ((SPI_MEM_SPI_SMEM_EXTRA_DUMMY_CYCLELEN_V)<<(SPI_MEM_SPI_SMEM_EXTRA_DUMMY_CYCLELEN_S))
#define SPI_MEM_SPI_SMEM_EXTRA_DUMMY_CYCLELEN_V 0x7
#define SPI_MEM_SPI_SMEM_EXTRA_DUMMY_CYCLELEN_S 2
/* SPI_MEM_SPI_SMEM_TIMING_CALI : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set this bit to add extra SPI_CLK cycles in DUMMY phase for all reading operatio
ns..*/
#define SPI_MEM_SPI_SMEM_TIMING_CALI (BIT(1))
#define SPI_MEM_SPI_SMEM_TIMING_CALI_M (BIT(1))
#define SPI_MEM_SPI_SMEM_TIMING_CALI_V 0x1
#define SPI_MEM_SPI_SMEM_TIMING_CALI_S 1
/* SPI_MEM_SPI_SMEM_TIMING_CLK_ENA : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to power on HCLK. When PLL is powered on, the frequency of HCLK equ
als to that of PLL. Otherwise, the frequency equals to that of XTAL..*/
#define SPI_MEM_SPI_SMEM_TIMING_CLK_ENA (BIT(0))
#define SPI_MEM_SPI_SMEM_TIMING_CLK_ENA_M (BIT(0))
#define SPI_MEM_SPI_SMEM_TIMING_CLK_ENA_V 0x1
#define SPI_MEM_SPI_SMEM_TIMING_CLK_ENA_S 0
#define SPI_MEM_SPI_SMEM_DIN_MODE_REG(i) (REG_SPI_MEM_BASE(i) + 0xC0)
/* SPI_MEM_SPI_SMEM_DINS_MODE : R/W ;bitpos:[26:24] ;default: 3'h0 ; */
/*description: SPI_DQS input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DINS_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DINS_NUM+1) cycles at HC
LK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI
_SMEM_DINS_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK ne
gative edge. 4: Delay for (SPI_SMEM_DINS_NUM+1) cycles at HCLK negative edge and
one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DINS_NUM+1) cy
cles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DINS_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DINS_MODE_M ((SPI_MEM_SPI_SMEM_DINS_MODE_V)<<(SPI_MEM_SPI_SMEM_DINS_MODE_S))
#define SPI_MEM_SPI_SMEM_DINS_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DINS_MODE_S 24
/* SPI_MEM_SPI_SMEM_DIN7_MODE : R/W ;bitpos:[23:21] ;default: 3'h0 ; */
/*description: SPI_IO7 input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycle
s at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at
HCLK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (S
PI_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK
negative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge
and one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+
1) cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN7_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN7_MODE_M ((SPI_MEM_SPI_SMEM_DIN7_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN7_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN7_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN7_MODE_S 21
/* SPI_MEM_SPI_SMEM_DIN6_MODE : R/W ;bitpos:[20:18] ;default: 3'h0 ; */
/*description: SPI_IO6 input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycle
s at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at
HCLK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (S
PI_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK
negative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge
and one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+
1) cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN6_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN6_MODE_M ((SPI_MEM_SPI_SMEM_DIN6_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN6_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN6_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN6_MODE_S 18
/* SPI_MEM_SPI_SMEM_DIN5_MODE : R/W ;bitpos:[17:15] ;default: 3'h0 ; */
/*description: SPI_IO5 input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycle
s at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at
HCLK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (S
PI_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK
negative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge
and one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+
1) cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN5_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN5_MODE_M ((SPI_MEM_SPI_SMEM_DIN5_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN5_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN5_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN5_MODE_S 15
/* SPI_MEM_SPI_SMEM_DIN4_MODE : R/W ;bitpos:[14:12] ;default: 3'h0 ; */
/*description: SPI_IO4 input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycle
s at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at
HCLK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (S
PI_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK
negative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge
and one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+
1) cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN4_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN4_MODE_M ((SPI_MEM_SPI_SMEM_DIN4_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN4_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN4_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN4_MODE_S 12
/* SPI_MEM_SPI_SMEM_DIN3_MODE : R/W ;bitpos:[11:9] ;default: 3'h0 ; */
/*description: SPI_HD input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at H
CLK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SP
I_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK
negative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge
and one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+1
) cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN3_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN3_MODE_M ((SPI_MEM_SPI_SMEM_DIN3_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN3_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN3_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN3_MODE_S 9
/* SPI_MEM_SPI_SMEM_DIN2_MODE : R/W ;bitpos:[8:6] ;default: 3'h0 ; */
/*description: SPI_WP input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at H
CLK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SP
I_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK
negative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge
and one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+1
) cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN2_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN2_MODE_M ((SPI_MEM_SPI_SMEM_DIN2_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN2_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN2_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN2_MODE_S 6
/* SPI_MEM_SPI_SMEM_DIN1_MODE : R/W ;bitpos:[5:3] ;default: 3'h0 ; */
/*description: SPI_Q input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HC
LK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI
_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK n
egative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge a
nd one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+1)
cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN1_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN1_MODE_M ((SPI_MEM_SPI_SMEM_DIN1_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN1_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN1_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN1_MODE_S 3
/* SPI_MEM_SPI_SMEM_DIN0_MODE : R/W ;bitpos:[2:0] ;default: 3'h0 ; */
/*description: SPI_D input delay mode. 0: No delay. 1: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles
at MSPI_CORE_CLK negative edge. 2: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HC
LK positive edge and one cycle at MSPI_CORE_CLK positive edge. 3: Delay for (SPI
_SMEM_DIN$n_NUM+1) cycles at HCLK positive edge and one cycle at MSPI_CORE_CLK n
egative edge. 4: Delay for (SPI_SMEM_DIN$n_NUM+1) cycles at HCLK negative edge a
nd one cycle at MSPI_CORE_CLK positive edge. 5: Delay for (SPI_SMEM_DIN$n_NUM+1)
cycles at HCLK negative edge and one cycle at MSPI_CORE_CLK negative edge..*/
#define SPI_MEM_SPI_SMEM_DIN0_MODE 0x00000007
#define SPI_MEM_SPI_SMEM_DIN0_MODE_M ((SPI_MEM_SPI_SMEM_DIN0_MODE_V)<<(SPI_MEM_SPI_SMEM_DIN0_MODE_S))
#define SPI_MEM_SPI_SMEM_DIN0_MODE_V 0x7
#define SPI_MEM_SPI_SMEM_DIN0_MODE_S 0
#define SPI_MEM_SPI_SMEM_DIN_NUM_REG(i) (REG_SPI_MEM_BASE(i) + 0xC4)
/* SPI_MEM_SPI_SMEM_DINS_NUM : R/W ;bitpos:[17:16] ;default: 2'h0 ; */
/*description: SPI_DQS input delay number..*/
#define SPI_MEM_SPI_SMEM_DINS_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DINS_NUM_M ((SPI_MEM_SPI_SMEM_DINS_NUM_V)<<(SPI_MEM_SPI_SMEM_DINS_NUM_S))
#define SPI_MEM_SPI_SMEM_DINS_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DINS_NUM_S 16
/* SPI_MEM_SPI_SMEM_DIN7_NUM : R/W ;bitpos:[15:14] ;default: 2'h0 ; */
/*description: SPI_IO7 input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN7_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN7_NUM_M ((SPI_MEM_SPI_SMEM_DIN7_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN7_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN7_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN7_NUM_S 14
/* SPI_MEM_SPI_SMEM_DIN6_NUM : R/W ;bitpos:[13:12] ;default: 2'h0 ; */
/*description: SPI_IO6 input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN6_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN6_NUM_M ((SPI_MEM_SPI_SMEM_DIN6_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN6_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN6_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN6_NUM_S 12
/* SPI_MEM_SPI_SMEM_DIN5_NUM : R/W ;bitpos:[11:10] ;default: 2'h0 ; */
/*description: SPI_IO5 input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN5_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN5_NUM_M ((SPI_MEM_SPI_SMEM_DIN5_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN5_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN5_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN5_NUM_S 10
/* SPI_MEM_SPI_SMEM_DIN4_NUM : R/W ;bitpos:[9:8] ;default: 2'h0 ; */
/*description: SPI_IO4 input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN4_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN4_NUM_M ((SPI_MEM_SPI_SMEM_DIN4_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN4_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN4_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN4_NUM_S 8
/* SPI_MEM_SPI_SMEM_DIN3_NUM : R/W ;bitpos:[7:6] ;default: 2'h0 ; */
/*description: SPI_HD input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN3_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN3_NUM_M ((SPI_MEM_SPI_SMEM_DIN3_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN3_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN3_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN3_NUM_S 6
/* SPI_MEM_SPI_SMEM_DIN2_NUM : R/W ;bitpos:[5:4] ;default: 2'h0 ; */
/*description: SPI_WP input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN2_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN2_NUM_M ((SPI_MEM_SPI_SMEM_DIN2_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN2_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN2_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN2_NUM_S 4
/* SPI_MEM_SPI_SMEM_DIN1_NUM : R/W ;bitpos:[3:2] ;default: 2'h0 ; */
/*description: SPI_Q input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN1_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN1_NUM_M ((SPI_MEM_SPI_SMEM_DIN1_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN1_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN1_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN1_NUM_S 2
/* SPI_MEM_SPI_SMEM_DIN0_NUM : R/W ;bitpos:[1:0] ;default: 2'h0 ; */
/*description: SPI_D input delay number..*/
#define SPI_MEM_SPI_SMEM_DIN0_NUM 0x00000003
#define SPI_MEM_SPI_SMEM_DIN0_NUM_M ((SPI_MEM_SPI_SMEM_DIN0_NUM_V)<<(SPI_MEM_SPI_SMEM_DIN0_NUM_S))
#define SPI_MEM_SPI_SMEM_DIN0_NUM_V 0x3
#define SPI_MEM_SPI_SMEM_DIN0_NUM_S 0
#define SPI_MEM_SPI_SMEM_DOUT_MODE_REG(i) (REG_SPI_MEM_BASE(i) + 0xC8)
/* SPI_MEM_SPI_SMEM_DOUTS_MODE : R/W ;bitpos:[8] ;default: 1'h0 ; */
/*description: SPI_DQS output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_SPI_SMEM_DOUTS_MODE (BIT(8))
#define SPI_MEM_SPI_SMEM_DOUTS_MODE_M (BIT(8))
#define SPI_MEM_SPI_SMEM_DOUTS_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUTS_MODE_S 8
/* SPI_MEM_SPI_SMEM_DOUT7_MODE : R/W ;bitpos:[7] ;default: 1'h0 ; */
/*description: SPI_IO7 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_SPI_SMEM_DOUT7_MODE (BIT(7))
#define SPI_MEM_SPI_SMEM_DOUT7_MODE_M (BIT(7))
#define SPI_MEM_SPI_SMEM_DOUT7_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT7_MODE_S 7
/* SPI_MEM_SPI_SMEM_DOUT6_MODE : R/W ;bitpos:[6] ;default: 1'h0 ; */
/*description: SPI_IO6 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_SPI_SMEM_DOUT6_MODE (BIT(6))
#define SPI_MEM_SPI_SMEM_DOUT6_MODE_M (BIT(6))
#define SPI_MEM_SPI_SMEM_DOUT6_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT6_MODE_S 6
/* SPI_MEM_SPI_SMEM_DOUT5_MODE : R/W ;bitpos:[5] ;default: 1'h0 ; */
/*description: SPI_IO5 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_SPI_SMEM_DOUT5_MODE (BIT(5))
#define SPI_MEM_SPI_SMEM_DOUT5_MODE_M (BIT(5))
#define SPI_MEM_SPI_SMEM_DOUT5_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT5_MODE_S 5
/* SPI_MEM_SPI_SMEM_DOUT4_MODE : R/W ;bitpos:[4] ;default: 1'h0 ; */
/*description: SPI_IO4 output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK nega
tive edge..*/
#define SPI_MEM_SPI_SMEM_DOUT4_MODE (BIT(4))
#define SPI_MEM_SPI_SMEM_DOUT4_MODE_M (BIT(4))
#define SPI_MEM_SPI_SMEM_DOUT4_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT4_MODE_S 4
/* SPI_MEM_SPI_SMEM_DOUT3_MODE : R/W ;bitpos:[3] ;default: 1'h0 ; */
/*description: SPI_HD output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negat
ive edge..*/
#define SPI_MEM_SPI_SMEM_DOUT3_MODE (BIT(3))
#define SPI_MEM_SPI_SMEM_DOUT3_MODE_M (BIT(3))
#define SPI_MEM_SPI_SMEM_DOUT3_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT3_MODE_S 3
/* SPI_MEM_SPI_SMEM_DOUT2_MODE : R/W ;bitpos:[2] ;default: 1'h0 ; */
/*description: SPI_WP output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negat
ive edge..*/
#define SPI_MEM_SPI_SMEM_DOUT2_MODE (BIT(2))
#define SPI_MEM_SPI_SMEM_DOUT2_MODE_M (BIT(2))
#define SPI_MEM_SPI_SMEM_DOUT2_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT2_MODE_S 2
/* SPI_MEM_SPI_SMEM_DOUT1_MODE : R/W ;bitpos:[1] ;default: 1'h0 ; */
/*description: SPI_Q output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negati
ve edge..*/
#define SPI_MEM_SPI_SMEM_DOUT1_MODE (BIT(1))
#define SPI_MEM_SPI_SMEM_DOUT1_MODE_M (BIT(1))
#define SPI_MEM_SPI_SMEM_DOUT1_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT1_MODE_S 1
/* SPI_MEM_SPI_SMEM_DOUT0_MODE : R/W ;bitpos:[0] ;default: 1'h0 ; */
/*description: SPI_D output delay mode. 0: No delay. 1: Delay one cycle at MSPI_CORE_CLK negati
ve edge..*/
#define SPI_MEM_SPI_SMEM_DOUT0_MODE (BIT(0))
#define SPI_MEM_SPI_SMEM_DOUT0_MODE_M (BIT(0))
#define SPI_MEM_SPI_SMEM_DOUT0_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DOUT0_MODE_S 0
#define SPI_MEM_ECC_CTRL_REG(i) (REG_SPI_MEM_BASE(i) + 0xCC)
/* SPI_MEM_SPI_FMEM_ECC_ERR_INT_EN : R/W ;bitpos:[8] ;default: 1'b0 ; */
/*description: Set this bit to calculate the error times of MSPI ECC read when accesses to flas
h..*/
#define SPI_MEM_SPI_FMEM_ECC_ERR_INT_EN (BIT(8))
#define SPI_MEM_SPI_FMEM_ECC_ERR_INT_EN_M (BIT(8))
#define SPI_MEM_SPI_FMEM_ECC_ERR_INT_EN_V 0x1
#define SPI_MEM_SPI_FMEM_ECC_ERR_INT_EN_S 8
/* SPI_MEM_ECC_ERR_INT_NUM : R/W ;bitpos:[7:0] ;default: 8'd10 ; */
/*description: Set the error times of MSPI ECC read to generate MSPI SPI_MEM_ECC_ERR_INT interr
upt..*/
#define SPI_MEM_ECC_ERR_INT_NUM 0x000000FF
#define SPI_MEM_ECC_ERR_INT_NUM_M ((SPI_MEM_ECC_ERR_INT_NUM_V)<<(SPI_MEM_ECC_ERR_INT_NUM_S))
#define SPI_MEM_ECC_ERR_INT_NUM_V 0xFF
#define SPI_MEM_ECC_ERR_INT_NUM_S 0
#define SPI_MEM_ECC_ERR_ADDR_REG(i) (REG_SPI_MEM_BASE(i) + 0xD0)
/* SPI_MEM_ECC_ERR_ADDR : R/SS/WTC ;bitpos:[31:0] ;default: 32'h0 ; */
/*description: These bits show the first MSPI ECC error address when SPI_FMEM_ECC_ERR_INT_EN/SP
I_SMEM_ECC_ERR_INT_EN is set and accessed to flash/Ext_RAM, including ECC byte e
rror and data error. It is cleared by when SPI_MEM_ECC_ERR_INT_CLR bit is set. .*/
#define SPI_MEM_ECC_ERR_ADDR 0xFFFFFFFF
#define SPI_MEM_ECC_ERR_ADDR_M ((SPI_MEM_ECC_ERR_ADDR_V)<<(SPI_MEM_ECC_ERR_ADDR_S))
#define SPI_MEM_ECC_ERR_ADDR_V 0xFFFFFFFF
#define SPI_MEM_ECC_ERR_ADDR_S 0
#define SPI_MEM_ECC_ERR_BIT_REG(i) (REG_SPI_MEM_BASE(i) + 0xD4)
/* SPI_MEM_ECC_ERR_CNT : RO ;bitpos:[24:17] ;default: 8'd0 ; */
/*description: This bits show the error times of MSPI ECC read, including ECC byte error and da
ta byte error. It is cleared by when SPI_MEM_ECC_ERR_INT_CLR bit is set. .*/
#define SPI_MEM_ECC_ERR_CNT 0x000000FF
#define SPI_MEM_ECC_ERR_CNT_M ((SPI_MEM_ECC_ERR_CNT_V)<<(SPI_MEM_ECC_ERR_CNT_S))
#define SPI_MEM_ECC_ERR_CNT_V 0xFF
#define SPI_MEM_ECC_ERR_CNT_S 17
/* SPI_MEM_ECC_BYTE_ERR : R/SS/WTC ;bitpos:[16] ;default: 1'd0 ; */
/*description: It records the first ECC byte error when SPI_FMEM_ECC_ERR_INT_EN/SPI_SMEM_ECC_ER
R_INT_EN is set and accessed to flash/Ext_RAM. It is cleared by SPI_MEM_ECC_ERR_
INT_CLR bit..*/
#define SPI_MEM_ECC_BYTE_ERR (BIT(16))
#define SPI_MEM_ECC_BYTE_ERR_M (BIT(16))
#define SPI_MEM_ECC_BYTE_ERR_V 0x1
#define SPI_MEM_ECC_BYTE_ERR_S 16
/* SPI_MEM_ECC_CHK_ERR_BIT : R/SS/WTC ;bitpos:[15:13] ;default: 3'd0 ; */
/*description: When SPI_MEM_ECC_BYTE_ERR is set, these bits show the error bit number of ECC by
te..*/
#define SPI_MEM_ECC_CHK_ERR_BIT 0x00000007
#define SPI_MEM_ECC_CHK_ERR_BIT_M ((SPI_MEM_ECC_CHK_ERR_BIT_V)<<(SPI_MEM_ECC_CHK_ERR_BIT_S))
#define SPI_MEM_ECC_CHK_ERR_BIT_V 0x7
#define SPI_MEM_ECC_CHK_ERR_BIT_S 13
/* SPI_MEM_ECC_DATA_ERR_BIT : R/SS/WTC ;bitpos:[12:6] ;default: 7'd0 ; */
/*description: It records the first ECC data error bit number when SPI_FMEM_ECC_ERR_INT_EN/SPI_
SMEM_ECC_ERR_INT_EN is set and accessed to flash/Ext_RAM. The value ranges from
0~127, corresponding to the bit number in 16 data bytes. It is cleared by SPI_ME
M_ECC_ERR_INT_CLR bit..*/
#define SPI_MEM_ECC_DATA_ERR_BIT 0x0000007F
#define SPI_MEM_ECC_DATA_ERR_BIT_M ((SPI_MEM_ECC_DATA_ERR_BIT_V)<<(SPI_MEM_ECC_DATA_ERR_BIT_S))
#define SPI_MEM_ECC_DATA_ERR_BIT_V 0x7F
#define SPI_MEM_ECC_DATA_ERR_BIT_S 6
#define SPI_MEM_SPI_SMEM_AC_REG(i) (REG_SPI_MEM_BASE(i) + 0xDC)
/* SPI_MEM_SPI_SMEM_CS_HOLD_DELAY : R/W ;bitpos:[30:25] ;default: 6'd0 ; */
/*description: These bits are used to set the minimum CS high time tSHSL between SPI burst tran
sfer when accesses to external RAM. tSHSL is (SPI_SMEM_CS_HOLD_DELAY[5:0] + 1) M
SPI core clock cycles..*/
#define SPI_MEM_SPI_SMEM_CS_HOLD_DELAY 0x0000003F
#define SPI_MEM_SPI_SMEM_CS_HOLD_DELAY_M ((SPI_MEM_SPI_SMEM_CS_HOLD_DELAY_V)<<(SPI_MEM_SPI_SMEM_CS_HOLD_DELAY_S))
#define SPI_MEM_SPI_SMEM_CS_HOLD_DELAY_V 0x3F
#define SPI_MEM_SPI_SMEM_CS_HOLD_DELAY_S 25
/* SPI_MEM_SPI_SMEM_ECC_ERR_INT_EN : R/W ;bitpos:[24] ;default: 1'b0 ; */
/*description: Set this bit to calculate the error times of MSPI ECC read when accesses to exte
rnal RAM..*/
#define SPI_MEM_SPI_SMEM_ECC_ERR_INT_EN (BIT(24))
#define SPI_MEM_SPI_SMEM_ECC_ERR_INT_EN_M (BIT(24))
#define SPI_MEM_SPI_SMEM_ECC_ERR_INT_EN_V 0x1
#define SPI_MEM_SPI_SMEM_ECC_ERR_INT_EN_S 24
/* SPI_MEM_SPI_SMEM_ECC_16TO18_BYTE_EN : R/W ;bitpos:[16] ;default: 1'b0 ; */
/*description: Set this bit to enable MSPI ECC 16 bytes data with 2 ECC bytes mode when accesse
s to external RAM..*/
#define SPI_MEM_SPI_SMEM_ECC_16TO18_BYTE_EN (BIT(16))
#define SPI_MEM_SPI_SMEM_ECC_16TO18_BYTE_EN_M (BIT(16))
#define SPI_MEM_SPI_SMEM_ECC_16TO18_BYTE_EN_V 0x1
#define SPI_MEM_SPI_SMEM_ECC_16TO18_BYTE_EN_S 16
/* SPI_MEM_SPI_SMEM_ECC_SKIP_PAGE_CORNER : R/W ;bitpos:[15] ;default: 1'b1 ; */
/*description: 1: MSPI skips page corner when accesses to external RAM. 0: Not skip page corner
when accesses to external RAM..*/
#define SPI_MEM_SPI_SMEM_ECC_SKIP_PAGE_CORNER (BIT(15))
#define SPI_MEM_SPI_SMEM_ECC_SKIP_PAGE_CORNER_M (BIT(15))
#define SPI_MEM_SPI_SMEM_ECC_SKIP_PAGE_CORNER_V 0x1
#define SPI_MEM_SPI_SMEM_ECC_SKIP_PAGE_CORNER_S 15
/* SPI_MEM_SPI_SMEM_ECC_CS_HOLD_TIME : R/W ;bitpos:[14:12] ;default: 3'd3 ; */
/*description: SPI_SMEM_CS_HOLD_TIME + SPI_SMEM_ECC_CS_HOLD_TIME is the MSPI CS hold cycles in
ECC mode when accesses to external RAM..*/
#define SPI_MEM_SPI_SMEM_ECC_CS_HOLD_TIME 0x00000007
#define SPI_MEM_SPI_SMEM_ECC_CS_HOLD_TIME_M ((SPI_MEM_SPI_SMEM_ECC_CS_HOLD_TIME_V)<<(SPI_MEM_SPI_SMEM_ECC_CS_HOLD_TIME_S))
#define SPI_MEM_SPI_SMEM_ECC_CS_HOLD_TIME_V 0x7
#define SPI_MEM_SPI_SMEM_ECC_CS_HOLD_TIME_S 12
/* SPI_MEM_SPI_SMEM_CS_HOLD_TIME : R/W ;bitpos:[11:7] ;default: 5'h1 ; */
/*description: SPI Bus CS (SPI_CS) signal is delayed to inactive by SPI Bus clock (SPI_CLK), wh
ich is the SPI_CS hold time in non-ECC mode. These bits are combined with SPI_ME
M_CS_HOLD bit..*/
#define SPI_MEM_SPI_SMEM_CS_HOLD_TIME 0x0000001F
#define SPI_MEM_SPI_SMEM_CS_HOLD_TIME_M ((SPI_MEM_SPI_SMEM_CS_HOLD_TIME_V)<<(SPI_MEM_SPI_SMEM_CS_HOLD_TIME_S))
#define SPI_MEM_SPI_SMEM_CS_HOLD_TIME_V 0x1F
#define SPI_MEM_SPI_SMEM_CS_HOLD_TIME_S 7
/* SPI_MEM_SPI_SMEM_CS_SETUP_TIME : R/W ;bitpos:[6:2] ;default: 5'h1 ; */
/*description: (cycles-1) of PREP phase by SPI_CLK, which is the SPI_CS setup time. These bits
are combined with SPI_MEM_CS_SETUP bit..*/
#define SPI_MEM_SPI_SMEM_CS_SETUP_TIME 0x0000001F
#define SPI_MEM_SPI_SMEM_CS_SETUP_TIME_M ((SPI_MEM_SPI_SMEM_CS_SETUP_TIME_V)<<(SPI_MEM_SPI_SMEM_CS_SETUP_TIME_S))
#define SPI_MEM_SPI_SMEM_CS_SETUP_TIME_V 0x1F
#define SPI_MEM_SPI_SMEM_CS_SETUP_TIME_S 2
/* SPI_MEM_SPI_SMEM_CS_HOLD : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set this bit to keep SPI_CS low when MSPI is in DONE state..*/
#define SPI_MEM_SPI_SMEM_CS_HOLD (BIT(1))
#define SPI_MEM_SPI_SMEM_CS_HOLD_M (BIT(1))
#define SPI_MEM_SPI_SMEM_CS_HOLD_V 0x1
#define SPI_MEM_SPI_SMEM_CS_HOLD_S 1
/* SPI_MEM_SPI_SMEM_CS_SETUP : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: Set this bit to keep SPI_CS low when MSPI is in PREP state..*/
#define SPI_MEM_SPI_SMEM_CS_SETUP (BIT(0))
#define SPI_MEM_SPI_SMEM_CS_SETUP_M (BIT(0))
#define SPI_MEM_SPI_SMEM_CS_SETUP_V 0x1
#define SPI_MEM_SPI_SMEM_CS_SETUP_S 0
#define SPI_MEM_DDR_REG(i) (REG_SPI_MEM_BASE(i) + 0xE0)
/* SPI_MEM_SPI_FMEM_HYPERBUS_CA : R/W ;bitpos:[30] ;default: 1'b0 ; */
/*description: Set this bit to enable HyperRAM address out when accesses to flash, which means
ADDR_OUT[31:0] = {spi_usr_addr_value[19:4], 13'd0, spi_usr_addr_value[3:1]}..*/
#define SPI_MEM_SPI_FMEM_HYPERBUS_CA (BIT(30))
#define SPI_MEM_SPI_FMEM_HYPERBUS_CA_M (BIT(30))
#define SPI_MEM_SPI_FMEM_HYPERBUS_CA_V 0x1
#define SPI_MEM_SPI_FMEM_HYPERBUS_CA_S 30
/* SPI_MEM_SPI_FMEM_OCTA_RAM_ADDR : R/W ;bitpos:[29] ;default: 1'b0 ; */
/*description: Set this bit to enable octa_ram address out when accesses to flash, which means
ADDR_OUT[31:0] = {spi_usr_addr_value[25:4], 6'd0, spi_usr_addr_value[3:1], 1'b0}
..*/
#define SPI_MEM_SPI_FMEM_OCTA_RAM_ADDR (BIT(29))
#define SPI_MEM_SPI_FMEM_OCTA_RAM_ADDR_M (BIT(29))
#define SPI_MEM_SPI_FMEM_OCTA_RAM_ADDR_V 0x1
#define SPI_MEM_SPI_FMEM_OCTA_RAM_ADDR_S 29
/* SPI_MEM_SPI_FMEM_CLK_DIFF_INV : R/W ;bitpos:[28] ;default: 1'b0 ; */
/*description: Set this bit to invert SPI_DIFF when accesses to flash. ..*/
#define SPI_MEM_SPI_FMEM_CLK_DIFF_INV (BIT(28))
#define SPI_MEM_SPI_FMEM_CLK_DIFF_INV_M (BIT(28))
#define SPI_MEM_SPI_FMEM_CLK_DIFF_INV_V 0x1
#define SPI_MEM_SPI_FMEM_CLK_DIFF_INV_S 28
/* SPI_MEM_SPI_FMEM_HYPERBUS_DUMMY_2X : R/W ;bitpos:[27] ;default: 1'b0 ; */
/*description: Set this bit to enable the vary dummy function in SPI HyperBus mode, when SPI0 a
ccesses flash or SPI1 accesses flash or sram..*/
#define SPI_MEM_SPI_FMEM_HYPERBUS_DUMMY_2X (BIT(27))
#define SPI_MEM_SPI_FMEM_HYPERBUS_DUMMY_2X_M (BIT(27))
#define SPI_MEM_SPI_FMEM_HYPERBUS_DUMMY_2X_V 0x1
#define SPI_MEM_SPI_FMEM_HYPERBUS_DUMMY_2X_S 27
/* SPI_MEM_SPI_FMEM_DQS_CA_IN : R/W ;bitpos:[26] ;default: 1'b0 ; */
/*description: Set this bit to enable the input of SPI_DQS signal in SPI phases of CMD and ADDR
..*/
#define SPI_MEM_SPI_FMEM_DQS_CA_IN (BIT(26))
#define SPI_MEM_SPI_FMEM_DQS_CA_IN_M (BIT(26))
#define SPI_MEM_SPI_FMEM_DQS_CA_IN_V 0x1
#define SPI_MEM_SPI_FMEM_DQS_CA_IN_S 26
/* SPI_MEM_SPI_FMEM_HYPERBUS_MODE : R/W ;bitpos:[25] ;default: 1'b0 ; */
/*description: Set this bit to enable the SPI HyperBus mode..*/
#define SPI_MEM_SPI_FMEM_HYPERBUS_MODE (BIT(25))
#define SPI_MEM_SPI_FMEM_HYPERBUS_MODE_M (BIT(25))
#define SPI_MEM_SPI_FMEM_HYPERBUS_MODE_V 0x1
#define SPI_MEM_SPI_FMEM_HYPERBUS_MODE_S 25
/* SPI_MEM_SPI_FMEM_CLK_DIFF_EN : R/W ;bitpos:[24] ;default: 1'b0 ; */
/*description: Set this bit to enable the differential SPI_CLK#..*/
#define SPI_MEM_SPI_FMEM_CLK_DIFF_EN (BIT(24))
#define SPI_MEM_SPI_FMEM_CLK_DIFF_EN_M (BIT(24))
#define SPI_MEM_SPI_FMEM_CLK_DIFF_EN_V 0x1
#define SPI_MEM_SPI_FMEM_CLK_DIFF_EN_S 24
/* SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_MODE : R/W ;bitpos:[22] ;default: 1'b0 ; */
/*description: When SPI_FMEM_DDR_DQS_LOOP and SPI_FMEM_DDR_EN are set, 1: Use internal SPI_CLK
as data strobe. 0: Use internal ~SPI_CLK as data strobe. Otherwise this bit is
not active..*/
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_MODE (BIT(22))
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_MODE_M (BIT(22))
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_MODE_V 0x1
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_MODE_S 22
/* SPI_MEM_SPI_FMEM_DDR_DQS_LOOP : R/W ;bitpos:[21] ;default: 1'b0 ; */
/*description: 1: Use internal signal as data strobe, the strobe can not be delayed by input t
iming module. 0: Use input SPI_DQS signal from PAD as data strobe, the strobe ca
n be delayed by input timing module.*/
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP (BIT(21))
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_M (BIT(21))
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_V 0x1
#define SPI_MEM_SPI_FMEM_DDR_DQS_LOOP_S 21
/* SPI_MEM_SPI_FMEM_USR_DDR_DQS_THD : R/W ;bitpos:[20:14] ;default: 7'b0 ; */
/*description: The delay number of data strobe which from memory based on SPI_CLK..*/
#define SPI_MEM_SPI_FMEM_USR_DDR_DQS_THD 0x0000007F
#define SPI_MEM_SPI_FMEM_USR_DDR_DQS_THD_M ((SPI_MEM_SPI_FMEM_USR_DDR_DQS_THD_V)<<(SPI_MEM_SPI_FMEM_USR_DDR_DQS_THD_S))
#define SPI_MEM_SPI_FMEM_USR_DDR_DQS_THD_V 0x7F
#define SPI_MEM_SPI_FMEM_USR_DDR_DQS_THD_S 14
/* SPI_MEM_SPI_FMEM_RX_DDR_MSK_EN : R/W ;bitpos:[13] ;default: 1'h1 ; */
/*description: Set this bit to mask the first or the last byte in MSPI ECC DDR read mode, when
accesses to flash..*/
#define SPI_MEM_SPI_FMEM_RX_DDR_MSK_EN (BIT(13))
#define SPI_MEM_SPI_FMEM_RX_DDR_MSK_EN_M (BIT(13))
#define SPI_MEM_SPI_FMEM_RX_DDR_MSK_EN_V 0x1
#define SPI_MEM_SPI_FMEM_RX_DDR_MSK_EN_S 13
/* SPI_MEM_SPI_FMEM_TX_DDR_MSK_EN : R/W ;bitpos:[12] ;default: 1'h1 ; */
/*description: Set this bit to mask the first or the last byte in MSPI ECC DDR write mode, when
accesses to flash..*/
#define SPI_MEM_SPI_FMEM_TX_DDR_MSK_EN (BIT(12))
#define SPI_MEM_SPI_FMEM_TX_DDR_MSK_EN_M (BIT(12))
#define SPI_MEM_SPI_FMEM_TX_DDR_MSK_EN_V 0x1
#define SPI_MEM_SPI_FMEM_TX_DDR_MSK_EN_S 12
/* SPI_MEM_SPI_FMEM_OUTMINBYTELEN : R/W ;bitpos:[11:5] ;default: 7'b1 ; */
/*description: It is the minimum output data length in the panda device..*/
#define SPI_MEM_SPI_FMEM_OUTMINBYTELEN 0x0000007F
#define SPI_MEM_SPI_FMEM_OUTMINBYTELEN_M ((SPI_MEM_SPI_FMEM_OUTMINBYTELEN_V)<<(SPI_MEM_SPI_FMEM_OUTMINBYTELEN_S))
#define SPI_MEM_SPI_FMEM_OUTMINBYTELEN_V 0x7F
#define SPI_MEM_SPI_FMEM_OUTMINBYTELEN_S 5
/* SPI_MEM_SPI_FMEM_DDR_CMD_DIS : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: the bit is used to disable dual edge in command phase when DDR mode..*/
#define SPI_MEM_SPI_FMEM_DDR_CMD_DIS (BIT(4))
#define SPI_MEM_SPI_FMEM_DDR_CMD_DIS_M (BIT(4))
#define SPI_MEM_SPI_FMEM_DDR_CMD_DIS_V 0x1
#define SPI_MEM_SPI_FMEM_DDR_CMD_DIS_S 4
/* SPI_MEM_SPI_FMEM_DDR_WDAT_SWP : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: Set the bit to reorder TX data of the word in DDR mode..*/
#define SPI_MEM_SPI_FMEM_DDR_WDAT_SWP (BIT(3))
#define SPI_MEM_SPI_FMEM_DDR_WDAT_SWP_M (BIT(3))
#define SPI_MEM_SPI_FMEM_DDR_WDAT_SWP_V 0x1
#define SPI_MEM_SPI_FMEM_DDR_WDAT_SWP_S 3
/* SPI_MEM_SPI_FMEM_DDR_RDAT_SWP : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: Set the bit to reorder RX data of the word in DDR mode..*/
#define SPI_MEM_SPI_FMEM_DDR_RDAT_SWP (BIT(2))
#define SPI_MEM_SPI_FMEM_DDR_RDAT_SWP_M (BIT(2))
#define SPI_MEM_SPI_FMEM_DDR_RDAT_SWP_V 0x1
#define SPI_MEM_SPI_FMEM_DDR_RDAT_SWP_S 2
/* SPI_MEM_SPI_FMEM_VAR_DUMMY : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set the bit to enable variable dummy cycle in DDRmode..*/
#define SPI_MEM_SPI_FMEM_VAR_DUMMY (BIT(1))
#define SPI_MEM_SPI_FMEM_VAR_DUMMY_M (BIT(1))
#define SPI_MEM_SPI_FMEM_VAR_DUMMY_V 0x1
#define SPI_MEM_SPI_FMEM_VAR_DUMMY_S 1
/* SPI_MEM_SPI_FMEM_DDR_EN : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: 1: in DDR mode, 0: in SDR mode..*/
#define SPI_MEM_SPI_FMEM_DDR_EN (BIT(0))
#define SPI_MEM_SPI_FMEM_DDR_EN_M (BIT(0))
#define SPI_MEM_SPI_FMEM_DDR_EN_V 0x1
#define SPI_MEM_SPI_FMEM_DDR_EN_S 0
#define SPI_MEM_SPI_SMEM_DDR_REG(i) (REG_SPI_MEM_BASE(i) + 0xE4)
/* SPI_MEM_SPI_SMEM_HYPERBUS_CA : R/W ;bitpos:[30] ;default: 1'b0 ; */
/*description: Set this bit to enable HyperRAM address out when accesses to external RAM, which
means ADDR_OUT[31:0] = {spi_usr_addr_value[19:4], 13'd0, spi_usr_addr_value[3:1
]}..*/
#define SPI_MEM_SPI_SMEM_HYPERBUS_CA (BIT(30))
#define SPI_MEM_SPI_SMEM_HYPERBUS_CA_M (BIT(30))
#define SPI_MEM_SPI_SMEM_HYPERBUS_CA_V 0x1
#define SPI_MEM_SPI_SMEM_HYPERBUS_CA_S 30
/* SPI_MEM_SPI_SMEM_OCTA_RAM_ADDR : R/W ;bitpos:[29] ;default: 1'b0 ; */
/*description: Set this bit to enable octa_ram address out when accesses to external RAM, which
means ADDR_OUT[31:0] = {spi_usr_addr_value[25:4], 6'd0, spi_usr_addr_value[3:1]
, 1'b0}..*/
#define SPI_MEM_SPI_SMEM_OCTA_RAM_ADDR (BIT(29))
#define SPI_MEM_SPI_SMEM_OCTA_RAM_ADDR_M (BIT(29))
#define SPI_MEM_SPI_SMEM_OCTA_RAM_ADDR_V 0x1
#define SPI_MEM_SPI_SMEM_OCTA_RAM_ADDR_S 29
/* SPI_MEM_SPI_SMEM_CLK_DIFF_INV : R/W ;bitpos:[28] ;default: 1'b0 ; */
/*description: Set this bit to invert SPI_DIFF when accesses to external RAM. ..*/
#define SPI_MEM_SPI_SMEM_CLK_DIFF_INV (BIT(28))
#define SPI_MEM_SPI_SMEM_CLK_DIFF_INV_M (BIT(28))
#define SPI_MEM_SPI_SMEM_CLK_DIFF_INV_V 0x1
#define SPI_MEM_SPI_SMEM_CLK_DIFF_INV_S 28
/* SPI_MEM_SPI_SMEM_HYPERBUS_DUMMY_2X : R/W ;bitpos:[27] ;default: 1'b0 ; */
/*description: Set this bit to enable the vary dummy function in SPI HyperBus mode, when SPI0 a
ccesses to flash or SPI1 accesses flash or sram..*/
#define SPI_MEM_SPI_SMEM_HYPERBUS_DUMMY_2X (BIT(27))
#define SPI_MEM_SPI_SMEM_HYPERBUS_DUMMY_2X_M (BIT(27))
#define SPI_MEM_SPI_SMEM_HYPERBUS_DUMMY_2X_V 0x1
#define SPI_MEM_SPI_SMEM_HYPERBUS_DUMMY_2X_S 27
/* SPI_MEM_SPI_SMEM_DQS_CA_IN : R/W ;bitpos:[26] ;default: 1'b0 ; */
/*description: Set this bit to enable the input of SPI_DQS signal in SPI phases of CMD and ADDR
..*/
#define SPI_MEM_SPI_SMEM_DQS_CA_IN (BIT(26))
#define SPI_MEM_SPI_SMEM_DQS_CA_IN_M (BIT(26))
#define SPI_MEM_SPI_SMEM_DQS_CA_IN_V 0x1
#define SPI_MEM_SPI_SMEM_DQS_CA_IN_S 26
/* SPI_MEM_SPI_SMEM_HYPERBUS_MODE : R/W ;bitpos:[25] ;default: 1'b0 ; */
/*description: Set this bit to enable the SPI HyperBus mode..*/
#define SPI_MEM_SPI_SMEM_HYPERBUS_MODE (BIT(25))
#define SPI_MEM_SPI_SMEM_HYPERBUS_MODE_M (BIT(25))
#define SPI_MEM_SPI_SMEM_HYPERBUS_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_HYPERBUS_MODE_S 25
/* SPI_MEM_SPI_SMEM_CLK_DIFF_EN : R/W ;bitpos:[24] ;default: 1'b0 ; */
/*description: Set this bit to enable the differential SPI_CLK#..*/
#define SPI_MEM_SPI_SMEM_CLK_DIFF_EN (BIT(24))
#define SPI_MEM_SPI_SMEM_CLK_DIFF_EN_M (BIT(24))
#define SPI_MEM_SPI_SMEM_CLK_DIFF_EN_V 0x1
#define SPI_MEM_SPI_SMEM_CLK_DIFF_EN_S 24
/* SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_MODE : R/W ;bitpos:[22] ;default: 1'b0 ; */
/*description: When SPI_SMEM_DDR_DQS_LOOP and SPI_SMEM_DDR_EN are set, 1: Use internal SPI_CLK
as data strobe. 0: Use internal ~SPI_CLK as data strobe. Otherwise this bit is
not active..*/
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_MODE (BIT(22))
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_MODE_M (BIT(22))
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_MODE_V 0x1
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_MODE_S 22
/* SPI_MEM_SPI_SMEM_DDR_DQS_LOOP : R/W ;bitpos:[21] ;default: 1'b0 ; */
/*description: 1: Use internal signal as data strobe, the strobe can not be delayed by input t
iming module. 0: Use input SPI_DQS signal from PAD as data strobe, the strobe ca
n be delayed by input timing module.*/
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP (BIT(21))
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_M (BIT(21))
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_V 0x1
#define SPI_MEM_SPI_SMEM_DDR_DQS_LOOP_S 21
/* SPI_MEM_SPI_SMEM_USR_DDR_DQS_THD : R/W ;bitpos:[20:14] ;default: 7'b0 ; */
/*description: The delay number of data strobe which from memory based on SPI_CLK..*/
#define SPI_MEM_SPI_SMEM_USR_DDR_DQS_THD 0x0000007F
#define SPI_MEM_SPI_SMEM_USR_DDR_DQS_THD_M ((SPI_MEM_SPI_SMEM_USR_DDR_DQS_THD_V)<<(SPI_MEM_SPI_SMEM_USR_DDR_DQS_THD_S))
#define SPI_MEM_SPI_SMEM_USR_DDR_DQS_THD_V 0x7F
#define SPI_MEM_SPI_SMEM_USR_DDR_DQS_THD_S 14
/* SPI_MEM_SPI_SMEM_RX_DDR_MSK_EN : R/W ;bitpos:[13] ;default: 1'h1 ; */
/*description: Set this bit to mask the first or the last byte in MSPI ECC DDR read mode, when
accesses to external RAM..*/
#define SPI_MEM_SPI_SMEM_RX_DDR_MSK_EN (BIT(13))
#define SPI_MEM_SPI_SMEM_RX_DDR_MSK_EN_M (BIT(13))
#define SPI_MEM_SPI_SMEM_RX_DDR_MSK_EN_V 0x1
#define SPI_MEM_SPI_SMEM_RX_DDR_MSK_EN_S 13
/* SPI_MEM_SPI_SMEM_TX_DDR_MSK_EN : R/W ;bitpos:[12] ;default: 1'h1 ; */
/*description: Set this bit to mask the first or the last byte in MSPI ECC DDR write mode, when
accesses to external RAM..*/
#define SPI_MEM_SPI_SMEM_TX_DDR_MSK_EN (BIT(12))
#define SPI_MEM_SPI_SMEM_TX_DDR_MSK_EN_M (BIT(12))
#define SPI_MEM_SPI_SMEM_TX_DDR_MSK_EN_V 0x1
#define SPI_MEM_SPI_SMEM_TX_DDR_MSK_EN_S 12
/* SPI_MEM_SPI_SMEM_OUTMINBYTELEN : R/W ;bitpos:[11:5] ;default: 7'b1 ; */
/*description: It is the minimum output data length in the ddr psram..*/
#define SPI_MEM_SPI_SMEM_OUTMINBYTELEN 0x0000007F
#define SPI_MEM_SPI_SMEM_OUTMINBYTELEN_M ((SPI_MEM_SPI_SMEM_OUTMINBYTELEN_V)<<(SPI_MEM_SPI_SMEM_OUTMINBYTELEN_S))
#define SPI_MEM_SPI_SMEM_OUTMINBYTELEN_V 0x7F
#define SPI_MEM_SPI_SMEM_OUTMINBYTELEN_S 5
/* SPI_MEM_SPI_SMEM_DDR_CMD_DIS : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: the bit is used to disable dual edge in CMD phase when ddr mode..*/
#define SPI_MEM_SPI_SMEM_DDR_CMD_DIS (BIT(4))
#define SPI_MEM_SPI_SMEM_DDR_CMD_DIS_M (BIT(4))
#define SPI_MEM_SPI_SMEM_DDR_CMD_DIS_V 0x1
#define SPI_MEM_SPI_SMEM_DDR_CMD_DIS_S 4
/* SPI_MEM_SPI_SMEM_DDR_WDAT_SWP : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: Set the bit to reorder tx data of the word in spi ddr mode..*/
#define SPI_MEM_SPI_SMEM_DDR_WDAT_SWP (BIT(3))
#define SPI_MEM_SPI_SMEM_DDR_WDAT_SWP_M (BIT(3))
#define SPI_MEM_SPI_SMEM_DDR_WDAT_SWP_V 0x1
#define SPI_MEM_SPI_SMEM_DDR_WDAT_SWP_S 3
/* SPI_MEM_SPI_SMEM_DDR_RDAT_SWP : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: Set the bit to reorder rx data of the word in spi ddr mode..*/
#define SPI_MEM_SPI_SMEM_DDR_RDAT_SWP (BIT(2))
#define SPI_MEM_SPI_SMEM_DDR_RDAT_SWP_M (BIT(2))
#define SPI_MEM_SPI_SMEM_DDR_RDAT_SWP_V 0x1
#define SPI_MEM_SPI_SMEM_DDR_RDAT_SWP_S 2
/* SPI_MEM_SPI_SMEM_VAR_DUMMY : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: Set the bit to enable variable dummy cycle in spi ddr mode..*/
#define SPI_MEM_SPI_SMEM_VAR_DUMMY (BIT(1))
#define SPI_MEM_SPI_SMEM_VAR_DUMMY_M (BIT(1))
#define SPI_MEM_SPI_SMEM_VAR_DUMMY_V 0x1
#define SPI_MEM_SPI_SMEM_VAR_DUMMY_S 1
/* SPI_MEM_SPI_SMEM_DDR_EN : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: 1: in ddr mode, 0 in sdr mode.*/
#define SPI_MEM_SPI_SMEM_DDR_EN (BIT(0))
#define SPI_MEM_SPI_SMEM_DDR_EN_M (BIT(0))
#define SPI_MEM_SPI_SMEM_DDR_EN_V 0x1
#define SPI_MEM_SPI_SMEM_DDR_EN_S 0
#define SPI_MEM_CLOCK_GATE_REG(i) (REG_SPI_MEM_BASE(i) + 0xE8)
/* SPI_MEM_CLK_EN : R/W ;bitpos:[0] ;default: 1'b1 ; */
/*description: Register clock gate enable signal. 1: Enable. 0: Disable..*/
#define SPI_MEM_CLK_EN (BIT(0))
#define SPI_MEM_CLK_EN_M (BIT(0))
#define SPI_MEM_CLK_EN_V 0x1
#define SPI_MEM_CLK_EN_S 0
#define SPI_MEM_CORE_CLK_SEL_REG(i) (REG_SPI_MEM_BASE(i) + 0xEC)
/* SPI_MEM_CORE_CLK_SEL : R/W ;bitpos:[1:0] ;default: 2'd0 ; */
/*description: When the digital system clock selects PLL clock and the frequency of PLL clock i
s 480MHz, the value of SPI_MEM_CORE_CLK_SEL: 0: SPI0/1 module clock (MSPI_CORE_
CLK) is 80MHz. 1: MSPI_CORE_CLK is 120MHz. 2: MSPI_CORE_CLK is 160MHz. 3: MSPI_
CORE_CLK is 240MHz. When the digital system clock selects PLL clock and the freq
uency of PLL clock is 320MHz, the value of SPI_MEM_CORE_CLK_SEL: 0: MSPI_CORE_C
LK is 80MHz. 1: MSPI_CORE_CLK is 80MHz. 2: MSPI_CORE_CLK 160MHz. 3: Not used. .*/
#define SPI_MEM_CORE_CLK_SEL 0x00000003
#define SPI_MEM_CORE_CLK_SEL_M ((SPI_MEM_CORE_CLK_SEL_V)<<(SPI_MEM_CORE_CLK_SEL_S))
#define SPI_MEM_CORE_CLK_SEL_V 0x3
#define SPI_MEM_CORE_CLK_SEL_S 0
#define SPI_MEM_INT_ENA_REG(i) (REG_SPI_MEM_BASE(i) + 0xF0)
/* SPI_MEM_ECC_ERR_INT_ENA : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: The enable bit for SPI_MEM_ECC_ERR_INT interrupt..*/
#define SPI_MEM_ECC_ERR_INT_ENA (BIT(4))
#define SPI_MEM_ECC_ERR_INT_ENA_M (BIT(4))
#define SPI_MEM_ECC_ERR_INT_ENA_V 0x1
#define SPI_MEM_ECC_ERR_INT_ENA_S 4
/* SPI_MEM_BROWN_OUT_INT_ENA : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: The enable bit for SPI_MEM_BROWN_OUT_INT interrupt..*/
#define SPI_MEM_BROWN_OUT_INT_ENA (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_ENA_M (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_ENA_V 0x1
#define SPI_MEM_BROWN_OUT_INT_ENA_S 3
/* SPI_MEM_TOTAL_TRANS_END_INT_ENA : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: The enable bit for SPI_MEM_TOTAL_TRANS_END_INT interrupt..*/
#define SPI_MEM_TOTAL_TRANS_END_INT_ENA (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_ENA_M (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_ENA_V 0x1
#define SPI_MEM_TOTAL_TRANS_END_INT_ENA_S 2
/* SPI_MEM_PES_END_INT_ENA : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: The enable bit for SPI_MEM_PES_END_INT interrupt..*/
#define SPI_MEM_PES_END_INT_ENA (BIT(1))
#define SPI_MEM_PES_END_INT_ENA_M (BIT(1))
#define SPI_MEM_PES_END_INT_ENA_V 0x1
#define SPI_MEM_PES_END_INT_ENA_S 1
/* SPI_MEM_PER_END_INT_ENA : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: The enable bit for SPI_MEM_PER_END_INT interrupt..*/
#define SPI_MEM_PER_END_INT_ENA (BIT(0))
#define SPI_MEM_PER_END_INT_ENA_M (BIT(0))
#define SPI_MEM_PER_END_INT_ENA_V 0x1
#define SPI_MEM_PER_END_INT_ENA_S 0
#define SPI_MEM_INT_CLR_REG(i) (REG_SPI_MEM_BASE(i) + 0xF4)
/* SPI_MEM_ECC_ERR_INT_CLR : WT ;bitpos:[4] ;default: 1'b0 ; */
/*description: The clear bit for SPI_MEM_ECC_ERR_INT interrupt. SPI_MEM_ECC_ERR_ADDR and SPI_ME
M_ECC_ERR_CNT will be cleared by the pulse of this bit..*/
#define SPI_MEM_ECC_ERR_INT_CLR (BIT(4))
#define SPI_MEM_ECC_ERR_INT_CLR_M (BIT(4))
#define SPI_MEM_ECC_ERR_INT_CLR_V 0x1
#define SPI_MEM_ECC_ERR_INT_CLR_S 4
/* SPI_MEM_BROWN_OUT_INT_CLR : WT ;bitpos:[3] ;default: 1'b0 ; */
/*description: The status bit for SPI_MEM_BROWN_OUT_INT interrupt..*/
#define SPI_MEM_BROWN_OUT_INT_CLR (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_CLR_M (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_CLR_V 0x1
#define SPI_MEM_BROWN_OUT_INT_CLR_S 3
/* SPI_MEM_TOTAL_TRANS_END_INT_CLR : WT ;bitpos:[2] ;default: 1'b0 ; */
/*description: The clear bit for SPI_MEM_TOTAL_TRANS_END_INT interrupt..*/
#define SPI_MEM_TOTAL_TRANS_END_INT_CLR (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_CLR_M (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_CLR_V 0x1
#define SPI_MEM_TOTAL_TRANS_END_INT_CLR_S 2
/* SPI_MEM_PES_END_INT_CLR : WT ;bitpos:[1] ;default: 1'b0 ; */
/*description: The clear bit for SPI_MEM_PES_END_INT interrupt..*/
#define SPI_MEM_PES_END_INT_CLR (BIT(1))
#define SPI_MEM_PES_END_INT_CLR_M (BIT(1))
#define SPI_MEM_PES_END_INT_CLR_V 0x1
#define SPI_MEM_PES_END_INT_CLR_S 1
/* SPI_MEM_PER_END_INT_CLR : WT ;bitpos:[0] ;default: 1'b0 ; */
/*description: The clear bit for SPI_MEM_PER_END_INT interrupt..*/
#define SPI_MEM_PER_END_INT_CLR (BIT(0))
#define SPI_MEM_PER_END_INT_CLR_M (BIT(0))
#define SPI_MEM_PER_END_INT_CLR_V 0x1
#define SPI_MEM_PER_END_INT_CLR_S 0
#define SPI_MEM_INT_RAW_REG(i) (REG_SPI_MEM_BASE(i) + 0xF8)
/* SPI_MEM_ECC_ERR_INT_RAW : R/WTC/SS ;bitpos:[4] ;default: 1'b0 ; */
/*description: The raw bit for SPI_MEM_ECC_ERR_INT interrupt. When APB_CTRL_FECC_ERR_INT_EN is
set and APB_CTRL_SECC_ERR_INT_EN is cleared, this bit is triggered when the err
or times of SPI0/1 ECC read flash are equal or bigger than APB_CTRL_ECC_ERR_INT_
NUM. When APB_CTRL_FECC_ERR_INT_EN is cleared and APB_CTRL_SECC_ERR_INT_EN is s
et, this bit is triggered when the error times of SPI0/1 ECC read external RAM a
re equal or bigger than APB_CTRL_ECC_ERR_INT_NUM. When APB_CTRL_FECC_ERR_INT_EN
and APB_CTRL_SECC_ERR_INT_EN are set, this bit is triggered when the total erro
r times of SPI0/1 ECC read external RAM and flash are equal or bigger than APB_C
TRL_ECC_ERR_INT_NUM. When APB_CTRL_FECC_ERR_INT_EN and APB_CTRL_SECC_ERR_INT_EN
are cleared, this bit will not be triggered..*/
#define SPI_MEM_ECC_ERR_INT_RAW (BIT(4))
#define SPI_MEM_ECC_ERR_INT_RAW_M (BIT(4))
#define SPI_MEM_ECC_ERR_INT_RAW_V 0x1
#define SPI_MEM_ECC_ERR_INT_RAW_S 4
/* SPI_MEM_BROWN_OUT_INT_RAW : R/WTC/SS ;bitpos:[3] ;default: 1'b0 ; */
/*description: The raw bit for SPI_MEM_BROWN_OUT_INT interrupt. 1: Triggered condition is that
chip is loosing power and RTC module sends out brown out close flash request to
SPI1. After SPI1 sends out suspend command to flash, this interrupt is triggered
and MSPI returns to idle state. 0: Others..*/
#define SPI_MEM_BROWN_OUT_INT_RAW (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_RAW_M (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_RAW_V 0x1
#define SPI_MEM_BROWN_OUT_INT_RAW_S 3
/* SPI_MEM_TOTAL_TRANS_END_INT_RAW : R/WTC/SS ;bitpos:[2] ;default: 1'b0 ; */
/*description: The raw bit for SPI_MEM_TOTAL_TRANS_END_INT interrupt. 1: Triggered when SPI1 tr
ansfer is done and flash is already idle. When WRSR/PP/SE/BE/CE is sent and PES/
PER command is sent, this bit is set when WRSR/PP/SE/BE/CE is success. 0: Other
s..*/
#define SPI_MEM_TOTAL_TRANS_END_INT_RAW (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_RAW_M (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_RAW_V 0x1
#define SPI_MEM_TOTAL_TRANS_END_INT_RAW_S 2
/* SPI_MEM_PES_END_INT_RAW : R/WTC/SS ;bitpos:[1] ;default: 1'b0 ; */
/*description: The raw bit for SPI_MEM_PES_END_INT interrupt.1: Triggered when Auto Suspend com
mand (0x75) is sent and flash is suspended successfully. 0: Others..*/
#define SPI_MEM_PES_END_INT_RAW (BIT(1))
#define SPI_MEM_PES_END_INT_RAW_M (BIT(1))
#define SPI_MEM_PES_END_INT_RAW_V 0x1
#define SPI_MEM_PES_END_INT_RAW_S 1
/* SPI_MEM_PER_END_INT_RAW : R/WTC/SS ;bitpos:[0] ;default: 1'b0 ; */
/*description: The raw bit for SPI_MEM_PER_END_INT interrupt. 1: Triggered when Auto Resume com
mand (0x7A) is sent and flash is resumed successfully. 0: Others..*/
#define SPI_MEM_PER_END_INT_RAW (BIT(0))
#define SPI_MEM_PER_END_INT_RAW_M (BIT(0))
#define SPI_MEM_PER_END_INT_RAW_V 0x1
#define SPI_MEM_PER_END_INT_RAW_S 0
#define SPI_MEM_INT_ST_REG(i) (REG_SPI_MEM_BASE(i) + 0xFC)
/* SPI_MEM_ECC_ERR_INT_ST : RO ;bitpos:[4] ;default: 1'b0 ; */
/*description: The status bit for SPI_MEM_ECC_ERR_INT interrupt..*/
#define SPI_MEM_ECC_ERR_INT_ST (BIT(4))
#define SPI_MEM_ECC_ERR_INT_ST_M (BIT(4))
#define SPI_MEM_ECC_ERR_INT_ST_V 0x1
#define SPI_MEM_ECC_ERR_INT_ST_S 4
/* SPI_MEM_BROWN_OUT_INT_ST : RO ;bitpos:[3] ;default: 1'b0 ; */
/*description: The status bit for SPI_MEM_BROWN_OUT_INT interrupt..*/
#define SPI_MEM_BROWN_OUT_INT_ST (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_ST_M (BIT(3))
#define SPI_MEM_BROWN_OUT_INT_ST_V 0x1
#define SPI_MEM_BROWN_OUT_INT_ST_S 3
/* SPI_MEM_TOTAL_TRANS_END_INT_ST : RO ;bitpos:[2] ;default: 1'b0 ; */
/*description: The status bit for SPI_MEM_TOTAL_TRANS_END_INT interrupt..*/
#define SPI_MEM_TOTAL_TRANS_END_INT_ST (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_ST_M (BIT(2))
#define SPI_MEM_TOTAL_TRANS_END_INT_ST_V 0x1
#define SPI_MEM_TOTAL_TRANS_END_INT_ST_S 2
/* SPI_MEM_PES_END_INT_ST : RO ;bitpos:[1] ;default: 1'b0 ; */
/*description: The status bit for SPI_MEM_PES_END_INT interrupt..*/
#define SPI_MEM_PES_END_INT_ST (BIT(1))
#define SPI_MEM_PES_END_INT_ST_M (BIT(1))
#define SPI_MEM_PES_END_INT_ST_V 0x1
#define SPI_MEM_PES_END_INT_ST_S 1
/* SPI_MEM_PER_END_INT_ST : RO ;bitpos:[0] ;default: 1'b0 ; */
/*description: The status bit for SPI_MEM_PER_END_INT interrupt..*/
#define SPI_MEM_PER_END_INT_ST (BIT(0))
#define SPI_MEM_PER_END_INT_ST_M (BIT(0))
#define SPI_MEM_PER_END_INT_ST_V 0x1
#define SPI_MEM_PER_END_INT_ST_S 0
#define SPI_MEM_DATE_REG(i) (REG_SPI_MEM_BASE(i) + 0x3FC)
/* SPI_MEM_DATE : R/W ;bitpos:[27:5] ;default: 23'h108082 ; */
/*description: SPI register version..*/
#define SPI_MEM_DATE 0x007FFFFF
#define SPI_MEM_DATE_M ((SPI_MEM_DATE_V)<<(SPI_MEM_DATE_S))
#define SPI_MEM_DATE_V 0x7FFFFF
#define SPI_MEM_DATE_S 5
/* SPI_MEM_SPICLK_PAD_DRV_CTL_EN : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: SPI_CLK PAD driver control signal. 1: The driver of SPI_CLK PAD is controlled b
y the bits SPI_FMEM_SPICLK_FUN_DRV[1:0] and SPI_SMEM_SPICLK_FUN_DRV[1:0]. 0: The
driver of SPI_CLK PAD is controlled by the bits IO_MUX_FUNC_DRV[1:0] of SPICLK
PAD..*/
#define SPI_MEM_SPICLK_PAD_DRV_CTL_EN (BIT(4))
#define SPI_MEM_SPICLK_PAD_DRV_CTL_EN_M (BIT(4))
#define SPI_MEM_SPICLK_PAD_DRV_CTL_EN_V 0x1
#define SPI_MEM_SPICLK_PAD_DRV_CTL_EN_S 4
/* SPI_MEM_SPI_FMEM_SPICLK_FUN_DRV : R/W ;bitpos:[3:2] ;default: 2'b0 ; */
/*description: The driver of SPI_CLK PAD is controlled by the bits SPI_FMEM_SPICLK_FUN_DRV[1:0
] when the bit SPI_SPICLK_PAD_DRV_CTL_EN is set and MSPI accesses to flash..*/
#define SPI_MEM_SPI_FMEM_SPICLK_FUN_DRV 0x00000003
#define SPI_MEM_SPI_FMEM_SPICLK_FUN_DRV_M ((SPI_MEM_SPI_FMEM_SPICLK_FUN_DRV_V)<<(SPI_MEM_SPI_FMEM_SPICLK_FUN_DRV_S))
#define SPI_MEM_SPI_FMEM_SPICLK_FUN_DRV_V 0x3
#define SPI_MEM_SPI_FMEM_SPICLK_FUN_DRV_S 2
/* SPI_MEM_SPI_SMEM_SPICLK_FUN_DRV : R/W ;bitpos:[1:0] ;default: 2'b0 ; */
/*description: The driver of SPI_CLK PAD is controlled by the bits SPI_SMEM_SPICLK_FUN_DRV[1:0
] when the bit SPI_SPICLK_PAD_DRV_CTL_EN is set and MSPI accesses to external RA
M..*/
#define SPI_MEM_SPI_SMEM_SPICLK_FUN_DRV 0x00000003
#define SPI_MEM_SPI_SMEM_SPICLK_FUN_DRV_M ((SPI_MEM_SPI_SMEM_SPICLK_FUN_DRV_V)<<(SPI_MEM_SPI_SMEM_SPICLK_FUN_DRV_S))
#define SPI_MEM_SPI_SMEM_SPICLK_FUN_DRV_V 0x3
#define SPI_MEM_SPI_SMEM_SPICLK_FUN_DRV_S 0
#ifdef __cplusplus
}
#endif
#endif /*_SOC_SPI_MEM_REG_H_ */