STM32 HAL库 U盘打开FATFS文件异常的问题
由于公司里面不允许使用手机,汇报的时候写ppt拍照非常麻烦,想着干脆就自己做一个小的拍照机,拍了照通过FAFTS文件系统储存在flash里面,通过usb作为u盘上传到电脑上面。 说干就干,使用的是stm32f407,这几天把DICM和LCD调通了,就准备移植USB和FATFTS代码。 USB和FATFS顺利移植成功了,但是最后想看下效果的时候发现,我在拍了照储存的bmp文件电脑上面打不开,显示如下: 简单来说就是说找不到这个文件了。但是我u盘里面是有这个文件的。只是打不开。 但是,更加扯淡的是,我用的flash的sector是4096byte,只要我的文件不超过4k,就能正常打开,超过4k就不行。 我最开始怀疑是底层读写函数可能哪里写错了。但是很奇怪的是,我用电脑上面考文件进到u盘就OK,也能正常打开(超过4k的),并且我stm32内部写文件也能正常打开,也就是说,电脑访问电脑搞进去的文件是正常的,我自己访问我自己储存的文件也是能够正常读取的。 一筹莫展,于是我想到了既然我不超过4k的文件能打开,但是i超过就打不开,那很可能是我FAFTS的储存链表哪里有问题,于是我就用winhex查我flash 里面的储存链表,这个是根目录的截图, 第一次接触链表,把我看得够呛,但是无论我怎么看,链表的文件都是正常的,关键是winhex是能够打开这写文件的。也就是说我用u盘打不开,但是winhex是能打开的,(我的测试文件是txt文件)这就让我更奇怪了,难道是我的usb通讯的时候有些数据不对? 于是我开始调试看每次返回的数据是否正常,不出意外都是正常的。 于是我继续开始看这个fat表 并且我就一个一个开始对。因为我用的是fat16,里面16位代表的是一个簇。我就开始一个一个对比,发现不对,不i管怎么样都对不上,本来实际数据是第2簇和第三簇是一起的,但是从fat表上面显示第二簇到后面几千簇去了。但是我电脑依然能够识别??? 这个时候我就有点怀疑是不是我的文件系统是不是哪里和我芯片里面的对不上。因为我这个flash文件系统是直接在电脑上面格式化的,电脑没有选择fat12,还是fat16还是fat32,直接自动就格式化了。 于是我就自己在芯片内部初始化的时候重新初始化一下这个文件系统,然后重新连接。。。。就可以查看了。 也就是说是我电脑刷的文件系统和我芯片里面的文件系统不匹配,应该是我芯片是fat16的,但是电脑刷的是fat12的,就导致两者独立的话都能识别自己的文件,但是相互交叉就不行了。主要原因就是链表上面fat16是两个字节,但是fat12是1各半字节。。。。。 就这个问题,搞了我2天TAT。还好总算是解决了
|