LibC: open/openat: Make sure path is not a nullptr before dereferencing

open and openat both try to get the length of the path string. When
the path was a nullptr, strlen tried to dereference it, causing a
segfault.
This commit is contained in:
Till Mayer 2019-11-13 20:21:46 +01:00 committed by Andreas Kling
commit 00e56cda0c
Notes: sideshowbarker 2024-07-19 11:14:02 +09:00

View file

@ -202,6 +202,10 @@ int openat_with_path_length(int dirfd, const char* path, size_t path_length, int
int open(const char* path, int options, ...)
{
if (!path) {
errno = EFAULT;
return -1;
}
va_list ap;
va_start(ap, options);
auto mode = (mode_t)va_arg(ap, unsigned);
@ -211,6 +215,10 @@ int open(const char* path, int options, ...)
int openat(int dirfd, const char* path, int options, ...)
{
if (!path) {
errno = EFAULT;
return -1;
}
va_list ap;
va_start(ap, options);
auto mode = (mode_t)va_arg(ap, unsigned);