diff options
author | dzwdz | 2022-12-27 22:37:25 +0100 |
---|---|---|
committer | dzwdz | 2022-12-27 22:37:25 +0100 |
commit | 35a82cb0dae43eb538de7afa1da77c4e249ba4e4 (patch) | |
tree | 32df01e99d293d045fc8bd1ad4312753c5c94290 /src/user/lib/elfload.c | |
parent | a54c80d07bbaa8cb34dd5924d0926ac47e7deded (diff) |
libc/elfload: don't override cwd
Diffstat (limited to 'src/user/lib/elfload.c')
-rw-r--r-- | src/user/lib/elfload.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/src/user/lib/elfload.c b/src/user/lib/elfload.c index 6dab8ae..7cad10f 100644 --- a/src/user/lib/elfload.c +++ b/src/user/lib/elfload.c @@ -78,9 +78,13 @@ static const char *default_argv[] = {NULL}; void _freejmp_chstack(void *entry, void *low, size_t len, const char **argv, char **envp, void *stack); // elfload.s _Noreturn void execbuf_chstack(void *stack, void __user *buf, size_t len); void _freejmp(void *entry, void *low, size_t imglen, const char **argv, char **envp) { + // TODO error checking + // although i guess it's fine for it to crash + // also TODO just alloc a new stack void *stack = (void*)~0; struct execdata ed; size_t argv_len; + size_t cwd_len = absolutepath(NULL, NULL, 0); if (!argv) argv = default_argv; @@ -91,8 +95,11 @@ void _freejmp(void *entry, void *low, size_t imglen, const char **argv, char **e /* make a copy of argv, so it doesn't get overridden * if it overlaps with the new stack. */ argv = memdup(argv, argv_len); - for (int i = 0; i < ed.argc; i++) + for (int i = 0; i < ed.argc; i++) { argv[i] = strdup(argv[i]); + } + ed.cwd = malloc(cwd_len); + getcwd(ed.cwd, cwd_len); stack -= argv_len; ed.argv = stack; @@ -106,9 +113,8 @@ void _freejmp(void *entry, void *low, size_t imglen, const char **argv, char **e ed.argv[ed.argc] = NULL; /* push cwd */ - size_t len = absolutepath(NULL, NULL, 0); - stack -= len; - getcwd(stack, len); + stack -= cwd_len; + memcpy(stack, ed.cwd, cwd_len); ed.cwd = stack; stack -= sizeof ed; |