diff options
author | Sergey Bugaev <bugaevc@gmail.com> | 2023-06-26 02:17:49 +0300 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2023-07-03 01:38:12 +0200 |
commit | f84c3ceb0447477eb022cd5da6c8f27a705deae6 (patch) | |
tree | 1bf12f75f7ff37e7b7056672c4a2dc115a6bcaed | |
parent | 4b5e576fc21931969c0a1b53fdaf7ce3bfcebb86 (diff) | |
download | glibc-f84c3ceb0447477eb022cd5da6c8f27a705deae6.tar.gz glibc-f84c3ceb0447477eb022cd5da6c8f27a705deae6.tar.xz glibc-f84c3ceb0447477eb022cd5da6c8f27a705deae6.zip |
hurd: Fix calling vm_deallocate (NULL)
Only call vm_deallocate when we do have the old buffer, and check for unexpected errors. Spotted while debugging a msgids/readdir issue on x86_64-gnu. Signed-off-by: Sergey Bugaev <bugaevc@gmail.com> Message-Id: <20230625231751.404120-3-bugaevc@gmail.com>
-rw-r--r-- | sysdeps/mach/hurd/readdir64.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/sysdeps/mach/hurd/readdir64.c b/sysdeps/mach/hurd/readdir64.c index 2c01ca22c9..2d946793af 100644 --- a/sysdeps/mach/hurd/readdir64.c +++ b/sysdeps/mach/hurd/readdir64.c @@ -64,9 +64,13 @@ __readdir64 (DIR *dirp) /* The data was passed out of line, so our old buffer is no longer useful. Deallocate the old buffer and reset our information for the new buffer. */ - __vm_deallocate (__mach_task_self (), - (vm_address_t) dirp->__data, - dirp->__allocation); + if (dirp->__data != NULL) + { + err = __vm_deallocate (__mach_task_self (), + (vm_address_t) dirp->__data, + dirp->__allocation); + assert_perror (err); + } dirp->__data = data; dirp->__allocation = round_page (dirp->__size); } |