X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fdevices%2Fapic.h;h=40415e6c4188f334d9e9f887ccb5344725c16c17;hb=f40945e5a406b48b7b5ee678a3d8d8f0b56f7d74;hp=6ad758e12761595346ef56b7f25602c7ef721f84;hpb=b6e528a6dba181bfbf151ec72ebfad03971fa297;p=palacios.git diff --git a/palacios/include/devices/apic.h b/palacios/include/devices/apic.h index 6ad758e..40415e6 100644 --- a/palacios/include/devices/apic.h +++ b/palacios/include/devices/apic.h @@ -25,8 +25,32 @@ #include +typedef enum {IPI_FIXED = 0, + IPI_LOWEST_PRIO = 1, + IPI_SMI = 2, + IPI_NMI = 4, + IPI_INIT = 5, + IPI_EXINT = 7 } ipi_mode_t; + + +struct v3_gen_ipi { + uint8_t vector; + ipi_mode_t mode; + + uint8_t logical : 1; + uint8_t trigger_mode : 1; + uint8_t dst_shorthand : 2; + + uint8_t dst; +} __attribute__((packed)); + +int v3_apic_send_ipi(struct v3_vm_info * vm, struct vm_device * dev, + struct v3_gen_ipi * ipi); + +int v3_apic_raise_intr(struct v3_vm_info * vm, struct vm_device * apic_dev, + uint32_t irq, uint32_t dst); + -int v3_apic_raise_intr(struct v3_vm_info * vm, struct vm_device * apic_dev, uint32_t irq, uint32_t dst); #endif // ! __V3VEE__