X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fdevices%2Fapic.h;h=4ddfc7c867696c9a02af272a5e5bebbba08440ee;hb=94f67717b6461df514dc225ed84f03b44c44061b;hp=f78e2a60f9f3f7eab9c4ee4539a999337a198b2c;hpb=19b2e4b4ce85ae4e683a3ede33360bdf7547b069;p=palacios.git diff --git a/palacios/include/devices/apic.h b/palacios/include/devices/apic.h index f78e2a6..4ddfc7c 100644 --- a/palacios/include/devices/apic.h +++ b/palacios/include/devices/apic.h @@ -25,7 +25,32 @@ #include -int v3_apic_raise_intr(struct guest_info * info, struct vm_device * apic_dev, int intr_num); +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 v3_gen_ipi * ipi, void * dev_data); + +int v3_apic_raise_intr(struct v3_vm_info * vm, + uint32_t irq, uint32_t dst, + void * dev_data); + + #endif // ! __V3VEE__