1 /*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21 /*
22 * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
24 *
25 * Copyright 2018 Joyent, Inc.
26 */
27
28 #include <sys/types.h>
29 #include <sys/kdi_impl.h>
30 #include <sys/segments.h>
31 #include <sys/cpuvar.h>
32
33 #include <mdb/mdb_debug.h>
34 #include <mdb/mdb_err.h>
35 #include <mdb/mdb_umem.h>
36 #include <kmdb/kmdb_dpi.h>
37 #include <mdb/mdb.h>
38
39 /*ARGSUSED*/
40 void
kmdb_kdi_stop_slaves(int my_cpuid,int doxc)41 kmdb_kdi_stop_slaves(int my_cpuid, int doxc)
42 {
43 /* Stop other CPUs if there are CPUs to stop */
44 mdb.m_kdi->mkdi_stop_slaves(my_cpuid, doxc);
45 }
46
47 void
kmdb_kdi_start_slaves(void)48 kmdb_kdi_start_slaves(void)
49 {
50 mdb.m_kdi->mkdi_start_slaves();
51 }
52
53 void
kmdb_kdi_slave_wait(void)54 kmdb_kdi_slave_wait(void)
55 {
56 mdb.m_kdi->mkdi_slave_wait();
57 }
58
59 uintptr_t
kmdb_kdi_get_userlimit(void)60 kmdb_kdi_get_userlimit(void)
61 {
62 return (mdb.m_kdi->mkdi_get_userlimit());
63 }
64
65 int
kmdb_kdi_get_cpuinfo(uint_t * vendorp,uint_t * familyp,uint_t * modelp)66 kmdb_kdi_get_cpuinfo(uint_t *vendorp, uint_t *familyp, uint_t *modelp)
67 {
68 int err;
69
70 if ((err = mdb.m_kdi->mkdi_get_cpuinfo(vendorp, familyp, modelp)) != 0)
71 return (set_errno(err));
72
73 return (0);
74 }
75
76 /*ARGSUSED*/
77 void
kmdb_kdi_init_isadep(kdi_t * kdi,kmdb_auxv_t * kav)78 kmdb_kdi_init_isadep(kdi_t *kdi, kmdb_auxv_t *kav)
79 {
80 }
81
82 void
kmdb_kdi_activate(kdi_main_t main,kdi_cpusave_t * cpusave,int ncpusave)83 kmdb_kdi_activate(kdi_main_t main, kdi_cpusave_t *cpusave, int ncpusave)
84 {
85 mdb.m_kdi->mkdi_activate(main, cpusave, ncpusave);
86 }
87
88 void
kmdb_kdi_deactivate(void)89 kmdb_kdi_deactivate(void)
90 {
91 mdb.m_kdi->mkdi_deactivate();
92 }
93
94 void
kmdb_kdi_idt_switch(kdi_cpusave_t * cpusave)95 kmdb_kdi_idt_switch(kdi_cpusave_t *cpusave)
96 {
97 mdb.m_kdi->mkdi_idt_switch(cpusave);
98 }
99
100 void
kmdb_kdi_update_drreg(kdi_drreg_t * drreg)101 kmdb_kdi_update_drreg(kdi_drreg_t *drreg)
102 {
103 mdb.m_kdi->mkdi_update_drreg(drreg);
104 }
105
106 void
kmdb_kdi_memrange_add(caddr_t base,size_t len)107 kmdb_kdi_memrange_add(caddr_t base, size_t len)
108 {
109 mdb.m_kdi->mkdi_memrange_add(base, len);
110 }
111
112 void
kmdb_kdi_reboot(void)113 kmdb_kdi_reboot(void)
114 {
115 mdb.m_kdi->mkdi_reboot();
116 }
117