xref: /kvmtool/powerpc/include/kvm/kvm-arch.h (revision c481cfd579e5039b5ed6443c4905a43e53fd91aa)
1 /*
2  * PPC64 architecture-specific definitions
3  *
4  * Copyright 2011 Matt Evans <matt@ozlabs.org>, IBM Corporation.
5  *
6  * This program is free software; you can redistribute it and/or modify it
7  * under the terms of the GNU General Public License version 2 as published
8  * by the Free Software Foundation.
9  */
10 
11 #ifndef KVM__KVM_ARCH_H
12 #define KVM__KVM_ARCH_H
13 
14 #include <stdbool.h>
15 #include <linux/types.h>
16 #include <time.h>
17 
18 /*
19  * MMIO lives after RAM, but it'd be nice if it didn't constantly move.
20  * Choose a suitably high address, e.g. 63T...  This limits RAM size.
21  */
22 #define PPC_MMIO_START			0x3F0000000000UL
23 #define PPC_MMIO_SIZE			0x010000000000UL
24 
25 #define KERNEL_LOAD_ADDR        	0x0000000000000000
26 #define KERNEL_START_ADDR       	0x0000000000000000
27 #define KERNEL_SECONDARY_START_ADDR     0x0000000000000060
28 #define INITRD_LOAD_ADDR        	0x0000000002800000
29 
30 #define FDT_MAX_SIZE            	0x10000
31 #define RTAS_MAX_SIZE           	0x10000
32 
33 #define TIMEBASE_FREQ           	512000000ULL
34 
35 #define KVM_MMIO_START			PPC_MMIO_START
36 
37 /*
38  * This is the address that pci_get_io_space_block() starts allocating
39  * from.  Note that this is a PCI bus address.
40  */
41 #define KVM_PCI_MMIO_AREA		0x1000000
42 
43 struct spapr_phb;
44 
45 struct kvm {
46 	int			sys_fd;		/* For system ioctls(), i.e. /dev/kvm */
47 	int			vm_fd;		/* For VM ioctls() */
48 	timer_t			timerid;	/* Posix timer for interrupts */
49 
50 	int			nrcpus;		/* Number of cpus to run */
51 
52 	u32			mem_slots;	/* for KVM_SET_USER_MEMORY_REGION */
53 
54 	u64			ram_size;
55 	void			*ram_start;
56 
57 	u64			sdr1;
58 	u32			pvr;
59 
60 	bool			nmi_disabled;
61 
62 	bool			single_step;
63 
64 	const char		*vmlinux;
65 	struct disk_image       **disks;
66 	int                     nr_disks;
67 	unsigned long		rtas_gra;
68 	unsigned long		rtas_size;
69 	unsigned long		fdt_gra;
70 	unsigned long		initrd_gra;
71 	unsigned long		initrd_size;
72 	const char		*name;
73 	int			vm_state;
74 	struct icp_state	*icp;
75 	struct spapr_phb	*phb;
76 };
77 
78 /* Helper for the various bits of code that generate FDT nodes */
79 #define _FDT(exp)							\
80 	do {								\
81 		int ret = (exp);					\
82 		if (ret < 0) {						\
83 			die("Error creating device tree: %s: %s\n",	\
84 			    #exp, fdt_strerror(ret));			\
85 		}							\
86 	} while (0)
87 
88 #endif /* KVM__KVM_ARCH_H */
89