Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clock Speed Requirements #73

Closed
willeccles opened this issue Aug 4, 2023 · 8 comments
Closed

Clock Speed Requirements #73

willeccles opened this issue Aug 4, 2023 · 8 comments

Comments

@willeccles
Copy link

Apologies if I missed anything in the README, I sometimes skim things a little too vigorously.

I'm looking to use this in an application where the system clock frequency is 48MHz. Are there any issues with either SPI or SDIO at this frequency? I can use either of the above in this application, with SDIO's speed being preferable (the application involves high-speed data acquisition). Will the SDIO version work with a 48MHz system clock?

@carlk3
Copy link
Owner

carlk3 commented Aug 4, 2023

For SPI, you can set the SPI baud rate in the hardware configuration. This library uses the SDK call spi_set_baudrate which uses the SDK's clock_get_hz to get the current frequency of the peripheral clock for UART and SPI (see src\rp2_common\hardware_spi\spi.c in the pico-sdk). I'd have to look in the Datasheet to see what sets the peripheral clock's frequency. But, anyway, you could always scale the baud rate in the H/W config. if necessary.

For SDIO, it's on my list of things to do to make the SDIO clock rate configurable in the H/W config. It is currently hard coded in sd_sdio_begin in sd_driver\SDIO\sd_card_sdio.c.

    // Increase to 25 MHz clock rate
    // Actually, clk_sys / CLKDIV (from rp2040_sdio.pio),
    // So, say, 125 MHz / 4 = 31.25 MHz (see src\sd_driver\SDIO\rp2040_sdio.pio)
    // rp2040_sdio_init(sd_card_p, 1, 0); // 31.25 MHz
    rp2040_sdio_init(sd_card_p, 1, 128); // 20.8 MHz

so you would have to modify that directly. When I get around to making it configurable in the H/W config., I should use a scheme like that used in spi_set_baudrate and take the clk_sys into account.

There isn't a lot of computation going on, but it's possible that a slower system clock will slow down something to the point that you might see problems. The only thing that comes to mind is the verification of the CRCs. (For example, see sdio_verify_rx_checksums in rp2040_sdio.c). I got a great suggestion for how to do that in hardware ( #63 ), but that's another thing on the to do list.

@willeccles
Copy link
Author

Thanks for the info! I will look into this. Modifying it is certainly not an issue.

@carlk3
Copy link
Owner

carlk3 commented Sep 6, 2023

I have verified that it works reliably at system clock frequency is 48MHz and SDIO baud rate 5 MHz.

@willeccles
Copy link
Author

Awesome, thank you! Does 10MHz work? I see you noted it can't be greater than 1/4 of the system clock. Either should work for my purposes, though.

@carlk3
Copy link
Owner

carlk3 commented Sep 6, 2023

Awesome, thank you! Does 10MHz work?

Setting the system clock to 10000 kHz is "not possible" according to check_sys_clock_khz.

I see you noted it can't be greater than 1/4 of the system clock. Either should work for my purposes, though.

48 MHz system clock with 10 MHz baud rate works fine:

> set_sys_clock_48mhz

> mount 3:

> bench 3:
Type is FAT32
Card size: 31.95 GB (GB = 1E9 bytes)

Manufacturer ID: 0x0
OEM ID:
Product: USD
Revision: 1.0
Serial number: 0x302c
Manufacturing date: 8/2022

FILE_SIZE_MB = 5
BUF_SIZE = 20480
Starting write test, please wait.

write speed and latency
speed,max,min,avg
KB/Sec,usec,usec,usec
3196.9,13015,5826,6384
3226.4,11195,5811,6335

Starting read test, please wait.

read speed and latency
speed,max,min,avg
KB/Sec,usec,usec,usec
4045.4,6709,4659,5061
4051.7,6310,4638,5054

Done

> big_file_test bf 10 1
Writing...
Elapsed seconds 7.14
Transfer rate 1434 KiB/s (1468 kB/s) (11745 kb/s)
Reading...
Elapsed seconds 6.57
Transfer rate 1558 KiB/s (1596 kB/s) (12767 kb/s)

@carlk3
Copy link
Owner

carlk3 commented Sep 6, 2023

Really, you might as well got to 12 MHz baud rate:

> set_sys_clock_48mhz

> mount 3:

> bench 3:
Type is FAT32
Card size: 31.95 GB (GB = 1E9 bytes)

Manufacturer ID: 0x0
OEM ID:
Product: USD
Revision: 1.0
Serial number: 0x302c
Manufacturing date: 8/2022

FILE_SIZE_MB = 5
BUF_SIZE = 20480
Starting write test, please wait.

write speed and latency
speed,max,min,avg
KB/Sec,usec,usec,usec
3581.2,12436,5156,5693
3576.3,16683,5132,5710

Starting read test, please wait.

read speed and latency
speed,max,min,avg
KB/Sec,usec,usec,usec
4697.9,6140,3915,4356
4702.1,5790,3920,4353

Done

> big_file_test 3:bf 10 1
Writing...
Elapsed seconds 7.17
Transfer rate 1428 KiB/s (1462 kB/s) (11694 kb/s)
Reading...
Elapsed seconds 6.23
Transfer rate 1644 KiB/s (1683 kB/s) (13467 kb/s)

@willeccles
Copy link
Author

Setting the system clock to 10000 kHz is "not possible" according to check_sys_clock_khz.

Sorry, should have been more specific--I meant 10MHz baud rate. It sounds like 12 works just fine, and the faster the better, so that will work for me!

@willeccles
Copy link
Author

Closing as you've answered my question and implemented a convenient solution. Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants