OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5113|回复: 11

FAT文件系统,根目录下支持最大目录(文件)个数

[复制链接]

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
发表于 2017-3-3 14:02:48 | 显示全部楼层 |阅读模式
1金钱
最近在测试fatfs的时候;发现一个问题,我用的SPI flash,mount,read,write 都没有问题;
可是发现在根目录下,创建了254个文件后,再创建255个文件的时候,会失败;
跟踪代码发现是在dir alloc的时候失败;
static
FRESULT dir_alloc (
        DIR* dp,        /* Pointer to the directory object */
        UINT nent        /* Number of contiguous entries to allocate (1-21) */
)
{
        FRESULT res;
        UINT n;


        res = dir_sdi(dp, 0);
        if (res == FR_OK) {
                n = 0;
                do {
                        res = move_window(dp->fs, dp->sect);
                        if (res != FR_OK) break;
                        if (dp->dir[0] == DDEM || dp->dir[0] == 0) {        /* Is it a free entry? */
                                if (++n == nent) break;        /* A block of contiguous free entries is found */
                        } else {
                                n = 0;                                        /* Not a blank entry. Restart to search */
                        }
                        res = dir_next(dp, 1);                /* Next entry with table stretch enabled */
                } while (res == FR_OK);
        }
// 这里res返回 FR_NO_FILE;
        if (res == FR_NO_FILE) res = FR_DENIED;        /* No directory entry to allocate */
        return res;
}

进一步跟踪 dir_next里面的返回值;
                        if (i >= dp->fs->n_rootdir)        /* Report EOT if it reached end of static table */
                                return FR_NO_FILE;

是因为如上i为512 等于了n_rootdir的值;
n_rootdir的值是在mkfs的时候就初始化为512了;所以应该没有问题;
再跟踪下原因;
确认硬件信息;配置一个 page 4069,一个sector 4069;一共1000个;
这个时候,研究了fatfs的原理;
sector 第65~68 4个sector存放DIR的信息;每一个sector 存放128个dir信息;4069/32;这样4个sector可以存放512个dir信息;
程序跟踪调试;
当dir alloc的时候,会去扫描dir的信息,
if (dp->dir[0] == DDEM || dp->dir[0] == 0) 当dir删除或者dir未使用的时候,才可以被分配;
而我发现实际的一个文件,却被分配了2个dir信息;
一个为文件名;xxx;
而另外一个dir信息是一个A1开头的内容;
请问这是什么原因呢?这个A1开头的内容是什么呢?
请问有人研究过么?

最佳答案

