最近在测试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开头的内容是什么呢?
请问有人研究过么?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
多谢,我记得也是有,可是没有找到相关的介绍;
我在这里简单总结下这个问题,今天看了@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大小;
一周热门 更多>