xref: /haiku/headers/private/kernel/arch/x86/msi.h (revision 71452e98334eaac603bf542d159e24788a46bebb)
1 #ifndef _KERNEL_ARCH_x86_MSI_H
2 #define _KERNEL_ARCH_x86_MSI_H
3 
4 #include <SupportDefs.h>
5 
6 // address register
7 #define MSI_ADDRESS_BASE				0xfee00000
8 #define MSI_DESTINATION_ID_SHIFT		12
9 #define MSI_REDIRECTION					0x00000008
10 #define MSI_NO_REDIRECTION				0x00000000
11 #define MSI_DESTINATION_MODE_LOGICAL	0x00000004
12 #define MSI_DESTINATION_MODE_PHYSICAL	0x00000000
13 
14 // data register
15 #define MSI_TRIGGER_MODE_EDGE			0x00000000
16 #define MSI_TRIGGER_MODE_LEVEL			0x00008000
17 #define MSI_LEVEL_DEASSERT				0x00000000
18 #define MSI_LEVEL_ASSERT				0x00004000
19 #define MSI_DELIVERY_MODE_FIXED			0x00000000
20 #define MSI_DELIVERY_MODE_LOWEST_PRIO	0x00000100
21 #define MSI_DELIVERY_MODE_SMI			0x00000200
22 #define MSI_DELIVERY_MODE_NMI			0x00000400
23 #define MSI_DELIVERY_MODE_INIT			0x00000500
24 #define MSI_DELIVERY_MODE_EXT_INT		0x00000700
25 
26 
27 bool		msi_supported();
28 status_t	msi_allocate_vectors(uint8 count, uint8 *startVector,
29 				uint64 *address, uint16 *data);
30 void		msi_free_vectors(uint8 count, uint8 startVector);
31 void		msi_assign_interrupt_to_cpu(uint8 irq, int32 cpu);
32 
33 #endif // _KERNEL_ARCH_x86_MSI_H
34