kvm_read
,
kvm_read2
, kvm_write
— read or write kernel virtual memory
Kernel Data Access Library (libkvm,
-lkvm)
#include
<kvm.h>
ssize_t
kvm_read
(kvm_t
*kd, unsigned long
addr, void *buf,
size_t nbytes);
ssize_t
kvm_read2
(kvm_t
*kd, kvaddr_t addr,
void *buf,
size_t nbytes);
ssize_t
kvm_write
(kvm_t
*kd, unsigned long
addr, const void
*buf, size_t
nbytes);
The
kvm_read
(),
kvm_read2
(), and
kvm_write
()
functions are used to read and write kernel virtual memory (or a crash dump
file). See
kvm_open
(3)
for information regarding opening kernel virtual memory and crash dumps.
The
kvm_read
()
and kvm_read2
() functions transfer
nbytes bytes of data from the kernel space address
addr to buf. Conversely,
kvm_write
()
transfers data from buf to addr.
Unlike their SunOS counterparts, these functions cannot be used to read or
write process address spaces.
The
kvm_read2
()
function uses a different type (kvaddr_t) for the
addr argument to allow use of addresses larger than
ULONG_MAX
when examining non-native kernel
images.
Upon success, the number of bytes actually transferred is
returned. Otherwise, -1 is returned.
The kvm_read2
() function first appeared in
FreeBSD 11.0.