1 1.7 martin /* $NetBSD: kcore.h,v 1.7 2008/04/28 20:23:37 martin Exp $ */ 2 1.1 eeh 3 1.1 eeh /*- 4 1.1 eeh * Copyright (c) 1996 The NetBSD Foundation, Inc. 5 1.1 eeh * All rights reserved. 6 1.1 eeh * 7 1.1 eeh * This code is derived from software contributed to The NetBSD Foundation 8 1.1 eeh * by Paul Kranenburg. 9 1.1 eeh * 10 1.1 eeh * Redistribution and use in source and binary forms, with or without 11 1.1 eeh * modification, are permitted provided that the following conditions 12 1.1 eeh * are met: 13 1.1 eeh * 1. Redistributions of source code must retain the above copyright 14 1.1 eeh * notice, this list of conditions and the following disclaimer. 15 1.1 eeh * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 eeh * notice, this list of conditions and the following disclaimer in the 17 1.1 eeh * documentation and/or other materials provided with the distribution. 18 1.1 eeh * 19 1.1 eeh * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 eeh * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 eeh * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 eeh * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 eeh * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 eeh * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 eeh * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 eeh * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 eeh * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 eeh * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 eeh * POSSIBILITY OF SUCH DAMAGE. 30 1.1 eeh */ 31 1.1 eeh 32 1.1 eeh /* 33 1.1 eeh * The layout of a kernel core on the dump device is as follows: 34 1.1 eeh * a `struct kcore_seg' of type CORE_CPU 35 1.1 eeh * a `struct cpu_kcore_hdr' 36 1.1 eeh */ 37 1.1 eeh 38 1.5 martin struct cpu_kcore_4mbseg { 39 1.5 martin uint64_t va; /* virtual address */ 40 1.5 martin uint64_t pa; /* physical address */ 41 1.5 martin }; 42 1.5 martin 43 1.1 eeh typedef struct cpu_kcore_hdr { 44 1.4 eeh int cputype; /* CPU type associated with this dump */ 45 1.4 eeh 46 1.4 eeh int nmemseg; /* # of physical memory segments */ 47 1.4 eeh uint64_t memsegoffset; /* start of memseg array (relative */ 48 1.1 eeh /* to the start of this header) */ 49 1.4 eeh 50 1.4 eeh int nsegmap; /* # of kernel segs */ 51 1.4 eeh uint64_t segmapoffset; /* start of segmap array (relative */ 52 1.1 eeh /* to the start of this header) */ 53 1.4 eeh 54 1.4 eeh uint64_t kernbase; /* copy of KERNBASE goes here */ 55 1.4 eeh uint64_t cpubase; /* Pointer to cpu_info structure */ 56 1.4 eeh 57 1.4 eeh uint64_t ktextbase; /* Virtual start of text segment */ 58 1.4 eeh uint64_t ktextp; /* Physical address of 4MB locked TLB */ 59 1.4 eeh uint64_t ktextsz; /* Size of locked kernel text segment. */ 60 1.4 eeh 61 1.4 eeh uint64_t kdatabase; /* Virtual start of data segment */ 62 1.4 eeh uint64_t kdatap; /* Physical address of 4MB locked TLB */ 63 1.4 eeh uint64_t kdatasz; /* Size of locked kernel data segment. */ 64 1.4 eeh 65 1.5 martin uint64_t newmagic; /* magic value: everything beyound is 66 1.5 martin valid */ 67 1.5 martin #define SPARC64_KCORE_NEWMAGIC 0x3AFEC01E 68 1.5 martin uint64_t num4mbsegs; /* number of 4MB segments */ 69 1.5 martin uint64_t off4mbsegs; /* start of 4m segment array 70 1.5 martin (relative to start of this 71 1.5 martin header) */ 72 1.5 martin 73 1.6 martin uint64_t numcpuinfos; /* number of per CPU mapping infos */ 74 1.6 martin uint64_t percpusz; /* size of per cpu mapping */ 75 1.6 martin uint64_t thiscpu; /* index of the cpu writing the dump */ 76 1.6 martin uint64_t cpusp; /* physical address of first per-cpu 77 1.6 martin mapping */ 78 1.1 eeh } cpu_kcore_hdr_t; 79