1*91f16700Schasinglulu /* 2*91f16700Schasinglulu * Copyright (c) 2017 - 2020, Broadcom 3*91f16700Schasinglulu * 4*91f16700Schasinglulu * SPDX-License-Identifier: BSD-3-Clause 5*91f16700Schasinglulu */ 6*91f16700Schasinglulu 7*91f16700Schasinglulu #ifndef IPROC_QSPI_H 8*91f16700Schasinglulu #define IPROC_QSPI_H 9*91f16700Schasinglulu 10*91f16700Schasinglulu #include <platform_def.h> 11*91f16700Schasinglulu 12*91f16700Schasinglulu /*SPI configuration enable*/ 13*91f16700Schasinglulu #define IPROC_QSPI_CLK_SPEED 62500000 14*91f16700Schasinglulu #define SPI_CPHA (1 << 0) 15*91f16700Schasinglulu #define SPI_CPOL (1 << 1) 16*91f16700Schasinglulu #define IPROC_QSPI_MODE0 0 17*91f16700Schasinglulu #define IPROC_QSPI_MODE3 (SPI_CPOL|SPI_CPHA) 18*91f16700Schasinglulu 19*91f16700Schasinglulu #define IPROC_QSPI_BUS 0 20*91f16700Schasinglulu #define IPROC_QSPI_CS 0 21*91f16700Schasinglulu #define IPROC_QSPI_BASE_REG QSPI_CTRL_BASE_ADDR 22*91f16700Schasinglulu #define IPROC_QSPI_CRU_CONTROL_REG QSPI_CLK_CTRL 23*91f16700Schasinglulu 24*91f16700Schasinglulu #define QSPI_AXI_CLK 200000000 25*91f16700Schasinglulu 26*91f16700Schasinglulu #define QSPI_RETRY_COUNT_US_MAX 200000 27*91f16700Schasinglulu 28*91f16700Schasinglulu /* Chip attributes */ 29*91f16700Schasinglulu #define QSPI_REG_BASE IPROC_QSPI_BASE_REG 30*91f16700Schasinglulu #define CRU_CONTROL_REG IPROC_QSPI_CRU_CONTROL_REG 31*91f16700Schasinglulu #define SPBR_DIV_MIN 8U 32*91f16700Schasinglulu #define SPBR_DIV_MAX 255U 33*91f16700Schasinglulu #define NUM_CDRAM_BYTES 16U 34*91f16700Schasinglulu 35*91f16700Schasinglulu /* Register fields */ 36*91f16700Schasinglulu #define MSPI_SPCR0_MSB_BITS_8 0x00000020 37*91f16700Schasinglulu 38*91f16700Schasinglulu /* Flash opcode and parameters */ 39*91f16700Schasinglulu #define CDRAM_PCS0 2 40*91f16700Schasinglulu #define CDRAM_CONT (1 << 7) 41*91f16700Schasinglulu #define CDRAM_BITS_EN (1 << 6) 42*91f16700Schasinglulu #define CDRAM_QUAD_MODE (1 << 8) 43*91f16700Schasinglulu #define CDRAM_RBIT_INPUT (1 << 10) 44*91f16700Schasinglulu 45*91f16700Schasinglulu /* MSPI registers */ 46*91f16700Schasinglulu #define QSPI_MSPI_MODE_REG_BASE (QSPI_REG_BASE + 0x200) 47*91f16700Schasinglulu #define MSPI_SPCR0_LSB_REG 0x000 48*91f16700Schasinglulu #define MSPI_SPCR0_MSB_REG 0x004 49*91f16700Schasinglulu #define MSPI_SPCR1_LSB_REG 0x008 50*91f16700Schasinglulu #define MSPI_SPCR1_MSB_REG 0x00c 51*91f16700Schasinglulu #define MSPI_NEWQP_REG 0x010 52*91f16700Schasinglulu #define MSPI_ENDQP_REG 0x014 53*91f16700Schasinglulu #define MSPI_SPCR2_REG 0x018 54*91f16700Schasinglulu #define MSPI_STATUS_REG 0x020 55*91f16700Schasinglulu #define MSPI_CPTQP_REG 0x024 56*91f16700Schasinglulu #define MSPI_TXRAM_REG 0x040 57*91f16700Schasinglulu #define MSPI_RXRAM_REG 0x0c0 58*91f16700Schasinglulu #define MSPI_CDRAM_REG 0x140 59*91f16700Schasinglulu #define MSPI_WRITE_LOCK_REG 0x180 60*91f16700Schasinglulu #define MSPI_DISABLE_FLUSH_GEN_REG 0x184 61*91f16700Schasinglulu 62*91f16700Schasinglulu #define MSPI_SPCR0_MSB_REG_MSTR_SHIFT 7 63*91f16700Schasinglulu #define MSPI_SPCR0_MSB_REG_16_BITS_PER_WD_SHIFT (0 << 2) 64*91f16700Schasinglulu #define MSPI_SPCR0_MSB_REG_MODE_MASK 0x3 65*91f16700Schasinglulu 66*91f16700Schasinglulu /* BSPI registers */ 67*91f16700Schasinglulu #define QSPI_BSPI_MODE_REG_BASE QSPI_REG_BASE 68*91f16700Schasinglulu #define BSPI_MAST_N_BOOT_CTRL_REG 0x008 69*91f16700Schasinglulu #define BSPI_BUSY_STATUS_REG 0x00c 70*91f16700Schasinglulu 71*91f16700Schasinglulu #define MSPI_CMD_COMPLETE_MASK 1 72*91f16700Schasinglulu #define BSPI_BUSY_MASK 1 73*91f16700Schasinglulu #define MSPI_CTRL_MASK 1 74*91f16700Schasinglulu 75*91f16700Schasinglulu #define MSPI_SPE (1 << 6) 76*91f16700Schasinglulu #define MSPI_CONT_AFTER_CMD (1 << 7) 77*91f16700Schasinglulu 78*91f16700Schasinglulu /* State */ 79*91f16700Schasinglulu enum bcm_qspi_state { 80*91f16700Schasinglulu QSPI_STATE_DISABLED, 81*91f16700Schasinglulu QSPI_STATE_MSPI, 82*91f16700Schasinglulu QSPI_STATE_BSPI 83*91f16700Schasinglulu }; 84*91f16700Schasinglulu 85*91f16700Schasinglulu /* QSPI private data */ 86*91f16700Schasinglulu struct bcmspi_priv { 87*91f16700Schasinglulu /* Specified SPI parameters */ 88*91f16700Schasinglulu uint32_t max_hz; 89*91f16700Schasinglulu uint32_t spi_mode; 90*91f16700Schasinglulu 91*91f16700Schasinglulu /* State */ 92*91f16700Schasinglulu enum bcm_qspi_state state; 93*91f16700Schasinglulu int mspi_16bit; 94*91f16700Schasinglulu 95*91f16700Schasinglulu /* Registers */ 96*91f16700Schasinglulu uintptr_t mspi_hw; 97*91f16700Schasinglulu uintptr_t bspi_hw; 98*91f16700Schasinglulu }; 99*91f16700Schasinglulu 100*91f16700Schasinglulu int iproc_qspi_setup(uint32_t bus, uint32_t cs, 101*91f16700Schasinglulu uint32_t max_hz, uint32_t mode); 102*91f16700Schasinglulu int iproc_qspi_claim_bus(void); 103*91f16700Schasinglulu void iproc_qspi_release_bus(void); 104*91f16700Schasinglulu int iproc_qspi_xfer(uint32_t bitlen, const void *dout, 105*91f16700Schasinglulu void *din, unsigned long flags); 106*91f16700Schasinglulu 107*91f16700Schasinglulu #endif /* _IPROC_QSPI_H_ */ 108