From 32ab151712acfe8374df629c7eccf737267361cd Mon Sep 17 00:00:00 2001 From: chao an Date: Tue, 10 Dec 2024 20:56:40 +0800 Subject: [PATCH] libc/chdir: chdir/fchdir should not depend on environment variables This PR will still allow basic shell operations such as cd/ls/pwd to be used even when the environment is disabled. Signed-off-by: chao an --- libs/libc/unistd/CMakeLists.txt | 6 ++++-- libs/libc/unistd/Make.defs | 3 ++- libs/libc/unistd/lib_chdir.c | 11 +++++++---- libs/libc/unistd/lib_fchdir.c | 4 ---- 4 files changed, 13 insertions(+), 11 deletions(-) diff --git a/libs/libc/unistd/CMakeLists.txt b/libs/libc/unistd/CMakeLists.txt index f65c2fbe6f..77662136b8 100644 --- a/libs/libc/unistd/CMakeLists.txt +++ b/libs/libc/unistd/CMakeLists.txt @@ -66,7 +66,9 @@ set(SRCS lib_getpgid.c lib_lockf.c lib_flock.c - lib_getpass.c) + lib_getpass.c + lib_chdir.c + lib_fchdir.c) if(NOT CONFIG_SCHED_USER_IDENTITY) list( @@ -83,7 +85,7 @@ if(NOT CONFIG_SCHED_USER_IDENTITY) endif() if(NOT CONFIG_DISABLE_ENVIRON) - list(APPEND SRCS lib_chdir.c lib_fchdir.c lib_restoredir.c) + list(APPEND SRCS lib_restoredir.c) endif() if(CONFIG_LIBC_EXECFUNCS) diff --git a/libs/libc/unistd/Make.defs b/libs/libc/unistd/Make.defs index 329ac81c37..2e11aef1ea 100644 --- a/libs/libc/unistd/Make.defs +++ b/libs/libc/unistd/Make.defs @@ -33,6 +33,7 @@ CSRCS += lib_futimes.c lib_lutimes.c lib_gethostname.c lib_sethostname.c CSRCS += lib_fchownat.c lib_linkat.c lib_readlinkat.c lib_symlinkat.c CSRCS += lib_unlinkat.c lib_usleep.c lib_getpgrp.c lib_getpgid.c CSRCS += lib_lockf.c lib_flock.c lib_getpass.c +CSRCS += lib_chdir.c lib_fchdir.c ifneq ($(CONFIG_SCHED_USER_IDENTITY),y) CSRCS += lib_setuid.c lib_setgid.c lib_getuid.c lib_getgid.c @@ -40,7 +41,7 @@ CSRCS += lib_seteuid.c lib_setegid.c lib_geteuid.c lib_getegid.c endif ifneq ($(CONFIG_DISABLE_ENVIRON),y) -CSRCS += lib_chdir.c lib_fchdir.c lib_restoredir.c +CSRCS += lib_restoredir.c endif ifeq ($(CONFIG_LIBC_EXECFUNCS),y) diff --git a/libs/libc/unistd/lib_chdir.c b/libs/libc/unistd/lib_chdir.c index 025def3bd0..dd14d5b345 100644 --- a/libs/libc/unistd/lib_chdir.c +++ b/libs/libc/unistd/lib_chdir.c @@ -33,8 +33,6 @@ #include "libc.h" -#ifndef CONFIG_DISABLE_ENVIRON - /**************************************************************************** * Public Functions ****************************************************************************/ @@ -74,9 +72,11 @@ int chdir(FAR const char *path) { - struct stat buf; +#ifndef CONFIG_DISABLE_ENVIRON FAR char *oldpwd; +#endif /* !CONFIG_DISABLE_ENVIRON */ FAR char *abspath; + struct stat buf; int ret; /* Verify that 'path' refers to a directory */ @@ -105,6 +105,8 @@ int chdir(FAR const char *path) return ERROR; } +#ifndef CONFIG_DISABLE_ENVIRON + /* Replace any preceding OLDPWD with the current PWD (this is to * support 'cd -' in NSH) */ @@ -120,8 +122,9 @@ int chdir(FAR const char *path) /* Set the cwd to the input 'path' */ ret = setenv("PWD", abspath, TRUE); +#endif /* !CONFIG_DISABLE_ENVIRON */ + lib_free(abspath); return ret; } -#endif /* !CONFIG_DISABLE_ENVIRON */ diff --git a/libs/libc/unistd/lib_fchdir.c b/libs/libc/unistd/lib_fchdir.c index 06cd1aaa74..c49d361571 100644 --- a/libs/libc/unistd/lib_fchdir.c +++ b/libs/libc/unistd/lib_fchdir.c @@ -32,8 +32,6 @@ #include #include -#ifndef CONFIG_DISABLE_ENVIRON - /**************************************************************************** * Private Functions ****************************************************************************/ @@ -89,5 +87,3 @@ int fchdir(int fd) lib_put_pathbuffer(path); return ret; } - -#endif /* !CONFIG_DISABLE_ENVIRON */