-
Notifications
You must be signed in to change notification settings - Fork 54
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
Cannot create directories with lfn
feature.
#64
Comments
In which version of the crate you encountered this problem? Is it embedded environment? There are tests that create directories and |
Master branch of this repo.
Yes, on STM32L4 with the implementation I am working on (stm32-rs/stm32l4xx-hal#315), so possibly there is a bug in my implementation. With SFN, everything is working fine though. With LFN, it works sometimes, but most of the time it just creates a file instead of a directory. I first assumed it was due to reading/writing from an SD card being too slow, since I also encountered spurious timeouts. I have since implemented reading/writing using DMA and the timeouts are gone but I am still unable to create directories. |
I am also getting the following debug output when listing the root directory contents:
Is this expected when reaching the directory iterator end? |
No, I don't think it is normal. It most likely means that your filesystem got corrupted. |
Okay, I will have to investigate a bit more and try with a freshly formatted SD card to make sure the filesystem is not corrupted. |
Okay, I have now found the reason for this behaviour. I am mounting the SD card on my computer (macOS) via an STM32 running an application making it a USB MSC device. When I then reset the board (i.e. by rebuilding the application and restarting the debugger), the SD card is not properly ejected. On the next run, files are created instead of directories. If I then delete these files and eject the SD card properly before resetting the board again, the directories are created successfully on the subsequent run. Not sure how to debug this further. Maybe creating images of the SD card after ejecting it improperly and properly, respectively? |
Okay, I managed to create images of the SD card in both the working and broken states. After some investigation I finally found the culprit: The FAT dirty flag is set. If it is cleared before mounting the card again on my computer, the directories are created as expected. |
I don't think I fully understand. You are mounting a fat filesystem on your STM32 filesystem using this crate, then reset the board, then mount again (it should be mounting a dirty filesystem), then you create some directories, unmount, and then when mounting on Windows OS it see directories as files? I am still interested to see what is the reason. Dirty flag alone should not break anything unless filesystem is in corrupted state but I think it would still be weird to see directories as files, because all directory entry data is written at once (directory attribute and its name). Maybe there is some other issue here... Attached image with a detailed list of steps you performed to get it would be helpful |
Here's step by step how to reproduce it:
When replacing step 2 with a proper unmount, both dirty bits are cleared and everything works as expected. Also, when clearing the dirty bits as part of step 4 (as is made possible with #66), everything works as expected. |
I think it'd be easier if you created a disk.img with the filesystem state and a piece of code that reproduced the issue. |
@aruiz, not quite sure it would be easier. I couldn't reproduce it now if I wanted to since I don't have the necessary hardware anymore. Also, there is a an open PR with the solution, including a test which reproduces the state leading to the problem, i.e. step 3 and 4 above. |
I've recently migrated from short file names to LFN, my application is running on an STM32. I'm getting a similar odd behaviour and the directory is seen as a file on macos. |
When using the
lfn
feature, usingDir::create_dir
creates empty files instead of directories.The text was updated successfully, but these errors were encountered: