x86.c revision 1.3 1 1.3 christos /* $NetBSD: x86.c,v 1.3 2018/08/12 15:55:26 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.3 christos __RCSID("$NetBSD: x86.c,v 1.3 2018/08/12 15:55:26 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.2 christos vaddr_t vm_min_kernel_address = VM_MIN_KERNEL_ADDRESS_DEFAULT;
51 1.2 christos
52 1.1 christos static struct nlist nl[] = {
53 1.3 christos { .n_name = "_dumppcb" },
54 1.2 christos { .n_name = "vm_min_kernel_address" },
55 1.1 christos { .n_name = NULL },
56 1.1 christos };
57 1.1 christos
58 1.1 christos struct pcb pcb;
59 1.1 christos
60 1.1 christos void
61 1.1 christos db_mach_init(kvm_t *kd)
62 1.1 christos {
63 1.1 christos
64 1.1 christos if (kvm_nlist(kd, nl) == -1) {
65 1.1 christos errx(EXIT_FAILURE, "kvm_nlist: %s", kvm_geterr(kd));
66 1.1 christos }
67 1.1 christos if ((size_t)kvm_read(kd, nl[0].n_value, &pcb, sizeof(pcb)) !=
68 1.1 christos sizeof(pcb)) {
69 1.1 christos errx(EXIT_FAILURE, "cannot read dumppcb: %s", kvm_geterr(kd));
70 1.1 christos }
71 1.2 christos if ((size_t)kvm_read(kd, nl[1].n_value, &vm_min_kernel_address,
72 1.2 christos sizeof(vm_min_kernel_address)) != sizeof(vm_min_kernel_address)) {
73 1.2 christos errx(EXIT_FAILURE, "cannot read vm_min_kernel_address: %s",
74 1.2 christos kvm_geterr(kd));
75 1.2 christos }
76 1.1 christos ddb_regs.tf_sp = pcb.pcb_sp;
77 1.1 christos ddb_regs.tf_bp = pcb.pcb_bp;
78 1.1 christos if (ddb_regs.tf_bp != 0 && ddb_regs.tf_sp != 0) {
79 1.1 christos printf("Backtrace from time of crash is available.\n");
80 1.1 christos }
81 1.1 christos }
82