2 * NMI monitor handler class and helpers.
4 * Copyright IBM Corp., 2014
6 * Author: Alexey Kardashevskiy <aik@ozlabs.ru>
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License,
11 * or (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, see <http://www.gnu.org/licenses/>.
22 #include "qemu/osdep.h"
24 #include "qapi/error.h"
25 #include "qapi/qmp/qerror.h"
26 #include "qemu/module.h"
27 #include "monitor/monitor.h"
35 static void nmi_children(Object
*o
, struct do_nmi_s
*ns
);
37 static int do_nmi(Object
*o
, void *opaque
)
39 struct do_nmi_s
*ns
= opaque
;
40 NMIState
*n
= (NMIState
*) object_dynamic_cast(o
, TYPE_NMI
);
43 NMIClass
*nc
= NMI_GET_CLASS(n
);
46 nc
->nmi_monitor_handler(n
, ns
->cpu_index
, &ns
->err
);
56 static void nmi_children(Object
*o
, struct do_nmi_s
*ns
)
58 object_child_foreach(o
, do_nmi
, ns
);
61 void nmi_monitor_handle(int cpu_index
, Error
**errp
)
63 struct do_nmi_s ns
= {
64 .cpu_index
= cpu_index
,
69 nmi_children(object_get_root(), &ns
);
71 error_propagate(errp
, ns
.err
);
73 error_setg(errp
, QERR_UNSUPPORTED
);
77 static const TypeInfo nmi_info
= {
79 .parent
= TYPE_INTERFACE
,
80 .class_size
= sizeof(NMIClass
),
83 static void nmi_register_types(void)
85 type_register_static(&nmi_info
);
88 type_init(nmi_register_types
)