diff options
author | Shelley Chen <shchen@google.com> | 2023-02-23 22:40:42 +0000 |
---|---|---|
committer | Shelley Chen <shchen@google.com> | 2023-02-24 19:28:24 +0000 |
commit | 1720ba5e6bb70f76542420cd1d5633ea142db12a (patch) | |
tree | 07524cd9b921e8b4350bcdd690300fdf2117e9c5 /src/soc | |
parent | a0473c3be68d689e728542b3036d4e751439c36c (diff) |
Revert "soc/qualcomm: Increase SPI frequency to 75 MHz"
This reverts commit 363202b43589ec240c4a0c8f5b449fbd5c1333f8.
Reason for revert: Seeing some bit flips on the SPI bus, but cannot
repro reliably on local builds. Going to downgrade back to 50 MHz
to see if builder builds are more stable on each variant as a result.
Signed-off-by: Shelley Chen <shchen@google.com>
Change-Id: I4fe76bac915e3b3c794821cd160a66824e38ea83
Reviewed-on: https://review.coreboot.org/c/coreboot/+/73214
Reviewed-by: Julius Werner <jwerner@chromium.org>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Diffstat (limited to 'src/soc')
-rw-r--r-- | src/soc/qualcomm/common/include/soc/qspi_common.h | 12 | ||||
-rw-r--r-- | src/soc/qualcomm/common/qspi.c | 24 | ||||
-rw-r--r-- | src/soc/qualcomm/sc7180/bootblock.c | 2 | ||||
-rw-r--r-- | src/soc/qualcomm/sc7280/bootblock.c | 7 | ||||
-rw-r--r-- | src/soc/qualcomm/sc7280/clock.c | 10 |
5 files changed, 7 insertions, 48 deletions
diff --git a/src/soc/qualcomm/common/include/soc/qspi_common.h b/src/soc/qualcomm/common/include/soc/qspi_common.h index a0c8e46812..6e4b779aee 100644 --- a/src/soc/qualcomm/common/include/soc/qspi_common.h +++ b/src/soc/qualcomm/common/include/soc/qspi_common.h @@ -26,7 +26,6 @@ struct qcom_qspi_regs { u32 current_mem_addr; u32 hw_version; u32 rd_fifo[16]; - u32 sampling_clk_cfg; }; check_member(qcom_qspi_regs, rd_fifo, 0x50); @@ -98,16 +97,7 @@ static struct qcom_qspi_regs * const qcom_qspi = (void *)QSPI_BASE; #define QSPI_MAX_PACKET_COUNT 0xFFC0 -/* - * quadspi_init(): Configure SPI - * - * @param hz: SPI frequency in Hz - * @param sdelay: sampling delay in sdelay/8 cycle units example, if sdelay=1, - * then will delay sampling clock by 1/8 cycle. Note that - * setting sdelay to 4-7 would result in a negative sampling - * delay compared to 0. - */ -void quadspi_init(uint32_t hz, uint32_t sdelay); +void quadspi_init(uint32_t hz); int qspi_claim_bus(const struct spi_slave *slave); int qspi_setup_bus(const struct spi_slave *slave); void qspi_release_bus(const struct spi_slave *slave); diff --git a/src/soc/qualcomm/common/qspi.c b/src/soc/qualcomm/common/qspi.c index eb0c062a81..3340c00dd6 100644 --- a/src/soc/qualcomm/common/qspi.c +++ b/src/soc/qualcomm/common/qspi.c @@ -221,26 +221,11 @@ static void queue_data(uint8_t *data, uint32_t data_bytes, queue_bounce_data(epilog_ptr, epilog_bytes, data_mode, write); } -/* - * The way to encode the sampling delay is: - * - * QSPI_SAMPLE_CLK_CONFIG delay (cycle) - * ---------------------------------------- - * 0xFFFh = 1111 1111 1111b 7/8 - * 0xDB6h = 1101 1011 0110b 6/8 - * 0xB6Dh = 1011 0110 1101b 5/8 - * 0x924h = 1001 0010 0100b 4/8 - * 0x6DBh = 0110 1101 1011b 3/8 - * 0x492h = 0100 1001 0010b 2/8 - * 0x249h = 0010 0100 1001b 1/8 - * 0x000h = 0000 0000 0000b None - */ -static void reg_init(uint32_t sdelay) +static void reg_init(void) { uint32_t spi_mode; uint32_t tx_data_oe_delay, tx_data_delay; uint32_t mstr_config; - uint32_t sampling_delay; spi_mode = 0; @@ -251,6 +236,7 @@ static void reg_init(uint32_t sdelay) (tx_data_delay << TX_DATA_DELAY_SHIFT) | (SBL_EN) | (spi_mode << SPI_MODE_SHIFT) | (PIN_HOLDN) | + (FB_CLK_EN) | (DMA_ENABLE) | (FULL_CYCLE_MODE); @@ -260,16 +246,14 @@ static void reg_init(uint32_t sdelay) write32(&qcom_qspi->mstr_int_sts, 0xFFFFFFFF); write32(&qcom_qspi->rd_fifo_cfg, 0x0); write32(&qcom_qspi->rd_fifo_rst, RESET_FIFO); - sampling_delay = sdelay << 9 | sdelay << 6 | sdelay << 3 | sdelay << 0; - write32(&qcom_qspi->sampling_clk_cfg, sampling_delay); } -void quadspi_init(uint32_t hz, uint32_t sdelay) +void quadspi_init(uint32_t hz) { assert(dcache_line_bytes() == CACHE_LINE_SIZE); clock_configure_qspi(hz * 4); configure_gpios(); - reg_init(sdelay); + reg_init(); } int qspi_claim_bus(const struct spi_slave *slave) diff --git a/src/soc/qualcomm/sc7180/bootblock.c b/src/soc/qualcomm/sc7180/bootblock.c index c108157573..365b7d4460 100644 --- a/src/soc/qualcomm/sc7180/bootblock.c +++ b/src/soc/qualcomm/sc7180/bootblock.c @@ -8,6 +8,6 @@ void bootblock_soc_init(void) { clock_init(); - quadspi_init(37500 * KHz, 0); + quadspi_init(37500 * KHz); qupv3_fw_init(); } diff --git a/src/soc/qualcomm/sc7280/bootblock.c b/src/soc/qualcomm/sc7280/bootblock.c index 0926127baf..bdabea1fbb 100644 --- a/src/soc/qualcomm/sc7280/bootblock.c +++ b/src/soc/qualcomm/sc7280/bootblock.c @@ -8,11 +8,6 @@ void bootblock_soc_init(void) { clock_init(); - /* - * Through experimentation, we have determined - * that a delay of 1/8 cycle is best for herobrine. - * See b/190231148 - */ - quadspi_init(75000 * KHz, 1); + quadspi_init(50000 * KHz); qupv3_fw_init(); } diff --git a/src/soc/qualcomm/sc7280/clock.c b/src/soc/qualcomm/sc7280/clock.c index 7b017c4d80..4441e48083 100644 --- a/src/soc/qualcomm/sc7280/clock.c +++ b/src/soc/qualcomm/sc7280/clock.c @@ -28,16 +28,6 @@ static struct clock_freq_config qspi_core_cfg[] = { .div = QCOM_CLOCK_DIV(3), }, { - .hz = 240 * MHz, - .src = SRC_GPLL0_MAIN_600MHZ, - .div = QCOM_CLOCK_DIV(2.5), - }, - { - .hz = 300 * MHz, - .src = SRC_GPLL0_MAIN_600MHZ, - .div = QCOM_CLOCK_DIV(2), - }, - { .hz = 400 * MHz, .src = SRC_GPLL0_MAIN_600MHZ, .div = QCOM_CLOCK_DIV(1.5), |