查看完整内容[请看2#楼]

应该就在这几个文件里了,想看的话,可以下载下来看一下
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11547
金钱
11547
注册时间
2013-3-8
在线时间
1232 小时
发表于 2017-3-3 14:02:49 | 显示全部楼层
tt朝花夕拾 发表于 2017-3-3 14:41
多谢,我记得也是有,可是没有找到相关的介绍;

FAT32简单教材.pdf (2.77 MB, 下载次数: 155)
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11547
金钱
11547
注册时间
2013-3-8
在线时间
1232 小时
发表于 2017-3-3 14:29:53 | 显示全部楼层
你看一下FAT32的原理吧。我记得早期的FAT32一个文件夹中最多支持255个文件。文件创建时会有一个备份,以防文件损坏。具体的时间久了,不记得了。
回复

使用道具 举报

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
 楼主| 发表于 2017-3-3 14:41:26 | 显示全部楼层
augustedward 发表于 2017-3-3 14:29
你看一下FAT32的原理吧。我记得早期的FAT32一个文件夹中最多支持255个文件。文件创建时会有一个备份,以防 ...

多谢,我记得也是有,可是没有找到相关的介绍;
回复

使用道具 举报

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
 楼主| 发表于 2017-3-6 14:32:38 | 显示全部楼层
augustedward 发表于 2017-3-3 14:02
应该就在这几个文件里了,想看的话,可以下载下来看一下

感谢,感谢,你给的文档非常有用;在里面找到了答案;太感谢了;
回复

使用道具 举报

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
 楼主| 发表于 2017-3-6 15:27:24 | 显示全部楼层
我在这里简单总结下这个问题,今天看了@augustedward 的文档,里面的内容非常的好,也找到了想要的东西;
其实发现根本原因是开启了LFN,long file name 的功能,我的工程里配置了3;
在每次创建一个文件的时候,都会同步生成了一个32byte的,0xb位置上为0xf标志的目录项,此标志为长文件名标志;
所以,512个根目录数,只能创建254个,因为不可能创建255个到512的数目,
配置根目录数量为512;一个目录size为32byte,我的一个sector为4k,则一个sector可以存放128个目录项,需要4个sector;
我将一个sector跟踪读取出来,并解析了其中的2个32byte目录项,才真正看到这个存储过程;我简单分享出来供大家讨论;

存储的文件为,4_Fix.refC:\Users\TANQ\Desktop\file.png
上面为长文件名的目录项,可以查表看到是A40_0F0i0x0.0r0e0f;
其中0x0b的位置为0xf,表示是长文件类型,
下面的为短文件名目录项,常规的文件目录存放,存放了一些文件名,类型,时间,日期,簇地址,文件大小等;
文件名为4_FIX  0x20  REF ,0x0b位置上位0x20,表示存档信息,时间信息,在0x1a的簇数,4byte大小;
回复

使用道具 举报

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
 楼主| 发表于 2017-3-6 15:27:50 | 显示全部楼层
本帖最后由 tt朝花夕拾 于 2017-3-6 15:32 编辑

我在这里简单总结下这个问题,今天看了@augustedward 的文档,里面的内容非常的好,也找到了想要的东西;
其实发现根本原因是开启了LFN,long file name 的功能,我的工程里配置了3;
在每次创建一个文件的时候,都会同步生成了一个32byte的,0xb位置上为0xf标志的目录项,此标志为长文件名标志;
所以,512个根目录数,只能创建254个,因为不可能创建255个到512的数目,
配置根目录数量为512;一个目录size为32byte,我的一个sector为4k,则一个sector可以存放128个目录项,需要4个sector;
我将一个sector跟踪读取出来,并解析了其中的2个32byte目录项,才真正看到这个存储过程;我简单分享出来供大家讨论;

存储的文件为,
上面为长文件名的目录项,可以查表看到是A40_0F0i0x0.0r0e0f;
其中0x0b的位置为0xf,表示是长文件类型,
下面的为短文件名目录项,常规的文件目录存放,存放了一些文件名,类型,时间,日期,簇地址,文件大小等;
文件名为4_FIX  0x20  REF ,0x0b位置上位0x20,表示存档信息,时间信息,在0x1a的簇数,4byte大小;
file.png
回复

使用道具 举报

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
 楼主| 发表于 2017-3-6 15:28:52 | 显示全部楼层
直接贴上解析的flash目录信息吧;
ADDR        0x00        0x01        0x02        0x03        0x04        0x05        0x06        0x07        0x08        0x09        0x0a        0x0b        0x0c        0x0d        0x0e        0x0f
DATA        41        34        0        5f        0        46        0        69        0        78        0        f        0        39        2e        0
ADDR        0x10        0x11        0x12        0x13        0x14        0x15        0x16        0x17        0x18        0x19        0x1a        0x1b        0x1c        0x1d        0x1e        0x1f
DATA        72        0        65        0        66        0        0        0        ff        ff        0        0        ff        ff        ff        ff
ADDR        0x20        0x21        0x22        0x23        0x24        0x25        0x26        0x27        0x28        0x29        0x2a        0x2b        0x2c        0x2d        0x2e        0x2f
DATA        34        5f        46        49        58        20        20        20        52        45        46        20        0        32        b2        5c
ADDR        0x30        0x31        0x32        0x33        0x34        0x35        0x36        0x37        0x38        0x39        0x3a        0x3b        0x3c        0x3d        0x3e        0x3f
DATA        66        4a        66        4a        0        0        18        8        21        48        1a        0        4        0        0        0
回复

使用道具 举报

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
 楼主| 发表于 2017-3-6 16:26:09 | 显示全部楼层
附上用winhex打开flash mount到pc上的情况;打开rootdir的信息;
QQ截图20170306162457.png
回复

使用道具 举报

9

主题

1385

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
11547
金钱
11547
注册时间
2013-3-8
在线时间
1232 小时
发表于 2017-3-6 16:55:26 | 显示全部楼层
tt朝花夕拾 发表于 2017-3-6 15:27
我在这里简单总结下这个问题,今天看了@augustedward 的文档,里面的内容非常的好,也找到了想要的东西;
...

讲的很好,我也是两年前做这方面内容时看过,现在都忘的差不多了
回复

使用道具 举报

4

主题

57

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1760
金钱
1760
注册时间
2017-6-23
在线时间
172 小时
发表于 2017-7-12 17:23:33 | 显示全部楼层
楼主用心了,学习学习
回复

使用道具 举报

10

主题

98

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
319
金钱
319
注册时间
2017-1-20
在线时间
51 小时
 楼主| 发表于 2017-7-13 17:29:04 | 显示全部楼层
肩上的月光 发表于 2017-7-12 17:23
楼主用心了,学习学习

共同学习进步;
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-12-18 16:25

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表