xref: /kvmtool/arm/include/arm-common/kvm-config-arch.h (revision ffa8654620b70053657adf472d505deae2adb2a5)
1 #ifndef ARM_COMMON__KVM_CONFIG_ARCH_H
2 #define ARM_COMMON__KVM_CONFIG_ARCH_H
3 
4 #include "kvm/parse-options.h"
5 
6 struct kvm_config_arch {
7 	const char	*dump_dtb_filename;
8 	unsigned int	force_cntfrq;
9 	bool		virtio_trans_pci;
10 	bool		aarch32_guest;
11 	bool		has_pmuv3;
12 	u64		kaslr_seed;
13 	enum irqchip_type irqchip;
14 	u64		fw_addr;
15 	bool no_pvtime;
16 };
17 
18 int irqchip_parser(const struct option *opt, const char *arg, int unset);
19 
20 #define OPT_ARCH_RUN(pfx, cfg)							\
21 	pfx,									\
22 	ARM_OPT_ARCH_RUN(cfg)							\
23 	OPT_STRING('\0', "dump-dtb", &(cfg)->dump_dtb_filename,			\
24 		   ".dtb file", "Dump generated .dtb to specified file"),	\
25 	OPT_UINTEGER('\0', "override-bad-firmware-cntfrq", &(cfg)->force_cntfrq,\
26 		     "Specify Generic Timer frequency in guest DT to "		\
27 		     "work around buggy secure firmware *Firmware should be "	\
28 		     "updated to program CNTFRQ correctly*"),			\
29 	OPT_BOOLEAN('\0', "force-pci", &(cfg)->virtio_trans_pci,		\
30 		    "Force virtio devices to use PCI as their default "		\
31 		    "transport"),						\
32         OPT_CALLBACK('\0', "irqchip", &(cfg)->irqchip,				\
33 		     "[gicv2|gicv2m|gicv3|gicv3-its]",				\
34 		     "Type of interrupt controller to emulate in the guest",	\
35 		     irqchip_parser, NULL),					\
36 	OPT_U64('\0', "firmware-address", &(cfg)->fw_addr,			\
37 		"Address where firmware should be loaded"),
38 
39 #endif /* ARM_COMMON__KVM_CONFIG_ARCH_H */
40