[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for
From: |
Francisco Iglesias |
Subject: |
Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands |
Date: |
Thu, 14 Jan 2021 19:13:00 +0100 |
User-agent: |
Mutt/1.10.1 (2018-07-13) |
Hi Bin,
On [2021 Jan 14] Thu 23:08:53, Bin Meng wrote:
> From: Bin Meng <bin.meng@windriver.com>
>
> The m25p80 model uses s->needed_bytes to indicate how many follow-up
> bytes are expected to be received after it receives a command. For
> example, depending on the address mode, either 3-byte address or
> 4-byte address is needed.
>
> For fast read family commands, some dummy cycles are required after
> sending the address bytes, and the dummy cycles need to be counted
> in s->needed_bytes. This is where the mess began.
>
> As the variable name (needed_bytes) indicates, the unit is in byte.
> It is not in bit, or cycle. However for some reason the model has
> been using the number of dummy cycles for s->needed_bytes. The right
> approach is to convert the number of dummy cycles to bytes based on
> the SPI protocol, for example, 6 dummy cycles for the Fast Read Quad
> I/O (EBh) should be converted to 3 bytes per the formula (6 * 4 / 8).
While not being the original implementor I must assume that above solution was
considered but not chosen by the developers due to it is inaccuracy (it
wouldn't be possible to model exacly 6 dummy cycles, only a multiple of 8,
meaning that if the controller is wrongly programmed to generate 7 the error
wouldn't be caught and the controller will still be considered "correct"). Now
that we have this detail in the implementation I'm in favor of keeping it, this
also because the detail is already in use for catching exactly above error.
>
> Things get complicated when interacting with different SPI or QSPI
> flash controllers. There are major two cases:
>
> - Dummy bytes prepared by drivers, and wrote to the controller fifo.
> For such case, driver will calculate the correct number of dummy
> bytes and write them into the tx fifo. Fixing the m25p80 model will
> fix flashes working with such controllers.
Above can be fixed while still keeping the detailed dummy cycle implementation
inside m25p80. Perhaps one of the following could be looked into: configurating
the amount, letting the spi ctrl fetch the amount from m25p80 or by inheriting
some functionality handling this in the SPI controller. Or a mixture of above.
> - Dummy bytes not prepared by drivers. Drivers just tell the hardware
> the dummy cycle configuration via some registers, and hardware will
> automatically generate dummy cycles for us. Fixing the m25p80 model
> is not enough, and we will need to fix the SPI/QSPI models for such
> controllers.
>
> This series fixes the mess in the m25p80 from the flash side first,
Considering the problems solved by the solution in tree I find m25p80 pretty
clean, at least I don't see any clearly better way for accurately modeling the
dummy clock cycles. Counting bits instead of bytes would for example still
force the controllers to mark which bits to count (when transmitting one dummy
byte from a txfifo on four lines (Quad command) it generates 2 dummy clock
cycles since it takes two cycles to transfer 8 bits).
Best regards,
Francisco Iglesias
> followed by fixes to 3 known SPI controller models that fall into
> the 2nd case above.
>
> Please note, I have no way to verify patch 7/8/9 because:
>
> * There is no public datasheet available for the SoC / SPI controller
> * There is no QEMU docs, or details that tell people how to boot either
> U-Boot or Linux kernel to verify the functionality
>
> These 3 patches are very likely to be wrong. Hence I would like to ask
> help from the original author who wrote these SPI controller models
> to help testing, or completely rewrite these 3 patches to fix things.
> Thanks!
>
> Patch 6 is unvalidated with QEMU, mainly because there is no doc to
> tell people how to boot anything to test. But I have some confidence
> based on my read of the ZynqMP manual, as well as some experimental
> testing on a real ZCU102 board.
>
> Other flash patches can be tested with the SiFive SPI series:
> http://patchwork.ozlabs.org/project/qemu-devel/list/?series=222391
>
> Cherry-pick patch 16 and 17 from the series above, and switch to
> different flash model to test with the following command:
>
> $ qemu-system-riscv64 -nographic -M sifive_u -m 2G -smp 5 -kernel u-boot
>
> I've picked up two for testing:
>
> QEMU flash: "sst25vf032b"
>
> U-Boot 2020.10 (Jan 14 2021 - 21:55:59 +0800)
>
> CPU: rv64imafdcsu
> Model: SiFive HiFive Unleashed A00
> DRAM: 2 GiB
> MMC:
> Loading Environment from SPIFlash... SF: Detected sst25vf032b with page
> size 256 Bytes, erase size 4 KiB, total 4 MiB
> *** Warning - bad CRC, using default environment
>
> In: serial@10010000
> Out: serial@10010000
> Err: serial@10010000
> Net: failed to get gemgxl_reset reset
>
> Warning: ethernet@10090000 MAC addresses don't match:
> Address in DT is 52:54:00:12:34:56
> Address in environment is 70:b3:d5:92:f0:01
> eth0: ethernet@10090000
> Hit any key to stop autoboot: 0
> => sf probe
> SF: Detected sst25vf032b with page size 256 Bytes, erase size 4 KiB,
> total 4 MiB
> => sf test 1ff000 1000
> SPI flash test:
> 0 erase: 0 ticks, 4096000 KiB/s 32768.000 Mbps
> 1 check: 10 ticks, 400 KiB/s 3.200 Mbps
> 2 write: 170 ticks, 23 KiB/s 0.184 Mbps
> 3 read: 9 ticks, 444 KiB/s 3.552 Mbps
> Test passed
> 0 erase: 0 ticks, 4096000 KiB/s 32768.000 Mbps
> 1 check: 10 ticks, 400 KiB/s 3.200 Mbps
> 2 write: 170 ticks, 23 KiB/s 0.184 Mbps
> 3 read: 9 ticks, 444 KiB/s 3.552 Mbps
>
> QEMU flash: "mx66u51235f"
>
> U-Boot 2020.10 (Jan 14 2021 - 21:55:59 +0800)
>
> CPU: rv64imafdcsu
> Model: SiFive HiFive Unleashed A00
> DRAM: 2 GiB
> MMC:
> Loading Environment from SPIFlash... SF: Detected mx66u51235f with page
> size 256 Bytes, erase size 4 KiB, total 64 MiB
> *** Warning - bad CRC, using default environment
>
> In: serial@10010000
> Out: serial@10010000
> Err: serial@10010000
> Net: failed to get gemgxl_reset reset
>
> Warning: ethernet@10090000 MAC addresses don't match:
> Address in DT is 52:54:00:12:34:56
> Address in environment is 70:b3:d5:92:f0:01
> eth0: ethernet@10090000
> Hit any key to stop autoboot: 0
> => sf probe
> SF: Detected mx66u51235f with page size 256 Bytes, erase size 4 KiB, total
> 64 MiB
> => sf test 0 8000
> SPI flash test:
> 0 erase: 1 ticks, 32000 KiB/s 256.000 Mbps
> 1 check: 80 ticks, 400 KiB/s 3.200 Mbps
> 2 write: 83 ticks, 385 KiB/s 3.080 Mbps
> 3 read: 79 ticks, 405 KiB/s 3.240 Mbps
> Test passed
> 0 erase: 1 ticks, 32000 KiB/s 256.000 Mbps
> 1 check: 80 ticks, 400 KiB/s 3.200 Mbps
> 2 write: 83 ticks, 385 KiB/s 3.080 Mbps
> 3 read: 79 ticks, 405 KiB/s 3.240 Mbps
>
> I am sure there will be bugs, and I have not tested all flashes affected.
> But I want to send out this series for an early discussion and comments.
> I will continue my testing.
>
>
> Bin Meng (9):
> hw/block: m25p80: Fix the number of dummy bytes needed for Windbond
> flashes
> hw/block: m25p80: Fix the number of dummy bytes needed for
> Numonyx/Micron flashes
> hw/block: m25p80: Fix the number of dummy bytes needed for Macronix
> flashes
> hw/block: m25p80: Fix the number of dummy bytes needed for Spansion
> flashes
> hw/block: m25p80: Support fast read for SST flashes
> hw/ssi: xilinx_spips: Fix generic fifo dummy cycle handling
> Revert "aspeed/smc: Fix number of dummy cycles for FAST_READ_4
> command"
> Revert "aspeed/smc: snoop SPI transfers to fake dummy cycles"
> hw/ssi: npcm7xx_fiu: Correct the dummy cycle emulation logic
>
> include/hw/ssi/aspeed_smc.h | 3 -
> hw/block/m25p80.c | 153 ++++++++++++++++++++++++++++--------
> hw/ssi/aspeed_smc.c | 116 +--------------------------
> hw/ssi/npcm7xx_fiu.c | 8 +-
> hw/ssi/xilinx_spips.c | 29 ++++++-
> 5 files changed, 153 insertions(+), 156 deletions(-)
>
> --
> 2.25.1
>
- [PATCH 3/9] hw/block: m25p80: Fix the number of dummy bytes needed for Macronix flashes, (continued)
- [PATCH 3/9] hw/block: m25p80: Fix the number of dummy bytes needed for Macronix flashes, Bin Meng, 2021/01/14
- [PATCH 4/9] hw/block: m25p80: Fix the number of dummy bytes needed for Spansion flashes, Bin Meng, 2021/01/14
- [PATCH 5/9] hw/block: m25p80: Support fast read for SST flashes, Bin Meng, 2021/01/14
- [PATCH 6/9] hw/ssi: xilinx_spips: Fix generic fifo dummy cycle handling, Bin Meng, 2021/01/14
- [PATCH 7/9] Revert "aspeed/smc: Fix number of dummy cycles for FAST_READ_4 command", Bin Meng, 2021/01/14
- [PATCH 8/9] Revert "aspeed/smc: snoop SPI transfers to fake dummy cycles", Bin Meng, 2021/01/14
- [PATCH 9/9] hw/ssi: npcm7xx_fiu: Correct the dummy cycle emulation logic, Bin Meng, 2021/01/14
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Cédric Le Goater, 2021/01/14
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, no-reply, 2021/01/14
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands,
Francisco Iglesias <=
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Bin Meng, 2021/01/14
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Francisco Iglesias, 2021/01/15
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Bin Meng, 2021/01/15
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Francisco Iglesias, 2021/01/18
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Bin Meng, 2021/01/18
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Francisco Iglesias, 2021/01/19
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Bin Meng, 2021/01/20
- Re: [PATCH 0/9] hw/block: m25p80: Fix the mess of dummy bytes needed for fast read commands, Francisco Iglesias, 2021/01/21