2 * Xen basic APIC support
4 * Copyright (c) 2012 Citrix
7 * Wei Liu <wei.liu2@citrix.com>
9 * This work is licensed under the terms of the GNU GPL version 2 or
10 * later. See the COPYING file in the top-level directory.
12 #include "qemu/osdep.h"
13 #include "hw/i386/apic_internal.h"
14 #include "hw/pci/msi.h"
15 #include "hw/xen/xen.h"
17 static uint64_t xen_apic_mem_read(void *opaque
, hwaddr addr
,
23 static void xen_apic_mem_write(void *opaque
, hwaddr addr
,
24 uint64_t data
, unsigned size
)
26 if (size
!= sizeof(uint32_t)) {
27 fprintf(stderr
, "Xen: APIC write data size = %d, invalid\n", size
);
31 xen_hvm_inject_msi(addr
, data
);
34 static const MemoryRegionOps xen_apic_io_ops
= {
35 .read
= xen_apic_mem_read
,
36 .write
= xen_apic_mem_write
,
37 .endianness
= DEVICE_NATIVE_ENDIAN
,
40 static void xen_apic_realize(DeviceState
*dev
, Error
**errp
)
42 APICCommonState
*s
= APIC_COMMON(dev
);
45 memory_region_init_io(&s
->io_memory
, OBJECT(s
), &xen_apic_io_ops
, s
,
46 "xen-apic-msi", APIC_SPACE_SIZE
);
50 static void xen_apic_set_base(APICCommonState
*s
, uint64_t val
)
54 static void xen_apic_set_tpr(APICCommonState
*s
, uint8_t val
)
58 static uint8_t xen_apic_get_tpr(APICCommonState
*s
)
63 static void xen_apic_vapic_base_update(APICCommonState
*s
)
67 static void xen_apic_external_nmi(APICCommonState
*s
)
71 static void xen_send_msi(MSIMessage
*msi
)
73 xen_hvm_inject_msi(msi
->address
, msi
->data
);
76 static void xen_apic_class_init(ObjectClass
*klass
, void *data
)
78 APICCommonClass
*k
= APIC_COMMON_CLASS(klass
);
80 k
->realize
= xen_apic_realize
;
81 k
->set_base
= xen_apic_set_base
;
82 k
->set_tpr
= xen_apic_set_tpr
;
83 k
->get_tpr
= xen_apic_get_tpr
;
84 k
->vapic_base_update
= xen_apic_vapic_base_update
;
85 k
->external_nmi
= xen_apic_external_nmi
;
86 k
->send_msi
= xen_send_msi
;
89 static const TypeInfo xen_apic_info
= {
91 .parent
= TYPE_APIC_COMMON
,
92 .instance_size
= sizeof(APICCommonState
),
93 .class_init
= xen_apic_class_init
,
96 static void xen_apic_register_types(void)
98 type_register_static(&xen_apic_info
);
101 type_init(xen_apic_register_types
)