mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-25 03:03:32 +00:00 
			
		
		
		
	 5be5df720e
			
		
	
	
		5be5df720e
		
	
	
	
	
		
			
			Use kernel common header for fw_cfg. (unfortunately, optionrom.h must have its own define, since it's actually an assembler header) Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Message-Id: <20180817155910.5722-2-marcandre.lureau@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
		
			
				
	
	
		
			98 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: BSD-3-Clause */
 | |
| #ifndef _LINUX_FW_CFG_H
 | |
| #define _LINUX_FW_CFG_H
 | |
| 
 | |
| #include "standard-headers/linux/types.h"
 | |
| 
 | |
| #define FW_CFG_ACPI_DEVICE_ID	"QEMU0002"
 | |
| 
 | |
| /* selector key values for "well-known" fw_cfg entries */
 | |
| #define FW_CFG_SIGNATURE	0x00
 | |
| #define FW_CFG_ID		0x01
 | |
| #define FW_CFG_UUID		0x02
 | |
| #define FW_CFG_RAM_SIZE		0x03
 | |
| #define FW_CFG_NOGRAPHIC	0x04
 | |
| #define FW_CFG_NB_CPUS		0x05
 | |
| #define FW_CFG_MACHINE_ID	0x06
 | |
| #define FW_CFG_KERNEL_ADDR	0x07
 | |
| #define FW_CFG_KERNEL_SIZE	0x08
 | |
| #define FW_CFG_KERNEL_CMDLINE	0x09
 | |
| #define FW_CFG_INITRD_ADDR	0x0a
 | |
| #define FW_CFG_INITRD_SIZE	0x0b
 | |
| #define FW_CFG_BOOT_DEVICE	0x0c
 | |
| #define FW_CFG_NUMA		0x0d
 | |
| #define FW_CFG_BOOT_MENU	0x0e
 | |
| #define FW_CFG_MAX_CPUS		0x0f
 | |
| #define FW_CFG_KERNEL_ENTRY	0x10
 | |
| #define FW_CFG_KERNEL_DATA	0x11
 | |
| #define FW_CFG_INITRD_DATA	0x12
 | |
| #define FW_CFG_CMDLINE_ADDR	0x13
 | |
| #define FW_CFG_CMDLINE_SIZE	0x14
 | |
| #define FW_CFG_CMDLINE_DATA	0x15
 | |
| #define FW_CFG_SETUP_ADDR	0x16
 | |
| #define FW_CFG_SETUP_SIZE	0x17
 | |
| #define FW_CFG_SETUP_DATA	0x18
 | |
| #define FW_CFG_FILE_DIR		0x19
 | |
| 
 | |
| #define FW_CFG_FILE_FIRST	0x20
 | |
| #define FW_CFG_FILE_SLOTS_MIN	0x10
 | |
| 
 | |
| #define FW_CFG_WRITE_CHANNEL	0x4000
 | |
| #define FW_CFG_ARCH_LOCAL	0x8000
 | |
| #define FW_CFG_ENTRY_MASK	(~(FW_CFG_WRITE_CHANNEL | FW_CFG_ARCH_LOCAL))
 | |
| 
 | |
| #define FW_CFG_INVALID		0xffff
 | |
| 
 | |
| /* width in bytes of fw_cfg control register */
 | |
| #define FW_CFG_CTL_SIZE		0x02
 | |
| 
 | |
| /* fw_cfg "file name" is up to 56 characters (including terminating nul) */
 | |
| #define FW_CFG_MAX_FILE_PATH	56
 | |
| 
 | |
| /* size in bytes of fw_cfg signature */
 | |
| #define FW_CFG_SIG_SIZE 4
 | |
| 
 | |
| /* FW_CFG_ID bits */
 | |
| #define FW_CFG_VERSION		0x01
 | |
| #define FW_CFG_VERSION_DMA	0x02
 | |
| 
 | |
| /* fw_cfg file directory entry type */
 | |
| struct fw_cfg_file {
 | |
| 	uint32_t size;
 | |
| 	uint16_t select;
 | |
| 	uint16_t reserved;
 | |
| 	char name[FW_CFG_MAX_FILE_PATH];
 | |
| };
 | |
| 
 | |
| /* FW_CFG_DMA_CONTROL bits */
 | |
| #define FW_CFG_DMA_CTL_ERROR	0x01
 | |
| #define FW_CFG_DMA_CTL_READ	0x02
 | |
| #define FW_CFG_DMA_CTL_SKIP	0x04
 | |
| #define FW_CFG_DMA_CTL_SELECT	0x08
 | |
| #define FW_CFG_DMA_CTL_WRITE	0x10
 | |
| 
 | |
| #define FW_CFG_DMA_SIGNATURE    0x51454d5520434647ULL /* "QEMU CFG" */
 | |
| 
 | |
| /* Control as first field allows for different structures selected by this
 | |
|  * field, which might be useful in the future
 | |
|  */
 | |
| struct fw_cfg_dma_access {
 | |
| 	uint32_t control;
 | |
| 	uint32_t length;
 | |
| 	uint64_t address;
 | |
| };
 | |
| 
 | |
| #define FW_CFG_VMCOREINFO_FILENAME "etc/vmcoreinfo"
 | |
| 
 | |
| #define FW_CFG_VMCOREINFO_FORMAT_NONE 0x0
 | |
| #define FW_CFG_VMCOREINFO_FORMAT_ELF 0x1
 | |
| 
 | |
| struct fw_cfg_vmcoreinfo {
 | |
| 	uint16_t host_format;
 | |
| 	uint16_t guest_format;
 | |
| 	uint32_t size;
 | |
| 	uint64_t paddr;
 | |
| };
 | |
| 
 | |
| #endif
 |