blob: 7005ced5d1ad7ab93a3862f269855da4cf9a9171 [file] [log] [blame]
Konrad Rzeszutek Wilk31b3c9d2012-03-20 18:53:10 -04001#include <linux/init.h>
Ingo Molnar87e4baa2012-05-18 09:34:45 +02002
Konrad Rzeszutek Wilk31b3c9d2012-03-20 18:53:10 -04003#include <asm/x86_init.h>
Lin Mingab6ec392012-05-01 00:16:27 +08004#include <asm/apic.h>
Lin Mingab6ec392012-05-01 00:16:27 +08005#include <asm/xen/hypercall.h>
Konrad Rzeszutek Wilk31b3c9d2012-03-20 18:53:10 -04006
Ingo Molnar87e4baa2012-05-18 09:34:45 +02007#include <xen/xen.h>
8#include <xen/interface/physdev.h>
Konrad Rzeszutek Wilkb8b0f552012-08-21 14:49:34 -04009#include "xen-ops.h"
Ingo Molnar87e4baa2012-05-18 09:34:45 +020010
Konrad Rzeszutek Wilkb8b0f552012-08-21 14:49:34 -040011static unsigned int xen_io_apic_read(unsigned apic, unsigned reg)
Konrad Rzeszutek Wilk31b3c9d2012-03-20 18:53:10 -040012{
Lin Mingab6ec392012-05-01 00:16:27 +080013 struct physdev_apic apic_op;
14 int ret;
15
16 apic_op.apic_physbase = mpc_ioapic_addr(apic);
17 apic_op.reg = reg;
18 ret = HYPERVISOR_physdev_op(PHYSDEVOP_apic_read, &apic_op);
19 if (!ret)
20 return apic_op.value;
21
22 /* fallback to return an emulated IO_APIC values */
Konrad Rzeszutek Wilk31b3c9d2012-03-20 18:53:10 -040023 if (reg == 0x1)
24 return 0x00170020;
25 else if (reg == 0x0)
26 return apic << 24;
27
28 return 0xfd;
29}
30
31void __init xen_init_apic(void)
32{
33 x86_io_apic_ops.read = xen_io_apic_read;
34}