diff options
author | Jacques Vidrine <nectar@FreeBSD.org> | 2002-09-13 15:09:07 +0000 |
---|---|---|
committer | Jacques Vidrine <nectar@FreeBSD.org> | 2002-09-13 15:09:07 +0000 |
commit | 4917e7796c354d55f5f2bbff9882642661d52e11 (patch) | |
tree | 8286e19be662a002b180c76b65068ea8faa1215c /lib/libkvm/kvm.c | |
parent | 3465b7d32c15ed17f750a604fd5168e19ce6f27b (diff) | |
download | src-4917e7796c354d55f5f2bbff9882642661d52e11.tar.gz src-4917e7796c354d55f5f2bbff9882642661d52e11.zip |
MFC src/lib/libkvm/kvm.c 1.23: mark file descriptors close-on-exec.
Notes
Notes:
svn path=/releng/4.6/; revision=103292
Diffstat (limited to 'lib/libkvm/kvm.c')
-rw-r--r-- | lib/libkvm/kvm.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/lib/libkvm/kvm.c b/lib/libkvm/kvm.c index d4a7645857e9..e7bde960d3ea 100644 --- a/lib/libkvm/kvm.c +++ b/lib/libkvm/kvm.c @@ -206,6 +206,10 @@ _kvm_open(kd, uf, mf, flag, errout) _kvm_syserr(kd, kd->program, "%s", mf); goto failed; } + if (fcntl(kd->pmfd, F_SETFD, FD_CLOEXEC) < 0) { + _kvm_syserr(kd, kd->program, "%s", mf); + goto failed; + } if (S_ISCHR(st.st_mode)) { /* * If this is a character special device, then check that @@ -224,6 +228,10 @@ _kvm_open(kd, uf, mf, flag, errout) _kvm_syserr(kd, kd->program, "%s", _PATH_KMEM); goto failed; } + if (fcntl(kd->vmfd, F_SETFD, FD_CLOEXEC) < 0) { + _kvm_syserr(kd, kd->program, "%s", _PATH_KMEM); + goto failed; + } } } else { /* @@ -235,6 +243,10 @@ _kvm_open(kd, uf, mf, flag, errout) _kvm_syserr(kd, kd->program, "%s", uf); goto failed; } + if (fcntl(kd->nlfd, F_SETFD, FD_CLOEXEC) < 0) { + _kvm_syserr(kd, kd->program, "%s", uf); + goto failed; + } if (_kvm_initvtop(kd) < 0) goto failed; } |