diff options
author | Flavio Cruz <flaviocruz@gmail.com> | 2024-02-25 01:46:38 -0500 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2024-02-28 13:21:54 +0100 |
commit | ed1ca4b8c1db9b6578eab3ff8807bb1a174aaccc (patch) | |
tree | e42426702e2cc652135dd6446fd78aea33bb20cc /kern/task.c | |
parent | e5872f2d6a0129dfc4a564b8af8a0f45dcdce86c (diff) | |
download | gnumach-ed1ca4b8c1db9b6578eab3ff8807bb1a174aaccc.tar.gz gnumach-ed1ca4b8c1db9b6578eab3ff8807bb1a174aaccc.tar.bz2 gnumach-ed1ca4b8c1db9b6578eab3ff8807bb1a174aaccc.zip |
Check for null ports in task_set_essential, task_set_name and thread_set_name.
Otherwise, it is easy to crash the kernel if userland passes arbitrary port
names.
Message-ID: <ZdriTgNhPsfu7c2M@jupiter.tail36e24.ts.net>
Diffstat (limited to 'kern/task.c')
-rw-r--r-- | kern/task.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/kern/task.c b/kern/task.c index 60ab4d73..dfba04d4 100644 --- a/kern/task.c +++ b/kern/task.c @@ -1165,6 +1165,9 @@ task_set_name( task_t task, const_kernel_debug_name_t name) { + if (task == TASK_NULL) + return KERN_INVALID_ARGUMENT; + strncpy(task->name, name, sizeof task->name - 1); task->name[sizeof task->name - 1] = '\0'; return KERN_SUCCESS; @@ -1181,6 +1184,9 @@ task_set_essential( task_t task, boolean_t essential) { + if (task == TASK_NULL) + return KERN_INVALID_ARGUMENT; + task->essential = !!essential; return KERN_SUCCESS; } |