| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | #ifndef QEMU_MSIX_H
 | 
					
						
							|  |  |  | #define QEMU_MSIX_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-12 23:05:42 +02:00
										 |  |  | #include "hw/pci/pci.h"
 | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-21 08:15:43 -07:00
										 |  |  | #define MSIX_CAP_LENGTH 12
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-19 10:35:07 +10:00
										 |  |  | void msix_set_message(PCIDevice *dev, int vector, MSIMessage msg); | 
					
						
							| 
									
										
										
										
											2012-12-21 00:27:02 +02:00
										 |  |  | MSIMessage msix_get_message(PCIDevice *dev, unsigned int vector); | 
					
						
							| 
									
										
										
										
											2012-06-14 12:16:47 -06:00
										 |  |  | int msix_init(PCIDevice *dev, unsigned short nentries, | 
					
						
							|  |  |  |               MemoryRegion *table_bar, uint8_t table_bar_nr, | 
					
						
							|  |  |  |               unsigned table_offset, MemoryRegion *pba_bar, | 
					
						
							| 
									
										
										
										
											2017-01-17 14:18:48 +08:00
										 |  |  |               uint8_t pba_bar_nr, unsigned pba_offset, uint8_t cap_pos, | 
					
						
							|  |  |  |               Error **errp); | 
					
						
							| 
									
										
										
										
											2012-06-14 12:15:51 -06:00
										 |  |  | int msix_init_exclusive_bar(PCIDevice *dev, unsigned short nentries, | 
					
						
							| 
									
										
										
										
											2017-01-17 14:18:48 +08:00
										 |  |  |                             uint8_t bar_nr, Error **errp); | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-13 22:52:06 -06:00
										 |  |  | void msix_write_config(PCIDevice *dev, uint32_t address, uint32_t val, int len); | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-14 12:16:57 -06:00
										 |  |  | void msix_uninit(PCIDevice *dev, MemoryRegion *table_bar, | 
					
						
							|  |  |  |                  MemoryRegion *pba_bar); | 
					
						
							| 
									
										
										
										
											2012-06-14 12:15:51 -06:00
										 |  |  | void msix_uninit_exclusive_bar(PCIDevice *dev); | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-17 10:32:38 -03:00
										 |  |  | unsigned int msix_nr_vectors_allocated(const PCIDevice *dev); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | void msix_save(PCIDevice *dev, QEMUFile *f); | 
					
						
							|  |  |  | void msix_load(PCIDevice *dev, QEMUFile *f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int msix_enabled(PCIDevice *dev); | 
					
						
							|  |  |  | int msix_present(PCIDevice *dev); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-18 13:54:32 +02:00
										 |  |  | bool msix_is_masked(PCIDevice *dev, unsigned vector); | 
					
						
							|  |  |  | void msix_set_pending(PCIDevice *dev, unsigned vector); | 
					
						
							| 
									
										
										
										
											2016-06-01 11:23:31 +03:00
										 |  |  | void msix_clr_pending(PCIDevice *dev, int vector); | 
					
						
							| 
									
										
										
										
											2012-12-18 13:54:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | int msix_vector_use(PCIDevice *dev, unsigned vector); | 
					
						
							|  |  |  | void msix_vector_unuse(PCIDevice *dev, unsigned vector); | 
					
						
							| 
									
										
										
										
											2009-11-24 16:44:15 +02:00
										 |  |  | void msix_unuse_all_vectors(PCIDevice *dev); | 
					
						
							| 
									
										
										
										
											2022-06-13 16:26:33 -04:00
										 |  |  | void msix_set_mask(PCIDevice *dev, int vector, bool mask, Error **errp); | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | void msix_notify(PCIDevice *dev, unsigned vector); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void msix_reset(PCIDevice *dev); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-17 10:32:31 -03:00
										 |  |  | int msix_set_vector_notifiers(PCIDevice *dev, | 
					
						
							|  |  |  |                               MSIVectorUseNotifier use_notifier, | 
					
						
							| 
									
										
										
										
											2012-12-12 16:10:02 +02:00
										 |  |  |                               MSIVectorReleaseNotifier release_notifier, | 
					
						
							|  |  |  |                               MSIVectorPollNotifier poll_notifier); | 
					
						
							| 
									
										
										
										
											2012-05-17 10:32:31 -03:00
										 |  |  | void msix_unset_vector_notifiers(PCIDevice *dev); | 
					
						
							| 
									
										
										
										
											2013-05-07 15:16:58 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | extern const VMStateDescription vmstate_msix; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 14:05:13 +02:00
										 |  |  | #define VMSTATE_MSIX_TEST(_field, _state, _test) {                   \
 | 
					
						
							|  |  |  |     .name         = (stringify(_field)),                             \ | 
					
						
							|  |  |  |     .size         = sizeof(PCIDevice),                               \ | 
					
						
							|  |  |  |     .vmsd         = &vmstate_msix,                                   \ | 
					
						
							|  |  |  |     .flags        = VMS_STRUCT,                                      \ | 
					
						
							|  |  |  |     .offset       = vmstate_offset_value(_state, _field, PCIDevice), \ | 
					
						
							|  |  |  |     .field_exists = (_test)                                          \ | 
					
						
							| 
									
										
										
										
											2013-05-07 15:16:58 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 14:05:13 +02:00
										 |  |  | #define VMSTATE_MSIX(_f, _s)                                         \
 | 
					
						
							|  |  |  |     VMSTATE_MSIX_TEST(_f, _s, NULL) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-21 19:49:54 +03:00
										 |  |  | #endif
 |