summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/user/app/ps/ps.c2
-rw-r--r--src/user/bootstrap/main.c3
-rw-r--r--src/user/lib/_start2.c17
-rw-r--r--src/user/lib/include/_proc.h17
-rw-r--r--src/user/lib/stdlib.c8
5 files changed, 26 insertions, 21 deletions
diff --git a/src/user/app/ps/ps.c b/src/user/app/ps/ps.c
index d2b9ded..76a5841 100644
--- a/src/user/app/ps/ps.c
+++ b/src/user/app/ps/ps.c
@@ -33,7 +33,7 @@ main(void)
warn("couldn't open \"%s\"", procbuf);
strcpy(procbuf, "(can't peek)");
} else {
- fseek(g, (long)_libc_psdata, SEEK_SET);
+ fseek(g, (long)&_psdata_loc->desc, SEEK_SET);
if (fread(procbuf, 1, 128, g) <= 0) {
strcpy(procbuf, "(no psdata)");
}
diff --git a/src/user/bootstrap/main.c b/src/user/bootstrap/main.c
index c12989e..638585c 100644
--- a/src/user/bootstrap/main.c
+++ b/src/user/bootstrap/main.c
@@ -14,9 +14,8 @@ extern char _initrd;
__attribute__((section(".text")))
int main(void) {
- _sys_memflag(_libc_psdata, 1, MEMFLAG_PRESENT);
+ _sys_memflag(_psdata_loc, 1, MEMFLAG_PRESENT);
setprogname("bootstrap");
- setproctitle(NULL);
/* move everything provided by the kernel to /kdev */
MOUNT_AT("/kdev/") { fs_passthru(NULL); }
diff --git a/src/user/lib/_start2.c b/src/user/lib/_start2.c
index f55feab..b4eb76a 100644
--- a/src/user/lib/_start2.c
+++ b/src/user/lib/_start2.c
@@ -26,20 +26,17 @@ _Noreturn void _start2(struct execdata *ed) {
elf_selfreloc();
/* done first so it isn't allocated elsewhere by accident */
- _sys_memflag(_libc_psdata, 1, MEMFLAG_PRESENT);
- if (ed->argv[0]) {
- strcpy(_libc_psdata, ed->argv[0]);
- } else {
- strcpy(_libc_psdata, "?");
- }
+ _sys_memflag(_psdata_loc, 1, MEMFLAG_PRESENT);
+ _psdata_loc->base = __executable_start;
+ /* sets ->desc */
+ progname = shortname(ed->argv[0]);
+ setprogname(progname);
+
+ _klogf("_start2 %s %p", progname, __executable_start);
_sys_intr_set(intr_trampoline);
intr_set(intr_default);
__setinitialcwd(ed->cwd);
- progname = shortname(ed->argv[0]);
- setprogname(progname);
- _klogf("_start2 %s %p", progname, __executable_start);
-
exit(main(ed->argc, ed->argv, ed->envp));
}
diff --git a/src/user/lib/include/_proc.h b/src/user/lib/include/_proc.h
index c8fd70b..5f9c321 100644
--- a/src/user/lib/include/_proc.h
+++ b/src/user/lib/include/_proc.h
@@ -1,7 +1,14 @@
#pragma once
-/* That page contains a null-terminated string that describes the process
- * for tools such as ps. It's first allocated in the bootstrap process, and
- * then it's freed on every exec() - just to be immediately reallocated by
- * _start2(). */
-static char *const _libc_psdata = (void*)0x10000;
+struct _psdata {
+ /* Description of the process, see setprogname.
+ * Assumed to be null terminated. */
+ char desc[1024];
+
+ /* Base offset where the executable was loaded. */
+ void *base;
+};
+
+/* First allocated in bootstrap.
+ * Freed on every exec(), just to be immediately reallocated by _start2(). */
+static struct _psdata *const _psdata_loc = (void*)0x10000;
diff --git a/src/user/lib/stdlib.c b/src/user/lib/stdlib.c
index 13745d1..1739230 100644
--- a/src/user/lib/stdlib.c
+++ b/src/user/lib/stdlib.c
@@ -16,18 +16,20 @@ const char *getprogname(void) {
}
void setprogname(const char *pg) {
progname = pg;
+ setproctitle(NULL);
}
void setproctitle(const char *fmt, ...) {
+ // TODO bounds checking
if (!fmt) {
- strcpy(_libc_psdata, progname);
+ strcpy(_psdata_loc->desc, progname);
return;
}
- sprintf(_libc_psdata, "%s: ", progname);
+ sprintf(_psdata_loc->desc, "%s: ", progname);
va_list argp;
va_start(argp, fmt);
- vsnprintf(_libc_psdata + strlen(_libc_psdata), 128, fmt, argp);
+ vsnprintf(_psdata_loc->desc + strlen(_psdata_loc->desc), 128, fmt, argp);
va_end(argp);
}