mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-04 09:09:56 +00:00
7233 dir_is_empty should open directory with CLOEXEC
illumos/illumos-gate@d420209d9c
d420209d9c
https://www.illumos.org/issues/7233
This fixes a race where one thread is executing zfs_mount() while another
thread forks and execs. If the fork occurs while the directory is open, the
child process will inherit (but not necessarily close immediately) the open fd
for the directory, preventing the mount.
Reviewed by: Matthew Ahrens <mahrens@delphix.com>
Reviewed by: Paul Dagnelie <pcd@delphix.com>
Approved by: Richard Lowe <richlowe@richlowe.net>
Author: Alex Reece <alex@delphix.com>
This commit is contained in:
parent
8ba67dd37f
commit
68d57fec79
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/vendor/illumos/dist/; revision=316873
@ -21,7 +21,7 @@
|
||||
|
||||
/*
|
||||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2014 by Delphix. All rights reserved.
|
||||
* Copyright (c) 2014, 2015 by Delphix. All rights reserved.
|
||||
* Copyright 2016 Igor Kozhukhov <ikozhukhov@gmail.com>
|
||||
*/
|
||||
|
||||
@ -64,6 +64,7 @@
|
||||
#include <dirent.h>
|
||||
#include <dlfcn.h>
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#include <libgen.h>
|
||||
#include <libintl.h>
|
||||
#include <stdio.h>
|
||||
@ -179,9 +180,16 @@ dir_is_empty(const char *dirname)
|
||||
{
|
||||
DIR *dirp;
|
||||
struct dirent64 *dp;
|
||||
int dirfd;
|
||||
|
||||
if ((dirp = opendir(dirname)) == NULL)
|
||||
if ((dirfd = openat(AT_FDCWD, dirname,
|
||||
O_RDONLY | O_NDELAY | O_LARGEFILE | O_CLOEXEC, 0)) < 0) {
|
||||
return (B_TRUE);
|
||||
}
|
||||
|
||||
if ((dirp = fdopendir(dirfd)) == NULL) {
|
||||
return (B_TRUE);
|
||||
}
|
||||
|
||||
while ((dp = readdir64(dirp)) != NULL) {
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user