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

2019-07-20 13:25发布

最近在测试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开头的内容是什么呢?
请问有人研究过么?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
11条回答
tt朝花夕拾
2019-07-21 10:31
本帖最后由 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大小;

一周热门 更多>