-
Notifications
You must be signed in to change notification settings - Fork 20
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
Add ondie and software ECC code to SPI NAND block device driver #258
Conversation
Hi! Thank you for the contribution! I do have some questions which I mentioned on the PR from ARMmbed/mbed-os.
|
Hi, as this PR seems inactive I am going to close it for now. If you find time to answer the above questions then please do reopen this PR and we will review. |
Hi, please reopen this PR. @multiplemonomials
|
Hi @daniel-0723, after consideration I decided to move the entire SPI NAND block device to a library outside of the Mbed source tree. Repo has been created here: https://github.com/mbed-ce-libraries-examples/MacronixFlash and I have invited you for full access, so you can update this driver as needed and add other collaborators. Regarding the SPINAND driver, I would like to ask, which devices does it support? After a bit of research, it seems like it supports MX31 and MX35 QSPI NAND flashes, but not NAND flashes from other companies. Is that correct? If not, could you update the README of that repo to indicate what devices it does support? Thank you for submitting this code, I'm sure that people will find it super useful! |
Hi @multiplemonomials, Mbed has merged the SPINANDBlockDevice driver which we submitted in 2021. Also, we submitted similar PR in Zephyr.
This driver is compatible for Generic SPI NAND Flash not only for Macronix parts. |
Yeah but, ARM Mbed and Mbed CE have a bit different criteria for what can & can't be merged. If we were to merge this into Mbed CE, us Mbed maintainers would be on the hook to support it. I don't want to commit to that if we don't have to as our resources are quite limited (as in, we don't have a supported NAND flash to test with!). Which is why I think the best solution is an officially endorsed but 3rd party library, able to be updated by you guys at will. This way, people can easily use your driver, but it's clear that it's maintained separately from Mbed. Also, I did read through the driver a bit. It looks like, to read the ONFI table, it uses a Macronix specific sequence rather than the sequence in the ONFI standard. That's why I came to the conclusion that it's Macronix only. |
Hi @multiplemonomials, if you don't have SPI NAND Flash to test with, we can provide you some custom testing boards whose orignal Flash is replaced with our Macronix SPI NAND Flash such as STM32L562QE-DK. Also, we are interested in participating Mbed-CE Flash driver maintaince. We can assit your Flash driver testing and provide testing data since you don't have enough resources to maintain it. As for the ONFI table, that's a parameter page in Flash to provide Flash information for user. |
Summary of changes
Add ondie and software ECC code to SPI NAND block device driver for using ondie ECC function of SPI NAND Flash like Macronix Flash MX31LF4GE4BC or external ECC.
And the BCH implementation for software ECC is created by Macronix.
Impact of changes
Migration actions required
Documentation
Pull request type
Test results
This driver is tested on DISCO_L4R9I. The flash on this board is MX31LF4GE4BC. You need to replace it with MX31LF4GE4BC.
mbedgt: test case summary: 19 passes, 0 failures
mbedgt: all tests finished!
mbedgt: shuffle seed: 0.2715403632
mbedgt: test suite report:
his driver is tested on DISCO_L4R9I. The flash on this board is MX31LF4GE4BC. You need to replace it with MX31LF4GE4BC.
mbedgt: test case summary: 19 passes, 0 failures
mbedgt: all tests finished!
mbedgt: shuffle seed: 0.2715403632
mbedgt: test suite report: