blob: cef0bdf0e0fd568e6a66e2f927ad1a5fc11092d6 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0-only */
/* This file is part of the coreboot project. */
#ifndef MTK_MT8183_SPI_H
#define MTK_MT8183_SPI_H
#include <soc/spi_common.h>
#define SPI_BUS_NUMBER 6
/* SPI peripheral register map. */
typedef struct mtk_spi_regs {
uint32_t spi_cfg0_reg;
uint32_t spi_cfg1_reg;
uint32_t spi_tx_src_reg;
uint32_t spi_rx_dst_reg;
uint32_t spi_tx_data_reg;
uint32_t spi_rx_data_reg;
uint32_t spi_cmd_reg;
uint32_t spi_status0_reg;
uint32_t spi_status1_reg;
uint32_t spi_pad_macro_sel_reg;
uint32_t spi_cfg2_reg;
uint32_t spi_tx_src_64_reg;
uint32_t spi_rx_dst_64_reg;
} mtk_spi_regs;
check_member(mtk_spi_regs, spi_pad_macro_sel_reg, 0x24);
enum {
SPI_CFG0_CS_HOLD_SHIFT = 0,
SPI_CFG0_CS_SETUP_SHIFT = 16,
};
enum {
SPI_CFG2_SCK_LOW_SHIFT = 0,
SPI_CFG2_SCK_HIGH_SHIFT = 16,
};
enum {
SPI_CFG1_TICK_DLY_SHIFT = 29,
SPI_CFG1_TICK_DLY_MASK = 0x7 << SPI_CFG1_TICK_DLY_SHIFT,
};
#endif