2003-05-16 14:24:55 +04:00
|
|
|
.\" $NetBSD: kvm_dump.3,v 1.13 2003/05/16 10:24:55 wiz Exp $
|
1996-03-19 00:11:10 +03:00
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1996 Leo Weppelman
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
|
|
.\" must display the following acknowledgement:
|
|
|
|
.\" This product includes software developed by Leo Weppelman.
|
|
|
|
.\" 4. Neither the name of the University nor the names of its contributors
|
|
|
|
.\" may be used to endorse or promote products derived from this software
|
|
|
|
.\" without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\"
|
|
|
|
.Dd March 17, 1996
|
|
|
|
.Dt KVM_DUMP 3
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm kvm_dump_mkheader ,
|
|
|
|
.Nm kvm_dump_wrtheader ,
|
|
|
|
.Nm kvm_dump_inval
|
2003-05-16 14:24:55 +04:00
|
|
|
.Nd crash dump support functions
|
1998-02-05 21:45:17 +03:00
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libkvm
|
1996-03-19 00:11:10 +03:00
|
|
|
.Sh SYNOPSIS
|
2003-04-16 17:34:34 +04:00
|
|
|
.In kvm.h
|
1996-03-19 00:11:10 +03:00
|
|
|
.br
|
|
|
|
.Ft int
|
|
|
|
.Fn kvm_dump_mkheader "kvm_t *kd" "off_t dump_off"
|
|
|
|
.Ft int
|
|
|
|
.Fn kvm_dump_wrtheader "kvm_t *kd" "FILE *fp" "int dumpsize"
|
|
|
|
.Ft int
|
|
|
|
.Fn kvm_dump_inval "kvm_t *kd"
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
First note that the functions described here were designed to be used by
|
|
|
|
.Xr savecore 8 .
|
|
|
|
.Pp
|
|
|
|
The function
|
|
|
|
.Fn kvm_dump_mkheader
|
1999-07-02 19:28:49 +04:00
|
|
|
checks if the physical memory file associated with
|
1996-03-19 00:11:10 +03:00
|
|
|
.Fa kd
|
2003-05-16 14:24:55 +04:00
|
|
|
contains a valid crash dump header as generated by a dumping kernel.
|
2002-10-01 23:18:12 +04:00
|
|
|
When a valid header is found,
|
1996-03-19 00:11:10 +03:00
|
|
|
.Fn kvm_dump_mkheader
|
2003-05-16 14:24:55 +04:00
|
|
|
initializes the internal kvm data structures as if a crash dump generated by
|
1996-03-19 00:11:10 +03:00
|
|
|
the
|
|
|
|
.Xr savecore 8
|
2002-10-01 23:18:12 +04:00
|
|
|
program was opened.
|
|
|
|
This has the intentional side effect of enabling the
|
1996-03-19 00:11:10 +03:00
|
|
|
address translation machinery.
|
|
|
|
.Pp
|
|
|
|
A call to
|
|
|
|
.Fn kvm_dump_mkheader
|
|
|
|
will most likely be followed by a call to
|
|
|
|
.Fn kvm_dump_wrtheader .
|
|
|
|
This function takes care of generating the generic header, the CORE_CPU
|
2002-10-01 23:18:12 +04:00
|
|
|
section and the section header of the CORE_DATA section.
|
|
|
|
The data is written to the file pointed at by
|
1996-03-19 00:11:10 +03:00
|
|
|
.Fa fp .
|
|
|
|
The
|
|
|
|
.Fa dumpsize
|
|
|
|
argument is only used to properly the set the segment size of the CORE_DATA
|
2002-10-01 23:18:12 +04:00
|
|
|
section.
|
|
|
|
Note that this function assumes that
|
1996-03-19 00:11:10 +03:00
|
|
|
.Fa fp
|
2002-10-01 23:18:12 +04:00
|
|
|
is positioned at file location 0.
|
|
|
|
This function will not seek and therefore allows
|
1996-03-19 00:11:10 +03:00
|
|
|
.Fa fp
|
|
|
|
to be a file pointer obtained by
|
|
|
|
.Fn zopen .
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fn kvm_dump_inval
|
|
|
|
function clears the magic number in the physical memory file associated with
|
|
|
|
.Fa kd .
|
|
|
|
The address translations must be enabled for this to work (thus assuming
|
|
|
|
that
|
1996-06-24 00:28:05 +04:00
|
|
|
.Fn kvm_dump_mkheader
|
1996-03-19 00:11:10 +03:00
|
|
|
was called earlier in the sequence).
|
|
|
|
.Sh RETURN VALUES
|
1996-06-24 00:28:05 +04:00
|
|
|
All functions except
|
|
|
|
.Fn kvm_dump_mkheader
|
2002-10-01 23:18:12 +04:00
|
|
|
return 0 on success, -1 on failure.
|
|
|
|
The function
|
1996-06-24 00:28:05 +04:00
|
|
|
.Fn kvm_dump_mkheader
|
2002-10-01 23:18:12 +04:00
|
|
|
returns the size of the headers present before the actual dumpdata starts.
|
|
|
|
If no valid headers were found but no fatal errors occurred, 0 is returned.
|
|
|
|
On fatal errors the return value is -1.
|
1996-06-24 00:28:05 +04:00
|
|
|
.Pp
|
|
|
|
In the case of failure,
|
1996-03-19 00:11:10 +03:00
|
|
|
.Xr kvm_geterr 3
|
|
|
|
can be used to retrieve the cause of the error.
|
|
|
|
.Sh SEE ALSO
|
2001-04-06 18:37:27 +04:00
|
|
|
.Xr kvm 3 ,
|
|
|
|
.Xr kvm_open 3
|
2002-01-15 05:51:48 +03:00
|
|
|
.Sh HISTORY
|
|
|
|
These functions first appeared in
|
|
|
|
.Nx 1.2 .
|