| 
									
										
										
										
											2010-10-19 18:06:32 +09:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * msi.h | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2010 Isaku Yamahata <yamahata at valinux co jp> | 
					
						
							|  |  |  |  *                    VA Linux Systems Japan K.K. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation; either version 2 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License along | 
					
						
							|  |  |  |  * with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef QEMU_MSI_H
 | 
					
						
							|  |  |  | #define QEMU_MSI_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-12 23:05:42 +02:00
										 |  |  | #include "hw/pci/pci.h"
 | 
					
						
							| 
									
										
										
										
											2010-10-19 18:06:32 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-16 15:41:09 -03:00
										 |  |  | struct MSIMessage { | 
					
						
							|  |  |  |     uint64_t address; | 
					
						
							|  |  |  |     uint32_t data; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-04 11:24:28 +02:00
										 |  |  | extern bool msi_nonbroken; | 
					
						
							| 
									
										
										
										
											2011-10-15 14:33:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-19 10:35:07 +10:00
										 |  |  | void msi_set_message(PCIDevice *dev, MSIMessage msg); | 
					
						
							| 
									
										
										
										
											2012-10-02 13:22:07 -06:00
										 |  |  | MSIMessage msi_get_message(PCIDevice *dev, unsigned int vector); | 
					
						
							| 
									
										
										
										
											2010-10-19 18:06:32 +09:00
										 |  |  | bool msi_enabled(const PCIDevice *dev); | 
					
						
							|  |  |  | int msi_init(struct PCIDevice *dev, uint8_t offset, | 
					
						
							| 
									
										
										
										
											2016-06-20 14:13:39 +08:00
										 |  |  |              unsigned int nr_vectors, bool msi64bit, | 
					
						
							|  |  |  |              bool msi_per_vector_mask, Error **errp); | 
					
						
							| 
									
										
										
										
											2010-10-19 18:06:32 +09:00
										 |  |  | void msi_uninit(struct PCIDevice *dev); | 
					
						
							|  |  |  | void msi_reset(PCIDevice *dev); | 
					
						
							| 
									
										
										
										
											2019-01-16 11:08:14 +08:00
										 |  |  | bool msi_is_masked(const PCIDevice *dev, unsigned int vector); | 
					
						
							| 
									
										
										
										
											2010-10-19 18:06:32 +09:00
										 |  |  | void msi_notify(PCIDevice *dev, unsigned int vector); | 
					
						
							| 
									
										
										
										
											2015-05-27 15:59:59 +03:00
										 |  |  | void msi_send_message(PCIDevice *dev, MSIMessage msg); | 
					
						
							| 
									
										
										
										
											2010-10-19 18:06:32 +09:00
										 |  |  | void msi_write_config(PCIDevice *dev, uint32_t addr, uint32_t val, int len); | 
					
						
							|  |  |  | unsigned int msi_nr_vectors_allocated(const PCIDevice *dev); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline bool msi_present(const PCIDevice *dev) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return dev->cap_present & QEMU_PCI_CAP_MSI; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* QEMU_MSI_H */
 |