svn commit: r316039 - stable/11/lib/libkvm
Ngie Cooper
ngie at FreeBSD.org
Mon Mar 27 18:22:35 UTC 2017
Author: ngie
Date: Mon Mar 27 18:22:33 2017
New Revision: 316039
URL: https://svnweb.freebsd.org/changeset/base/316039
Log:
MFC r315595,r315601,r315603,r315647:
r315595:
Remove a commented out line before kvm_getprocs(3)
The commented out return value for kvm_getprocs(3) was misleading -- the
uncommented line is correct.
No content change
r315601:
kvm_open2(3): remove '*' when describing addr argument for `resolver`
As noted by vangyzen, with a similar issue in D10022, the pointer portion of
the .Fa macro call is unnecessary, so remove the '*'.
r315603:
kvm_close(3): return `error` instead of blindly returning `0`
`error` is the accumulated error from previous close(2) calls.
This bug has been present since the libcall's import from 4.4BSD
Lite (r1573).
Noticed by: vangyzen (D10022)
Relnotes: yes
r315647:
Handle kd == NULL gracefully with kvm_close(3)
Don't segfault in kvm_close(3) if provided a NULL pointer. Instead, return
-1 and set errno to EINVAL.
Document this new behavior explicitly.
Modified:
stable/11/lib/libkvm/kvm.c
stable/11/lib/libkvm/kvm_getprocs.3
stable/11/lib/libkvm/kvm_open.3
Directory Properties:
stable/11/ (props changed)
Modified: stable/11/lib/libkvm/kvm.c
==============================================================================
--- stable/11/lib/libkvm/kvm.c Mon Mar 27 18:20:32 2017 (r316038)
+++ stable/11/lib/libkvm/kvm.c Mon Mar 27 18:22:33 2017 (r316039)
@@ -534,6 +534,10 @@ kvm_close(kvm_t *kd)
{
int error = 0;
+ if (kd == NULL) {
+ errno = EINVAL;
+ return (-1);
+ }
if (kd->vmst != NULL)
kd->arch->ka_freevtop(kd);
if (kd->pmfd >= 0)
@@ -552,7 +556,7 @@ kvm_close(kvm_t *kd)
free((void *)kd->argv);
free((void *)kd);
- return (0);
+ return (error);
}
/*
Modified: stable/11/lib/libkvm/kvm_getprocs.3
==============================================================================
--- stable/11/lib/libkvm/kvm_getprocs.3 Mon Mar 27 18:20:32 2017 (r316038)
+++ stable/11/lib/libkvm/kvm_getprocs.3 Mon Mar 27 18:22:33 2017 (r316039)
@@ -47,7 +47,6 @@
.In sys/param.h
.In sys/sysctl.h
.In sys/user.h
-.\" .Fa kvm_t *kd
.Ft struct kinfo_proc *
.Fn kvm_getprocs "kvm_t *kd" "int op" "int arg" "int *cnt"
.Ft char **
Modified: stable/11/lib/libkvm/kvm_open.3
==============================================================================
--- stable/11/lib/libkvm/kvm_open.3 Mon Mar 27 18:20:32 2017 (r316038)
+++ stable/11/lib/libkvm/kvm_open.3 Mon Mar 27 18:22:33 2017 (r316039)
@@ -32,7 +32,7 @@
.\" @(#)kvm_open.3 8.3 (Berkeley) 4/19/94
.\" $FreeBSD$
.\"
-.Dd November 27, 2015
+.Dd March 20, 2017
.Dt KVM_OPEN 3
.Os
.Sh NAME
@@ -196,7 +196,7 @@ function is called,
specifies the requested symbol name.
If the function is able to resolve the name to an address,
the address should be set in
-.Fa *addr
+.Fa addr
and the function should return zero.
If the function is not able to resolve the name to an address,
it should return a non-zero value.
@@ -227,10 +227,29 @@ and
write the error message into
.Fa errbuf .
.Pp
+.Rv -std kvm_close
+.Sh ERRORS
The
.Fn kvm_close
-function returns 0 on success and -1 on failure.
+function may fail and set the global variable
+.Va errno
+for any of the errors specified for
+.Xr close 2 .
+.Pp
+The
+.Fn kvm_close
+function may also fail and set
+.Va errno
+if:
+.Bl -tag -width Er
+.It Bq Er EINVAL
+The value passed via
+.Fa kd
+was
+.Dv NULL .
+.El
.Sh SEE ALSO
+.Xr close 2 ,
.Xr open 2 ,
.Xr kvm 3 ,
.Xr kvm_getargv 3 ,
More information about the svn-src-stable
mailing list