diff options
author | He, Qing <qing.he@intel.com> | 2007-07-26 04:05:18 -0400 |
---|---|---|
committer | Avi Kivity <avi@qumranet.com> | 2007-10-13 04:18:25 -0400 |
commit | 6ceb9d791eeeb0a5493958f5d6d4dc7d91e59cf7 (patch) | |
tree | 8cef21acf9346fdbea36075029dc007fe969b51e /include | |
parent | 9cf98828d12285d1fb43e774c8c100a55f8f34e1 (diff) |
KVM: Add get/set irqchip ioctls for in-kernel PIC live migration support
This patch adds two new ioctls to dump and write kernel irqchips for
save/restore and live migration. PIC s/r and l/m is implemented in this
patch.
Signed-off-by: Yaozu (Eddie) Dong <eddie.dong@intel.com>
Signed-off-by: Qing He <qing.he@intel.com>
Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/kvm.h | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/include/linux/kvm.h b/include/linux/kvm.h index b0a13d1b34cc..6560f11870fd 100644 --- a/include/linux/kvm.h +++ b/include/linux/kvm.h | |||
@@ -45,6 +45,40 @@ struct kvm_irq_level { | |||
45 | __u32 level; | 45 | __u32 level; |
46 | }; | 46 | }; |
47 | 47 | ||
48 | /* for KVM_GET_IRQCHIP / KVM_SET_IRQCHIP */ | ||
49 | struct kvm_pic_state { | ||
50 | __u8 last_irr; /* edge detection */ | ||
51 | __u8 irr; /* interrupt request register */ | ||
52 | __u8 imr; /* interrupt mask register */ | ||
53 | __u8 isr; /* interrupt service register */ | ||
54 | __u8 priority_add; /* highest irq priority */ | ||
55 | __u8 irq_base; | ||
56 | __u8 read_reg_select; | ||
57 | __u8 poll; | ||
58 | __u8 special_mask; | ||
59 | __u8 init_state; | ||
60 | __u8 auto_eoi; | ||
61 | __u8 rotate_on_auto_eoi; | ||
62 | __u8 special_fully_nested_mode; | ||
63 | __u8 init4; /* true if 4 byte init */ | ||
64 | __u8 elcr; /* PIIX edge/trigger selection */ | ||
65 | __u8 elcr_mask; | ||
66 | }; | ||
67 | |||
68 | enum kvm_irqchip_id { | ||
69 | KVM_IRQCHIP_PIC_MASTER = 0, | ||
70 | KVM_IRQCHIP_PIC_SLAVE = 1, | ||
71 | }; | ||
72 | |||
73 | struct kvm_irqchip { | ||
74 | __u32 chip_id; | ||
75 | __u32 pad; | ||
76 | union { | ||
77 | char dummy[512]; /* reserving space */ | ||
78 | struct kvm_pic_state pic; | ||
79 | } chip; | ||
80 | }; | ||
81 | |||
48 | enum kvm_exit_reason { | 82 | enum kvm_exit_reason { |
49 | KVM_EXIT_UNKNOWN = 0, | 83 | KVM_EXIT_UNKNOWN = 0, |
50 | KVM_EXIT_EXCEPTION = 1, | 84 | KVM_EXIT_EXCEPTION = 1, |
@@ -299,6 +333,8 @@ struct kvm_signal_mask { | |||
299 | /* Device model IOC */ | 333 | /* Device model IOC */ |
300 | #define KVM_CREATE_IRQCHIP _IO(KVMIO, 0x60) | 334 | #define KVM_CREATE_IRQCHIP _IO(KVMIO, 0x60) |
301 | #define KVM_IRQ_LINE _IOW(KVMIO, 0x61, struct kvm_irq_level) | 335 | #define KVM_IRQ_LINE _IOW(KVMIO, 0x61, struct kvm_irq_level) |
336 | #define KVM_GET_IRQCHIP _IOWR(KVMIO, 0x62, struct kvm_irqchip) | ||
337 | #define KVM_SET_IRQCHIP _IOR(KVMIO, 0x63, struct kvm_irqchip) | ||
302 | 338 | ||
303 | /* | 339 | /* |
304 | * ioctls for vcpu fds | 340 | * ioctls for vcpu fds |