xref: /kvmtool/powerpc/spapr.h (revision c481cfd579e5039b5ed6443c4905a43e53fd91aa)
1be76823fSMatt Evans /*
2be76823fSMatt Evans  * SPAPR definitions and declarations
3be76823fSMatt Evans  *
4be76823fSMatt Evans  * Borrowed heavily from QEMU's spapr.h,
5be76823fSMatt Evans  * Copyright (c) 2010 David Gibson, IBM Corporation.
6be76823fSMatt Evans  *
7be76823fSMatt Evans  * Modifications by Matt Evans <matt@ozlabs.org>, IBM Corporation.
8be76823fSMatt Evans  *
9be76823fSMatt Evans  * This program is free software; you can redistribute it and/or modify it
10be76823fSMatt Evans  * under the terms of the GNU General Public License version 2 as published
11be76823fSMatt Evans  * by the Free Software Foundation.
12be76823fSMatt Evans  */
13be76823fSMatt Evans 
14be76823fSMatt Evans #if !defined(__HW_SPAPR_H__)
15be76823fSMatt Evans #define __HW_SPAPR_H__
16be76823fSMatt Evans 
17be76823fSMatt Evans #include <inttypes.h>
18be76823fSMatt Evans 
19be76823fSMatt Evans /* We need some of the H_ hcall defs, but they're __KERNEL__ only. */
20be76823fSMatt Evans #define __KERNEL__
21be76823fSMatt Evans #include <asm/hvcall.h>
22be76823fSMatt Evans #undef __KERNEL__
23be76823fSMatt Evans 
24be76823fSMatt Evans #include "kvm/kvm.h"
25be76823fSMatt Evans #include "kvm/kvm-cpu.h"
26be76823fSMatt Evans 
27be76823fSMatt Evans typedef unsigned long target_ulong;
28be76823fSMatt Evans typedef uintptr_t target_phys_addr_t;
29be76823fSMatt Evans 
30be76823fSMatt Evans /*
31be76823fSMatt Evans  * The hcalls above are standardized in PAPR and implemented by pHyp
32be76823fSMatt Evans  * as well.
33be76823fSMatt Evans  *
34be76823fSMatt Evans  * We also need some hcalls which are specific to qemu / KVM-on-POWER.
35be76823fSMatt Evans  * So far we just need one for H_RTAS, but in future we'll need more
36be76823fSMatt Evans  * for extensions like virtio.  We put those into the 0xf000-0xfffc
37be76823fSMatt Evans  * range which is reserved by PAPR for "platform-specific" hcalls.
38be76823fSMatt Evans  */
39be76823fSMatt Evans #define KVMPPC_HCALL_BASE       0xf000
40be76823fSMatt Evans #define KVMPPC_H_RTAS           (KVMPPC_HCALL_BASE + 0x0)
41be76823fSMatt Evans #define KVMPPC_HCALL_MAX        KVMPPC_H_RTAS
42be76823fSMatt Evans 
43be76823fSMatt Evans #define DEBUG_SPAPR_HCALLS
44be76823fSMatt Evans 
45be76823fSMatt Evans #ifdef DEBUG_SPAPR_HCALLS
46be76823fSMatt Evans #define hcall_dprintf(fmt, ...) \
47be76823fSMatt Evans     do { fprintf(stderr, fmt, ## __VA_ARGS__); } while (0)
48be76823fSMatt Evans #else
49be76823fSMatt Evans #define hcall_dprintf(fmt, ...) \
50be76823fSMatt Evans     do { } while (0)
51be76823fSMatt Evans #endif
52be76823fSMatt Evans 
53be76823fSMatt Evans typedef target_ulong (*spapr_hcall_fn)(struct kvm_cpu *vcpu,
54be76823fSMatt Evans 				       target_ulong opcode,
55be76823fSMatt Evans                                        target_ulong *args);
56be76823fSMatt Evans 
57be76823fSMatt Evans void hypercall_init(void);
58be76823fSMatt Evans void register_core_rtas(void);
59be76823fSMatt Evans 
60be76823fSMatt Evans void spapr_register_hypercall(target_ulong opcode, spapr_hcall_fn fn);
61be76823fSMatt Evans target_ulong spapr_hypercall(struct kvm_cpu *vcpu, target_ulong opcode,
62be76823fSMatt Evans                              target_ulong *args);
63be76823fSMatt Evans 
64be76823fSMatt Evans int spapr_rtas_fdt_setup(struct kvm *kvm, void *fdt);
65be76823fSMatt Evans 
66be76823fSMatt Evans static inline uint32_t rtas_ld(struct kvm *kvm, target_ulong phys, int n)
67be76823fSMatt Evans {
68be76823fSMatt Evans 	return *((uint32_t *)guest_flat_to_host(kvm, phys + 4*n));
69be76823fSMatt Evans }
70be76823fSMatt Evans 
71be76823fSMatt Evans static inline void rtas_st(struct kvm *kvm, target_ulong phys, int n, uint32_t val)
72be76823fSMatt Evans {
73be76823fSMatt Evans 	*((uint32_t *)guest_flat_to_host(kvm, phys + 4*n)) = val;
74be76823fSMatt Evans }
75be76823fSMatt Evans 
76be76823fSMatt Evans typedef void (*spapr_rtas_fn)(struct kvm_cpu *vcpu, uint32_t token,
77be76823fSMatt Evans                               uint32_t nargs, target_ulong args,
78be76823fSMatt Evans                               uint32_t nret, target_ulong rets);
79be76823fSMatt Evans void spapr_rtas_register(const char *name, spapr_rtas_fn fn);
80be76823fSMatt Evans target_ulong spapr_rtas_call(struct kvm_cpu *vcpu,
81be76823fSMatt Evans                              uint32_t token, uint32_t nargs, target_ulong args,
82be76823fSMatt Evans                              uint32_t nret, target_ulong rets);
83be76823fSMatt Evans 
84*c481cfd5SMatt Evans #define SPAPR_PCI_BUID          0x800000020000001ULL
85*c481cfd5SMatt Evans #define SPAPR_PCI_MEM_WIN_ADDR  (KVM_MMIO_START + 0xA0000000)
86*c481cfd5SMatt Evans #define SPAPR_PCI_MEM_WIN_SIZE  0x20000000
87*c481cfd5SMatt Evans #define SPAPR_PCI_IO_WIN_ADDR   (SPAPR_PCI_MEM_WIN_ADDR + SPAPR_PCI_MEM_WIN_SIZE)
88*c481cfd5SMatt Evans #define SPAPR_PCI_IO_WIN_SIZE	0x2000000
89*c481cfd5SMatt Evans 
90*c481cfd5SMatt Evans #define SPAPR_PCI_WIN_START	SPAPR_PCI_MEM_WIN_ADDR
91*c481cfd5SMatt Evans #define SPAPR_PCI_WIN_END	(SPAPR_PCI_IO_WIN_ADDR + SPAPR_PCI_IO_WIN_SIZE)
92*c481cfd5SMatt Evans 
93be76823fSMatt Evans #endif /* !defined (__HW_SPAPR_H__) */
94