!937 添加MAX_OPEN_DIRS宏,标识最大可打开dir数量

Merge pull request !937 from Hongjin Li/max_open_dirs
This commit is contained in:
openharmony_ci 2022-11-29 11:38:36 +00:00 committed by Gitee
commit 68b8deea89
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
2 changed files with 15 additions and 0 deletions

View File

@ -88,4 +88,9 @@
#define MAX_DIRENT_NUM 14 // 14 means 4096 length buffer can store 14 dirent, see struct DIR
/* max number of open directories */
#ifndef LOSCFG_MAX_OPEN_DIRS
#define LOSCFG_MAX_OPEN_DIRS 10
#endif
#endif

View File

@ -94,6 +94,7 @@ int PollQueryFd(int fd, struct PollTable *table)
#define IOV_MAX_CNT 4
UINT32 g_fsMutex;
static UINT32 g_dirNum = 0;
int VfsLock(void)
{
@ -666,6 +667,13 @@ static DIR *VfsOpendir(const char *path)
return NULL;
}
if (g_dirNum >= LOSCFG_MAX_OPEN_DIRS) {
VFS_ERRNO_SET(ENFILE);
VfsUnlock();
free(dir);
return NULL;
}
mp = VfsMpFind(path, &pathInMp);
if ((mp == NULL) || (pathInMp == NULL)) {
VFS_ERRNO_SET(ENOENT);
@ -687,6 +695,7 @@ static DIR *VfsOpendir(const char *path)
ret = (UINT32)mp->mFs->fsFops->opendir(dir, pathInMp);
if (ret == 0) {
mp->mRefs++;
g_dirNum++;
} else {
LOSCFG_FS_FREE_HOOK(dir);
dir = NULL;
@ -752,6 +761,7 @@ static int VfsClosedir(DIR *d)
if (ret == 0) {
mp->mRefs--;
g_dirNum--;
} else {
VFS_ERRNO_SET(EBADF);
}