提交 a9fc1e0e 编写于 作者: F Far

fix: Liteos-a创建的文件夹在Ubuntu中不可见

Linux的文件夹需要包含"."和".."才会被视为一个有效的目录
通过在新建的文件夹中创建"."和".."目录项修复这个BUG

Close #I3XMY6
Signed-off-by: NFar <yesiyuan2@huawei.com>
上级 8a3d1882
...@@ -251,11 +251,13 @@ static enum VnodeType fatfstype_2_vnodetype(BYTE type) { ...@@ -251,11 +251,13 @@ static enum VnodeType fatfstype_2_vnodetype(BYTE type) {
} }
} }
static FRESULT init_cluster(DIR *dp_new, FATFS *fs, int type, const char *target, DWORD *clust) #define DIR_SIZE 32
static FRESULT init_cluster(DIR_FILE *pdfp, DIR *dp_new, FATFS *fs, int type, const char *target, DWORD *clust)
{ {
FRESULT result; FRESULT result;
BYTE *dir = NULL; BYTE *dir = NULL;
QWORD sect; QWORD sect;
DWORD pclust;
UINT n; UINT n;
/* Allocate a new cluster */ /* Allocate a new cluster */
...@@ -285,23 +287,51 @@ static FRESULT init_cluster(DIR *dp_new, FATFS *fs, int type, const char *target ...@@ -285,23 +287,51 @@ static FRESULT init_cluster(DIR *dp_new, FATFS *fs, int type, const char *target
if (type == AM_LNK && target) { if (type == AM_LNK && target) {
/* Write target to symlink */ /* Write target to symlink */
strcpy_s((char *)dir, SS(fs), target); strcpy_s((char *)dir, SS(fs), target);
} else {
/* Write the dir cluster */
mem_set(dir, 0, SS(fs));
mem_set(dir + DIR_Name, ' ', 11); /* Create "." entry */
dir[DIR_Name] = '.';
dir[DIR_Attr] = AM_DIR;
st_clust(fs, dir, *clust);
mem_cpy(dir + DIR_SIZE, dir, DIR_SIZE); /* Create ".." entry */
dir[DIR_SIZE + 1] = '.'; /* Add extra "." */
pclust = pdfp->fno.sclst;
if (fs->fs_type == FS_FAT32 && pclust == fs->dirbase) {
pclust = 0;
}
st_clust(fs, dir + DIR_SIZE, pclust);
} }
for (n = fs->csize; n > 0; n--) {
#ifndef LOSCFG_FS_FAT_VIRTUAL_PARTITION #ifndef LOSCFG_FS_FAT_VIRTUAL_PARTITION
fs->winsect = sect++; fs->winsect = sect++;
fs->wflag = 1; fs->wflag = 1;
#else #else
PARENTFS(fs)->winsect = sect++; PARENTFS(fs)->winsect = sect++;
PARENTFS(fs)->wflag = 1; PARENTFS(fs)->wflag = 1;
#endif #endif
result = sync_window(fs); result = sync_window(fs);
if (result != FR_OK) { if (result != FR_OK) {
remove_chain(&(dp_new->obj), *clust, 0); remove_chain(&(dp_new->obj), *clust, 0);
return result; return result;
} }
if (type == AM_LNK) {
/* No need to clean the rest sectors of the cluster for symlink */ /* Rest of directory cluster should set to be zero */
break; if (type == AM_DIR) {
mem_set(dir, 0, SS(fs));
for (n = fs->csize - 1; n > 0; n--) {
#ifndef LOSCFG_FS_FAT_VIRTUAL_PARTITION
fs->winsect = sect++;
fs->wflag = 1;
#else
PARENTFS(fs)->winsect = sect++;
PARENTFS(fs)->wflag = 1;
#endif
result = sync_window(fs);
if (result != FR_OK) {
remove_chain(&(dp_new->obj), *clust, 0);
return result;
}
} }
} }
...@@ -366,7 +396,7 @@ static int fatfs_create_obj(struct Vnode *parent, const char *name, int mode, st ...@@ -366,7 +396,7 @@ static int fatfs_create_obj(struct Vnode *parent, const char *name, int mode, st
} }
if (type == AM_DIR || type == AM_LNK) { if (type == AM_DIR || type == AM_LNK) {
result = init_cluster(dp_new, fs, type, target, &clust); result = init_cluster(dfp, dp_new, fs, type, target, &clust);
if (result != FR_OK) { if (result != FR_OK) {
goto ERROR_UNLOCK; goto ERROR_UNLOCK;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册