2024-06-26 12:05:24 +03:00
|
|
|
/*
|
|
|
|
* QEMU PowerPC SPI model
|
|
|
|
*
|
|
|
|
* Copyright (c) 2024, IBM Corporation.
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PNV_SPI_CONTROLLER_REGS_H
|
|
|
|
#define PNV_SPI_CONTROLLER_REGS_H
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Macros from target/ppc/cpu.h
|
|
|
|
* These macros are copied from ppc target specific file target/ppc/cpu.h
|
|
|
|
* as target/ppc/cpu.h cannot be included here.
|
|
|
|
*/
|
|
|
|
#define PPC_BIT(bit) (0x8000000000000000ULL >> (bit))
|
|
|
|
#define PPC_BIT8(bit) (0x80 >> (bit))
|
|
|
|
#define PPC_BITMASK(bs, be) ((PPC_BIT(bs) - PPC_BIT(be)) | PPC_BIT(bs))
|
|
|
|
#define PPC_BITMASK8(bs, be) ((PPC_BIT8(bs) - PPC_BIT8(be)) | PPC_BIT8(bs))
|
|
|
|
#define MASK_TO_LSH(m) (__builtin_ffsll(m) - 1)
|
|
|
|
#define GETFIELD(m, v) (((v) & (m)) >> MASK_TO_LSH(m))
|
|
|
|
#define SETFIELD(m, v, val) \
|
|
|
|
(((v) & ~(m)) | ((((typeof(v))(val)) << MASK_TO_LSH(m)) & (m)))
|
|
|
|
|
|
|
|
/* Error Register */
|
|
|
|
#define ERROR_REG 0x00
|
|
|
|
|
|
|
|
/* counter_config_reg */
|
|
|
|
#define SPI_CTR_CFG_REG 0x01
|
2024-06-26 12:05:25 +03:00
|
|
|
#define SPI_CTR_CFG_N1 PPC_BITMASK(0, 7)
|
|
|
|
#define SPI_CTR_CFG_N2 PPC_BITMASK(8, 15)
|
|
|
|
#define SPI_CTR_CFG_CMP1 PPC_BITMASK(24, 31)
|
|
|
|
#define SPI_CTR_CFG_CMP2 PPC_BITMASK(32, 39)
|
|
|
|
#define SPI_CTR_CFG_N1_CTRL_B1 PPC_BIT(49)
|
|
|
|
#define SPI_CTR_CFG_N1_CTRL_B2 PPC_BIT(50)
|
|
|
|
#define SPI_CTR_CFG_N1_CTRL_B3 PPC_BIT(51)
|
|
|
|
#define SPI_CTR_CFG_N2_CTRL_B0 PPC_BIT(52)
|
|
|
|
#define SPI_CTR_CFG_N2_CTRL_B1 PPC_BIT(53)
|
|
|
|
#define SPI_CTR_CFG_N2_CTRL_B2 PPC_BIT(54)
|
|
|
|
#define SPI_CTR_CFG_N2_CTRL_B3 PPC_BIT(55)
|
2024-06-26 12:05:24 +03:00
|
|
|
|
|
|
|
/* config_reg */
|
|
|
|
#define CONFIG_REG1 0x02
|
|
|
|
|
|
|
|
/* clock_config_reset_control_ecc_enable_reg */
|
|
|
|
#define SPI_CLK_CFG_REG 0x03
|
|
|
|
#define SPI_CLK_CFG_HARD_RST 0x0084000000000000;
|
|
|
|
#define SPI_CLK_CFG_RST_CTRL PPC_BITMASK(24, 27)
|
2024-06-26 12:05:25 +03:00
|
|
|
#define SPI_CLK_CFG_ECC_EN PPC_BIT(28)
|
|
|
|
#define SPI_CLK_CFG_ECC_CTRL PPC_BITMASK(29, 30)
|
2024-06-26 12:05:24 +03:00
|
|
|
|
|
|
|
/* memory_mapping_reg */
|
|
|
|
#define SPI_MM_REG 0x04
|
2024-06-26 12:05:25 +03:00
|
|
|
#define SPI_MM_RDR_MATCH_VAL PPC_BITMASK(32, 47)
|
|
|
|
#define SPI_MM_RDR_MATCH_MASK PPC_BITMASK(48, 63)
|
2024-06-26 12:05:24 +03:00
|
|
|
|
|
|
|
/* transmit_data_reg */
|
|
|
|
#define SPI_XMIT_DATA_REG 0x05
|
|
|
|
|
|
|
|
/* receive_data_reg */
|
|
|
|
#define SPI_RCV_DATA_REG 0x06
|
|
|
|
|
|
|
|
/* sequencer_operation_reg */
|
|
|
|
#define SPI_SEQ_OP_REG 0x07
|
|
|
|
|
|
|
|
/* status_reg */
|
|
|
|
#define SPI_STS_REG 0x08
|
|
|
|
#define SPI_STS_RDR_FULL PPC_BIT(0)
|
|
|
|
#define SPI_STS_RDR_OVERRUN PPC_BIT(1)
|
|
|
|
#define SPI_STS_RDR_UNDERRUN PPC_BIT(2)
|
|
|
|
#define SPI_STS_TDR_FULL PPC_BIT(4)
|
|
|
|
#define SPI_STS_TDR_OVERRUN PPC_BIT(5)
|
|
|
|
#define SPI_STS_TDR_UNDERRUN PPC_BIT(6)
|
|
|
|
#define SPI_STS_SEQ_FSM PPC_BITMASK(8, 15)
|
|
|
|
#define SPI_STS_SHIFTER_FSM PPC_BITMASK(16, 27)
|
|
|
|
#define SPI_STS_SEQ_INDEX PPC_BITMASK(28, 31)
|
2024-06-26 12:05:25 +03:00
|
|
|
#define SPI_STS_GEN_STATUS_B3 PPC_BIT(35)
|
2024-06-26 12:05:24 +03:00
|
|
|
#define SPI_STS_RDR PPC_BITMASK(1, 3)
|
|
|
|
#define SPI_STS_TDR PPC_BITMASK(5, 7)
|
|
|
|
|
2024-06-26 12:05:25 +03:00
|
|
|
/*
|
|
|
|
* Shifter states
|
|
|
|
*
|
|
|
|
* These are the same values defined for the Shifter FSM field of the
|
|
|
|
* status register. It's a 12 bit field so we will represent it as three
|
|
|
|
* nibbles in the constants.
|
|
|
|
*
|
|
|
|
* These are shifter_fsm values
|
|
|
|
*
|
|
|
|
* Status reg bits 16-27 -> field bits 0-11
|
|
|
|
* bits 0,1,2,5 unused/reserved
|
|
|
|
* bit 4 crc shift in (unused)
|
|
|
|
* bit 8 crc shift out (unused)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define FSM_DONE 0x100 /* bit 3 */
|
|
|
|
#define FSM_SHIFT_N2 0x020 /* bit 6 */
|
|
|
|
#define FSM_WAIT 0x010 /* bit 7 */
|
|
|
|
#define FSM_SHIFT_N1 0x004 /* bit 9 */
|
|
|
|
#define FSM_START 0x002 /* bit 10 */
|
|
|
|
#define FSM_IDLE 0x001 /* bit 11 */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Sequencer states
|
|
|
|
*
|
|
|
|
* These are sequencer_fsm values
|
|
|
|
*
|
|
|
|
* Status reg bits 8-15 -> field bits 0-7
|
|
|
|
* bits 0-3 unused/reserved
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#define SEQ_STATE_INDEX_INCREMENT 0x08 /* bit 4 */
|
|
|
|
#define SEQ_STATE_EXECUTE 0x04 /* bit 5 */
|
|
|
|
#define SEQ_STATE_DECODE 0x02 /* bit 6 */
|
|
|
|
#define SEQ_STATE_IDLE 0x01 /* bit 7 */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* These are the supported sequencer operations.
|
|
|
|
* Only the upper nibble is significant because for many operations
|
|
|
|
* the lower nibble is a variable specific to the operation.
|
|
|
|
*/
|
|
|
|
#define SEQ_OP_STOP 0x00
|
|
|
|
#define SEQ_OP_SELECT_SLAVE 0x10
|
|
|
|
#define SEQ_OP_SHIFT_N1 0x30
|
|
|
|
#define SEQ_OP_SHIFT_N2 0x40
|
|
|
|
#define SEQ_OP_BRANCH_IFNEQ_RDR 0x60
|
|
|
|
#define SEQ_OP_TRANSFER_TDR 0xC0
|
|
|
|
#define SEQ_OP_BRANCH_IFNEQ_INC_1 0xE0
|
|
|
|
#define SEQ_OP_BRANCH_IFNEQ_INC_2 0xF0
|
|
|
|
#define NUM_SEQ_OPS 8
|
|
|
|
|
2024-06-26 12:05:24 +03:00
|
|
|
#endif
|