1 1.4 christos /* $NetBSD: x86.c,v 1.4 2018/08/12 16:00:41 christos Exp $ */ 2 1.1 christos 3 1.1 christos /*- 4 1.1 christos * Copyright (c) 2009 The NetBSD Foundation, Inc. 5 1.1 christos * All rights reserved. 6 1.1 christos * 7 1.1 christos * This code is derived from software contributed to The NetBSD Foundation 8 1.1 christos * by Andrew Doran. 9 1.1 christos * 10 1.1 christos * Redistribution and use in source and binary forms, with or without 11 1.1 christos * modification, are permitted provided that the following conditions 12 1.1 christos * are met: 13 1.1 christos * 1. Redistributions of source code must retain the above copyright 14 1.1 christos * notice, this list of conditions and the following disclaimer. 15 1.1 christos * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 christos * notice, this list of conditions and the following disclaimer in the 17 1.1 christos * documentation and/or other materials provided with the distribution. 18 1.1 christos * 19 1.1 christos * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 christos * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 christos * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 christos * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 christos * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 christos * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 christos * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 christos * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 christos * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 christos * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 christos * POSSIBILITY OF SUCH DAMAGE. 30 1.1 christos */ 31 1.1 christos 32 1.1 christos #include <sys/cdefs.h> 33 1.1 christos #ifndef lint 34 1.4 christos __RCSID("$NetBSD: x86.c,v 1.4 2018/08/12 16:00:41 christos Exp $"); 35 1.1 christos #endif /* not lint */ 36 1.1 christos 37 1.1 christos #include <ddb/ddb.h> 38 1.1 christos 39 1.1 christos #include <kvm.h> 40 1.1 christos #include <nlist.h> 41 1.1 christos #include <err.h> 42 1.1 christos #include <stdlib.h> 43 1.1 christos 44 1.1 christos #include <machine/frame.h> 45 1.1 christos #include <machine/pcb.h> 46 1.1 christos #include <x86/db_machdep.h> 47 1.1 christos 48 1.1 christos #include "extern.h" 49 1.1 christos 50 1.4 christos #ifdef VM_MIN_KERNEL_ADDRESS_DEFAULT 51 1.2 christos vaddr_t vm_min_kernel_address = VM_MIN_KERNEL_ADDRESS_DEFAULT; 52 1.4 christos #endif 53 1.2 christos 54 1.1 christos static struct nlist nl[] = { 55 1.3 christos { .n_name = "_dumppcb" }, 56 1.4 christos #ifdef VM_MIN_KERNEL_ADDRESS_DEFAULT 57 1.2 christos { .n_name = "vm_min_kernel_address" }, 58 1.4 christos #endif 59 1.1 christos { .n_name = NULL }, 60 1.1 christos }; 61 1.1 christos 62 1.1 christos struct pcb pcb; 63 1.1 christos 64 1.1 christos void 65 1.1 christos db_mach_init(kvm_t *kd) 66 1.1 christos { 67 1.1 christos 68 1.1 christos if (kvm_nlist(kd, nl) == -1) { 69 1.1 christos errx(EXIT_FAILURE, "kvm_nlist: %s", kvm_geterr(kd)); 70 1.1 christos } 71 1.1 christos if ((size_t)kvm_read(kd, nl[0].n_value, &pcb, sizeof(pcb)) != 72 1.1 christos sizeof(pcb)) { 73 1.1 christos errx(EXIT_FAILURE, "cannot read dumppcb: %s", kvm_geterr(kd)); 74 1.1 christos } 75 1.4 christos #ifdef VM_MIN_KERNEL_ADDRESS_DEFAULT 76 1.2 christos if ((size_t)kvm_read(kd, nl[1].n_value, &vm_min_kernel_address, 77 1.2 christos sizeof(vm_min_kernel_address)) != sizeof(vm_min_kernel_address)) { 78 1.2 christos errx(EXIT_FAILURE, "cannot read vm_min_kernel_address: %s", 79 1.2 christos kvm_geterr(kd)); 80 1.2 christos } 81 1.4 christos #endif 82 1.1 christos ddb_regs.tf_sp = pcb.pcb_sp; 83 1.1 christos ddb_regs.tf_bp = pcb.pcb_bp; 84 1.1 christos if (ddb_regs.tf_bp != 0 && ddb_regs.tf_sp != 0) { 85 1.1 christos printf("Backtrace from time of crash is available.\n"); 86 1.1 christos } 87 1.1 christos } 88