1*24761fbaSjakllsch /* $NetBSD: db_cpu.c,v 1.7 2014/04/12 19:25:48 jakllsch Exp $ */
2cd6b1c8fSad
3cd6b1c8fSad /*-
4cd6b1c8fSad * Copyright (c) 2009 The NetBSD Foundation, Inc.
5cd6b1c8fSad * All rights reserved.
6cd6b1c8fSad *
7cd6b1c8fSad * This code is derived from software contributed to The NetBSD Foundation
8cd6b1c8fSad * by Andrew Doran.
9cd6b1c8fSad *
10cd6b1c8fSad * Redistribution and use in source and binary forms, with or without
11cd6b1c8fSad * modification, are permitted provided that the following conditions
12cd6b1c8fSad * are met:
13cd6b1c8fSad * 1. Redistributions of source code must retain the above copyright
14cd6b1c8fSad * notice, this list of conditions and the following disclaimer.
15cd6b1c8fSad * 2. Redistributions in binary form must reproduce the above copyright
16cd6b1c8fSad * notice, this list of conditions and the following disclaimer in the
17cd6b1c8fSad * documentation and/or other materials provided with the distribution.
18cd6b1c8fSad *
19cd6b1c8fSad * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20cd6b1c8fSad * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21cd6b1c8fSad * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22cd6b1c8fSad * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23cd6b1c8fSad * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24cd6b1c8fSad * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25cd6b1c8fSad * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26cd6b1c8fSad * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27cd6b1c8fSad * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28cd6b1c8fSad * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29cd6b1c8fSad * POSSIBILITY OF SUCH DAMAGE.
30cd6b1c8fSad */
31cd6b1c8fSad
32cd6b1c8fSad #include <sys/cdefs.h>
33*24761fbaSjakllsch __KERNEL_RCSID(0, "$NetBSD: db_cpu.c,v 1.7 2014/04/12 19:25:48 jakllsch Exp $");
34d2ea53a0Smrg
35d2ea53a0Smrg #ifndef _KERNEL
36d2ea53a0Smrg #include <stdbool.h>
37d2ea53a0Smrg #endif
38cd6b1c8fSad
39cd6b1c8fSad #include <sys/param.h>
40cd6b1c8fSad #include <sys/cpu.h>
41cd6b1c8fSad #include <sys/proc.h>
42cd6b1c8fSad
434540375fSmrg #include <ddb/ddb.h>
444540375fSmrg
45ff1b98f1Sjakllsch static int db_ncpu;
46ff1b98f1Sjakllsch static struct cpu_info **db_cpu_infos;
47ff1b98f1Sjakllsch
48ff1b98f1Sjakllsch static void
db_cpu_init(void)49ff1b98f1Sjakllsch db_cpu_init(void)
50ff1b98f1Sjakllsch {
51ff1b98f1Sjakllsch db_expr_t addr;
52ff1b98f1Sjakllsch
53ff1b98f1Sjakllsch db_value_of_name("ncpu", &addr);
54ff1b98f1Sjakllsch db_read_bytes((db_addr_t)addr, sizeof(db_ncpu), (char *)&db_ncpu);
55ff1b98f1Sjakllsch
56ff1b98f1Sjakllsch db_value_of_name("cpu_infos", &addr);
57ff1b98f1Sjakllsch db_read_bytes((db_addr_t)addr, sizeof(db_cpu_infos),
58ff1b98f1Sjakllsch (char *)&db_cpu_infos);
59ff1b98f1Sjakllsch }
60df64447cSrmind
61df64447cSrmind static struct cpu_info *
db_cpu_by_index(u_int idx)62ff1b98f1Sjakllsch db_cpu_by_index(u_int idx)
63df64447cSrmind {
64df64447cSrmind struct cpu_info *ci;
65df64447cSrmind
66ff1b98f1Sjakllsch db_read_bytes((db_addr_t)&db_cpu_infos[idx], sizeof(ci), (char *)&ci);
67df64447cSrmind return ci;
68df64447cSrmind }
69cd6b1c8fSad
70cd6b1c8fSad struct cpu_info *
db_cpu_first(void)71cd6b1c8fSad db_cpu_first(void)
72cd6b1c8fSad {
73ff1b98f1Sjakllsch
74ff1b98f1Sjakllsch db_cpu_init();
75ff1b98f1Sjakllsch return db_cpu_by_index(0);
76cd6b1c8fSad }
77cd6b1c8fSad
78cd6b1c8fSad struct cpu_info *
db_cpu_next(struct cpu_info * ci)79cd6b1c8fSad db_cpu_next(struct cpu_info *ci)
80cd6b1c8fSad {
81df64447cSrmind u_int idx;
82cd6b1c8fSad
83df64447cSrmind db_read_bytes((db_addr_t)&ci->ci_index, sizeof(idx), (char *)&idx);
84*24761fbaSjakllsch if ((idx + 1) >= (u_int)db_ncpu)
85ff1b98f1Sjakllsch return NULL;
86ff1b98f1Sjakllsch return db_cpu_by_index(idx + 1);
87cd6b1c8fSad }
88