FreeBSD manual
download PDF document: kvm_read.3.pdf
KVM_READ(3) FreeBSD Library Functions Manual KVM_READ(3)
NAME
kvm_read, kvm_read2, kvm_write - read or write kernel virtual memory
LIBRARY
Kernel Data Access Library (libkvm, -lkvm)
SYNOPSIS
#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);
DESCRIPTION
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.
RETURN VALUES
Upon success, the number of bytes actually transferred is returned.
Otherwise, -1 is returned.
SEE ALSO
kvm(3), kvm_close(3), kvm_getargv(3), kvm_getenvv(3), kvm_geterr(3),
kvm_getprocs(3), kvm_nlist(3), kvm_open(3), kvm_openfiles(3)
HISTORY
The kvm_read2() function first appeared in FreeBSD 11.0.
FreeBSD 14.2-RELEASE November 27, 2015 FreeBSD 14.2-RELEASE