diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-11-06 20:12:03 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-11-06 20:12:03 -0500 |
commit | 1197ab2942f920f261952de0c392ac749a35796b (patch) | |
tree | 4922ccc8a6061e5ece6ac7420001f3bf4524ea92 /arch/powerpc/include/asm | |
parent | ec773e99ab4abce07b1ae23117179c2861831964 (diff) | |
parent | 96cc017c5b7ec095ef047d3c1952b6b6bbf98943 (diff) |
Merge branch 'next' of git://git.kernel.org/pub/scm/linux/kernel/git/benh/powerpc
* 'next' of git://git.kernel.org/pub/scm/linux/kernel/git/benh/powerpc: (106 commits)
powerpc/p3060qds: Add support for P3060QDS board
powerpc/83xx: Add shutdown request support to MCU handling on MPC8349 MITX
powerpc/85xx: Make kexec to interate over online cpus
powerpc/fsl_booke: Fix comment in head_fsl_booke.S
powerpc/85xx: issue 15 EOI after core reset for FSL CoreNet devices
powerpc/8xxx: Fix interrupt handling in MPC8xxx GPIO driver
powerpc/85xx: Add 'fsl,pq3-gpio' compatiable for GPIO driver
powerpc/86xx: Correct Gianfar support for GE boards
powerpc/cpm: Clear muram before it is in use.
drivers/virt: add ioctl for 32-bit compat on 64-bit to fsl-hv-manager
powerpc/fsl_msi: add support for "msi-address-64" property
powerpc/85xx: Setup secondary cores PIR with hard SMP id
powerpc/fsl-booke: Fix settlbcam for 64-bit
powerpc/85xx: Adding DCSR node to dtsi device trees
powerpc/85xx: clean up FPGA device tree nodes for Freecsale QorIQ boards
powerpc/85xx: fix PHYS_64BIT selection for P1022DS
powerpc/fsl-booke: Fix setup_initial_memory_limit to not blindly map
powerpc: respect mem= setting for early memory limit setup
powerpc: Update corenet64_smp_defconfig
powerpc: Update mpc85xx/corenet 32-bit defconfigs
...
Fix up trivial conflicts in:
- arch/powerpc/configs/40x/hcu4_defconfig
removed stale file, edited elsewhere
- arch/powerpc/include/asm/udbg.h, arch/powerpc/kernel/udbg.c:
added opal and gelic drivers vs added ePAPR driver
- drivers/tty/serial/8250.c
moved UPIO_TSI to powerpc vs removed UPIO_DWAPB support
Diffstat (limited to 'arch/powerpc/include/asm')
-rw-r--r-- | arch/powerpc/include/asm/device.h | 2 | ||||
-rw-r--r-- | arch/powerpc/include/asm/firmware.h | 10 | ||||
-rw-r--r-- | arch/powerpc/include/asm/hugetlb.h | 63 | ||||
-rw-r--r-- | arch/powerpc/include/asm/kexec.h | 2 | ||||
-rw-r--r-- | arch/powerpc/include/asm/machdep.h | 3 | ||||
-rw-r--r-- | arch/powerpc/include/asm/mmu-book3e.h | 7 | ||||
-rw-r--r-- | arch/powerpc/include/asm/mmu-hash64.h | 3 | ||||
-rw-r--r-- | arch/powerpc/include/asm/mmu.h | 18 | ||||
-rw-r--r-- | arch/powerpc/include/asm/mpic.h | 2 | ||||
-rw-r--r-- | arch/powerpc/include/asm/opal.h | 443 | ||||
-rw-r--r-- | arch/powerpc/include/asm/paca.h | 8 | ||||
-rw-r--r-- | arch/powerpc/include/asm/page.h | 31 | ||||
-rw-r--r-- | arch/powerpc/include/asm/page_64.h | 11 | ||||
-rw-r--r-- | arch/powerpc/include/asm/pte-book3e.h | 3 | ||||
-rw-r--r-- | arch/powerpc/include/asm/reg_booke.h | 3 | ||||
-rw-r--r-- | arch/powerpc/include/asm/rtas.h | 6 | ||||
-rw-r--r-- | arch/powerpc/include/asm/smp.h | 1 | ||||
-rw-r--r-- | arch/powerpc/include/asm/sparsemem.h | 2 | ||||
-rw-r--r-- | arch/powerpc/include/asm/topology.h | 14 | ||||
-rw-r--r-- | arch/powerpc/include/asm/udbg.h | 3 | ||||
-rw-r--r-- | arch/powerpc/include/asm/xics.h | 19 |
21 files changed, 614 insertions, 40 deletions
diff --git a/arch/powerpc/include/asm/device.h b/arch/powerpc/include/asm/device.h index 16d25c0974b..d57c08acedf 100644 --- a/arch/powerpc/include/asm/device.h +++ b/arch/powerpc/include/asm/device.h | |||
@@ -37,4 +37,6 @@ struct pdev_archdata { | |||
37 | u64 dma_mask; | 37 | u64 dma_mask; |
38 | }; | 38 | }; |
39 | 39 | ||
40 | #define ARCH_HAS_DMA_GET_REQUIRED_MASK | ||
41 | |||
40 | #endif /* _ASM_POWERPC_DEVICE_H */ | 42 | #endif /* _ASM_POWERPC_DEVICE_H */ |
diff --git a/arch/powerpc/include/asm/firmware.h b/arch/powerpc/include/asm/firmware.h index 3a6c586c4e4..14db29b18d0 100644 --- a/arch/powerpc/include/asm/firmware.h +++ b/arch/powerpc/include/asm/firmware.h | |||
@@ -48,6 +48,8 @@ | |||
48 | #define FW_FEATURE_CMO ASM_CONST(0x0000000002000000) | 48 | #define FW_FEATURE_CMO ASM_CONST(0x0000000002000000) |
49 | #define FW_FEATURE_VPHN ASM_CONST(0x0000000004000000) | 49 | #define FW_FEATURE_VPHN ASM_CONST(0x0000000004000000) |
50 | #define FW_FEATURE_XCMO ASM_CONST(0x0000000008000000) | 50 | #define FW_FEATURE_XCMO ASM_CONST(0x0000000008000000) |
51 | #define FW_FEATURE_OPAL ASM_CONST(0x0000000010000000) | ||
52 | #define FW_FEATURE_OPALv2 ASM_CONST(0x0000000020000000) | ||
51 | 53 | ||
52 | #ifndef __ASSEMBLY__ | 54 | #ifndef __ASSEMBLY__ |
53 | 55 | ||
@@ -65,6 +67,8 @@ enum { | |||
65 | FW_FEATURE_PSERIES_ALWAYS = 0, | 67 | FW_FEATURE_PSERIES_ALWAYS = 0, |
66 | FW_FEATURE_ISERIES_POSSIBLE = FW_FEATURE_ISERIES | FW_FEATURE_LPAR, | 68 | FW_FEATURE_ISERIES_POSSIBLE = FW_FEATURE_ISERIES | FW_FEATURE_LPAR, |
67 | FW_FEATURE_ISERIES_ALWAYS = FW_FEATURE_ISERIES | FW_FEATURE_LPAR, | 69 | FW_FEATURE_ISERIES_ALWAYS = FW_FEATURE_ISERIES | FW_FEATURE_LPAR, |
70 | FW_FEATURE_POWERNV_POSSIBLE = FW_FEATURE_OPAL | FW_FEATURE_OPALv2, | ||
71 | FW_FEATURE_POWERNV_ALWAYS = 0, | ||
68 | FW_FEATURE_PS3_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, | 72 | FW_FEATURE_PS3_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, |
69 | FW_FEATURE_PS3_ALWAYS = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, | 73 | FW_FEATURE_PS3_ALWAYS = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, |
70 | FW_FEATURE_CELLEB_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_BEAT, | 74 | FW_FEATURE_CELLEB_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_BEAT, |
@@ -78,6 +82,9 @@ enum { | |||
78 | #ifdef CONFIG_PPC_ISERIES | 82 | #ifdef CONFIG_PPC_ISERIES |
79 | FW_FEATURE_ISERIES_POSSIBLE | | 83 | FW_FEATURE_ISERIES_POSSIBLE | |
80 | #endif | 84 | #endif |
85 | #ifdef CONFIG_PPC_POWERNV | ||
86 | FW_FEATURE_POWERNV_POSSIBLE | | ||
87 | #endif | ||
81 | #ifdef CONFIG_PPC_PS3 | 88 | #ifdef CONFIG_PPC_PS3 |
82 | FW_FEATURE_PS3_POSSIBLE | | 89 | FW_FEATURE_PS3_POSSIBLE | |
83 | #endif | 90 | #endif |
@@ -95,6 +102,9 @@ enum { | |||
95 | #ifdef CONFIG_PPC_ISERIES | 102 | #ifdef CONFIG_PPC_ISERIES |
96 | FW_FEATURE_ISERIES_ALWAYS & | 103 | FW_FEATURE_ISERIES_ALWAYS & |
97 | #endif | 104 | #endif |
105 | #ifdef CONFIG_PPC_POWERNV | ||
106 | FW_FEATURE_POWERNV_ALWAYS & | ||
107 | #endif | ||
98 | #ifdef CONFIG_PPC_PS3 | 108 | #ifdef CONFIG_PPC_PS3 |
99 | FW_FEATURE_PS3_ALWAYS & | 109 | FW_FEATURE_PS3_ALWAYS & |
100 | #endif | 110 | #endif |
diff --git a/arch/powerpc/include/asm/hugetlb.h b/arch/powerpc/include/asm/hugetlb.h index 5856a66ab40..86004930a78 100644 --- a/arch/powerpc/include/asm/hugetlb.h +++ b/arch/powerpc/include/asm/hugetlb.h | |||
@@ -1,15 +1,60 @@ | |||
1 | #ifndef _ASM_POWERPC_HUGETLB_H | 1 | #ifndef _ASM_POWERPC_HUGETLB_H |
2 | #define _ASM_POWERPC_HUGETLB_H | 2 | #define _ASM_POWERPC_HUGETLB_H |
3 | 3 | ||
4 | #ifdef CONFIG_HUGETLB_PAGE | ||
4 | #include <asm/page.h> | 5 | #include <asm/page.h> |
5 | 6 | ||
7 | extern struct kmem_cache *hugepte_cache; | ||
8 | extern void __init reserve_hugetlb_gpages(void); | ||
9 | |||
10 | static inline pte_t *hugepd_page(hugepd_t hpd) | ||
11 | { | ||
12 | BUG_ON(!hugepd_ok(hpd)); | ||
13 | return (pte_t *)((hpd.pd & ~HUGEPD_SHIFT_MASK) | PD_HUGE); | ||
14 | } | ||
15 | |||
16 | static inline unsigned int hugepd_shift(hugepd_t hpd) | ||
17 | { | ||
18 | return hpd.pd & HUGEPD_SHIFT_MASK; | ||
19 | } | ||
20 | |||
21 | static inline pte_t *hugepte_offset(hugepd_t *hpdp, unsigned long addr, | ||
22 | unsigned pdshift) | ||
23 | { | ||
24 | /* | ||
25 | * On 32-bit, we have multiple higher-level table entries that point to | ||
26 | * the same hugepte. Just use the first one since they're all | ||
27 | * identical. So for that case, idx=0. | ||
28 | */ | ||
29 | unsigned long idx = 0; | ||
30 | |||
31 | pte_t *dir = hugepd_page(*hpdp); | ||
32 | #ifdef CONFIG_PPC64 | ||
33 | idx = (addr & ((1UL << pdshift) - 1)) >> hugepd_shift(*hpdp); | ||
34 | #endif | ||
35 | |||
36 | return dir + idx; | ||
37 | } | ||
38 | |||
6 | pte_t *huge_pte_offset_and_shift(struct mm_struct *mm, | 39 | pte_t *huge_pte_offset_and_shift(struct mm_struct *mm, |
7 | unsigned long addr, unsigned *shift); | 40 | unsigned long addr, unsigned *shift); |
8 | 41 | ||
9 | void flush_dcache_icache_hugepage(struct page *page); | 42 | void flush_dcache_icache_hugepage(struct page *page); |
10 | 43 | ||
44 | #if defined(CONFIG_PPC_MM_SLICES) || defined(CONFIG_PPC_SUBPAGE_PROT) | ||
11 | int is_hugepage_only_range(struct mm_struct *mm, unsigned long addr, | 45 | int is_hugepage_only_range(struct mm_struct *mm, unsigned long addr, |
12 | unsigned long len); | 46 | unsigned long len); |
47 | #else | ||
48 | static inline int is_hugepage_only_range(struct mm_struct *mm, | ||
49 | unsigned long addr, | ||
50 | unsigned long len) | ||
51 | { | ||
52 | return 0; | ||
53 | } | ||
54 | #endif | ||
55 | |||
56 | void book3e_hugetlb_preload(struct mm_struct *mm, unsigned long ea, pte_t pte); | ||
57 | void flush_hugetlb_page(struct vm_area_struct *vma, unsigned long vmaddr); | ||
13 | 58 | ||
14 | void hugetlb_free_pgd_range(struct mmu_gather *tlb, unsigned long addr, | 59 | void hugetlb_free_pgd_range(struct mmu_gather *tlb, unsigned long addr, |
15 | unsigned long end, unsigned long floor, | 60 | unsigned long end, unsigned long floor, |
@@ -50,8 +95,11 @@ static inline void set_huge_pte_at(struct mm_struct *mm, unsigned long addr, | |||
50 | static inline pte_t huge_ptep_get_and_clear(struct mm_struct *mm, | 95 | static inline pte_t huge_ptep_get_and_clear(struct mm_struct *mm, |
51 | unsigned long addr, pte_t *ptep) | 96 | unsigned long addr, pte_t *ptep) |
52 | { | 97 | { |
53 | unsigned long old = pte_update(mm, addr, ptep, ~0UL, 1); | 98 | #ifdef CONFIG_PPC64 |
54 | return __pte(old); | 99 | return __pte(pte_update(mm, addr, ptep, ~0UL, 1)); |
100 | #else | ||
101 | return __pte(pte_update(ptep, ~0UL, 0)); | ||
102 | #endif | ||
55 | } | 103 | } |
56 | 104 | ||
57 | static inline void huge_ptep_clear_flush(struct vm_area_struct *vma, | 105 | static inline void huge_ptep_clear_flush(struct vm_area_struct *vma, |
@@ -93,4 +141,15 @@ static inline void arch_release_hugepage(struct page *page) | |||
93 | { | 141 | { |
94 | } | 142 | } |
95 | 143 | ||
144 | #else /* ! CONFIG_HUGETLB_PAGE */ | ||
145 | static inline void reserve_hugetlb_gpages(void) | ||
146 | { | ||
147 | pr_err("Cannot reserve gpages without hugetlb enabled\n"); | ||
148 | } | ||
149 | static inline void flush_hugetlb_page(struct vm_area_struct *vma, | ||
150 | unsigned long vmaddr) | ||
151 | { | ||
152 | } | ||
153 | #endif | ||
154 | |||
96 | #endif /* _ASM_POWERPC_HUGETLB_H */ | 155 | #endif /* _ASM_POWERPC_HUGETLB_H */ |
diff --git a/arch/powerpc/include/asm/kexec.h b/arch/powerpc/include/asm/kexec.h index 8a33698c61b..f921eb121d3 100644 --- a/arch/powerpc/include/asm/kexec.h +++ b/arch/powerpc/include/asm/kexec.h | |||
@@ -2,7 +2,7 @@ | |||
2 | #define _ASM_POWERPC_KEXEC_H | 2 | #define _ASM_POWERPC_KEXEC_H |
3 | #ifdef __KERNEL__ | 3 | #ifdef __KERNEL__ |
4 | 4 | ||
5 | #ifdef CONFIG_FSL_BOOKE | 5 | #if defined(CONFIG_FSL_BOOKE) || defined(CONFIG_44x) |
6 | 6 | ||
7 | /* | 7 | /* |
8 | * On FSL-BookE we setup a 1:1 mapping which covers the first 2GiB of memory | 8 | * On FSL-BookE we setup a 1:1 mapping which covers the first 2GiB of memory |
diff --git a/arch/powerpc/include/asm/machdep.h b/arch/powerpc/include/asm/machdep.h index 47cacddb14c..58fc2162301 100644 --- a/arch/powerpc/include/asm/machdep.h +++ b/arch/powerpc/include/asm/machdep.h | |||
@@ -85,8 +85,9 @@ struct machdep_calls { | |||
85 | void (*pci_dma_dev_setup)(struct pci_dev *dev); | 85 | void (*pci_dma_dev_setup)(struct pci_dev *dev); |
86 | void (*pci_dma_bus_setup)(struct pci_bus *bus); | 86 | void (*pci_dma_bus_setup)(struct pci_bus *bus); |
87 | 87 | ||
88 | /* Platform set_dma_mask override */ | 88 | /* Platform set_dma_mask and dma_get_required_mask overrides */ |
89 | int (*dma_set_mask)(struct device *dev, u64 dma_mask); | 89 | int (*dma_set_mask)(struct device *dev, u64 dma_mask); |
90 | u64 (*dma_get_required_mask)(struct device *dev); | ||
90 | 91 | ||
91 | int (*probe)(void); | 92 | int (*probe)(void); |
92 | void (*setup_arch)(void); /* Optional, may be NULL */ | 93 | void (*setup_arch)(void); /* Optional, may be NULL */ |
diff --git a/arch/powerpc/include/asm/mmu-book3e.h b/arch/powerpc/include/asm/mmu-book3e.h index 3ea0f9a259d..0260ea5ec3c 100644 --- a/arch/powerpc/include/asm/mmu-book3e.h +++ b/arch/powerpc/include/asm/mmu-book3e.h | |||
@@ -66,6 +66,7 @@ | |||
66 | #define MAS2_M 0x00000004 | 66 | #define MAS2_M 0x00000004 |
67 | #define MAS2_G 0x00000002 | 67 | #define MAS2_G 0x00000002 |
68 | #define MAS2_E 0x00000001 | 68 | #define MAS2_E 0x00000001 |
69 | #define MAS2_WIMGE_MASK 0x0000001f | ||
69 | #define MAS2_EPN_MASK(size) (~0 << (size + 10)) | 70 | #define MAS2_EPN_MASK(size) (~0 << (size + 10)) |
70 | #define MAS2_VAL(addr, size, flags) ((addr) & MAS2_EPN_MASK(size) | (flags)) | 71 | #define MAS2_VAL(addr, size, flags) ((addr) & MAS2_EPN_MASK(size) | (flags)) |
71 | 72 | ||
@@ -80,6 +81,7 @@ | |||
80 | #define MAS3_SW 0x00000004 | 81 | #define MAS3_SW 0x00000004 |
81 | #define MAS3_UR 0x00000002 | 82 | #define MAS3_UR 0x00000002 |
82 | #define MAS3_SR 0x00000001 | 83 | #define MAS3_SR 0x00000001 |
84 | #define MAS3_BAP_MASK 0x0000003f | ||
83 | #define MAS3_SPSIZE 0x0000003e | 85 | #define MAS3_SPSIZE 0x0000003e |
84 | #define MAS3_SPSIZE_SHIFT 1 | 86 | #define MAS3_SPSIZE_SHIFT 1 |
85 | 87 | ||
@@ -212,6 +214,11 @@ typedef struct { | |||
212 | unsigned int id; | 214 | unsigned int id; |
213 | unsigned int active; | 215 | unsigned int active; |
214 | unsigned long vdso_base; | 216 | unsigned long vdso_base; |
217 | #ifdef CONFIG_PPC_MM_SLICES | ||
218 | u64 low_slices_psize; /* SLB page size encodings */ | ||
219 | u64 high_slices_psize; /* 4 bits per slice for now */ | ||
220 | u16 user_psize; /* page size index */ | ||
221 | #endif | ||
215 | } mm_context_t; | 222 | } mm_context_t; |
216 | 223 | ||
217 | /* Page size definitions, common between 32 and 64-bit | 224 | /* Page size definitions, common between 32 and 64-bit |
diff --git a/arch/powerpc/include/asm/mmu-hash64.h b/arch/powerpc/include/asm/mmu-hash64.h index b445e0af4c2..db645ec842b 100644 --- a/arch/powerpc/include/asm/mmu-hash64.h +++ b/arch/powerpc/include/asm/mmu-hash64.h | |||
@@ -262,8 +262,7 @@ extern void hash_failure_debug(unsigned long ea, unsigned long access, | |||
262 | extern int htab_bolt_mapping(unsigned long vstart, unsigned long vend, | 262 | extern int htab_bolt_mapping(unsigned long vstart, unsigned long vend, |
263 | unsigned long pstart, unsigned long prot, | 263 | unsigned long pstart, unsigned long prot, |
264 | int psize, int ssize); | 264 | int psize, int ssize); |
265 | extern void add_gpage(unsigned long addr, unsigned long page_size, | 265 | extern void add_gpage(u64 addr, u64 page_size, unsigned long number_of_pages); |
266 | unsigned long number_of_pages); | ||
267 | extern void demote_segment_4k(struct mm_struct *mm, unsigned long addr); | 266 | extern void demote_segment_4k(struct mm_struct *mm, unsigned long addr); |
268 | 267 | ||
269 | extern void hpte_init_native(void); | 268 | extern void hpte_init_native(void); |
diff --git a/arch/powerpc/include/asm/mmu.h b/arch/powerpc/include/asm/mmu.h index 698b3063868..f0145522cfb 100644 --- a/arch/powerpc/include/asm/mmu.h +++ b/arch/powerpc/include/asm/mmu.h | |||
@@ -175,14 +175,16 @@ extern u64 ppc64_rma_size; | |||
175 | #define MMU_PAGE_64K_AP 3 /* "Admixed pages" (hash64 only) */ | 175 | #define MMU_PAGE_64K_AP 3 /* "Admixed pages" (hash64 only) */ |
176 | #define MMU_PAGE_256K 4 | 176 | #define MMU_PAGE_256K 4 |
177 | #define MMU_PAGE_1M 5 | 177 | #define MMU_PAGE_1M 5 |
178 | #define MMU_PAGE_8M 6 | 178 | #define MMU_PAGE_4M 6 |
179 | #define MMU_PAGE_16M 7 | 179 | #define MMU_PAGE_8M 7 |
180 | #define MMU_PAGE_256M 8 | 180 | #define MMU_PAGE_16M 8 |
181 | #define MMU_PAGE_1G 9 | 181 | #define MMU_PAGE_64M 9 |
182 | #define MMU_PAGE_16G 10 | 182 | #define MMU_PAGE_256M 10 |
183 | #define MMU_PAGE_64G 11 | 183 | #define MMU_PAGE_1G 11 |
184 | #define MMU_PAGE_COUNT 12 | 184 | #define MMU_PAGE_16G 12 |
185 | 185 | #define MMU_PAGE_64G 13 | |
186 | |||
187 | #define MMU_PAGE_COUNT 14 | ||
186 | 188 | ||
187 | #if defined(CONFIG_PPC_STD_MMU_64) | 189 | #if defined(CONFIG_PPC_STD_MMU_64) |
188 | /* 64-bit classic hash table MMU */ | 190 | /* 64-bit classic hash table MMU */ |
diff --git a/arch/powerpc/include/asm/mpic.h b/arch/powerpc/include/asm/mpic.h index df18989e78d..e6fae49e0b7 100644 --- a/arch/powerpc/include/asm/mpic.h +++ b/arch/powerpc/include/asm/mpic.h | |||
@@ -273,8 +273,6 @@ struct mpic | |||
273 | unsigned int irq_count; | 273 | unsigned int irq_count; |
274 | /* Number of sources */ | 274 | /* Number of sources */ |
275 | unsigned int num_sources; | 275 | unsigned int num_sources; |
276 | /* Number of CPUs */ | ||
277 | unsigned int num_cpus; | ||
278 | /* default senses array */ | 276 | /* default senses array */ |
279 | unsigned char *senses; | 277 | unsigned char *senses; |
280 | unsigned int senses_count; | 278 | unsigned int senses_count; |
diff --git a/arch/powerpc/include/asm/opal.h b/arch/powerpc/include/asm/opal.h new file mode 100644 index 00000000000..2893e8f5406 --- /dev/null +++ b/arch/powerpc/include/asm/opal.h | |||
@@ -0,0 +1,443 @@ | |||
1 | /* | ||
2 | * PowerNV OPAL definitions. | ||
3 | * | ||
4 | * Copyright 2011 IBM Corp. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License | ||
8 | * as published by the Free Software Foundation; either version | ||
9 | * 2 of the License, or (at your option) any later version. | ||
10 | */ | ||
11 | |||
12 | #ifndef __OPAL_H | ||
13 | #define __OPAL_H | ||
14 | |||
15 | /****** Takeover interface ********/ | ||
16 | |||
17 | /* PAPR H-Call used to querty the HAL existence and/or instanciate | ||
18 | * it from within pHyp (tech preview only). | ||
19 | * | ||
20 | * This is exclusively used in prom_init.c | ||
21 | */ | ||
22 | |||
23 | #ifndef __ASSEMBLY__ | ||
24 | |||
25 | struct opal_takeover_args { | ||
26 | u64 k_image; /* r4 */ | ||
27 | u64 k_size; /* r5 */ | ||
28 | u64 k_entry; /* r6 */ | ||
29 | u64 k_entry2; /* r7 */ | ||
30 | u64 hal_addr; /* r8 */ | ||
31 | u64 rd_image; /* r9 */ | ||
32 | u64 rd_size; /* r10 */ | ||
33 | u64 rd_loc; /* r11 */ | ||
34 | }; | ||
35 | |||
36 | extern long opal_query_takeover(u64 *hal_size, u64 *hal_align); | ||
37 | |||
38 | extern long opal_do_takeover(struct opal_takeover_args *args); | ||
39 | |||
40 | struct rtas_args; | ||
41 | extern int opal_enter_rtas(struct rtas_args *args, | ||
42 | unsigned long data, | ||
43 | unsigned long entry); | ||
44 | |||
45 | #endif /* __ASSEMBLY__ */ | ||
46 | |||
47 | /****** OPAL APIs ******/ | ||
48 | |||
49 | /* Return codes */ | ||
50 | #define OPAL_SUCCESS 0 | ||
51 | #define OPAL_PARAMETER -1 | ||
52 | #define OPAL_BUSY -2 | ||
53 | #define OPAL_PARTIAL -3 | ||
54 | #define OPAL_CONSTRAINED -4 | ||
55 | #define OPAL_CLOSED -5 | ||
56 | #define OPAL_HARDWARE -6 | ||
57 | #define OPAL_UNSUPPORTED -7 | ||
58 | #define OPAL_PERMISSION -8 | ||
59 | #define OPAL_NO_MEM -9 | ||
60 | #define OPAL_RESOURCE -10 | ||
61 | #define OPAL_INTERNAL_ERROR -11 | ||
62 | #define OPAL_BUSY_EVENT -12 | ||
63 | #define OPAL_HARDWARE_FROZEN -13 | ||
64 | |||
65 | /* API Tokens (in r0) */ | ||
66 | #define OPAL_CONSOLE_WRITE 1 | ||
67 | #define OPAL_CONSOLE_READ 2 | ||
68 | #define OPAL_RTC_READ 3 | ||
69 | #define OPAL_RTC_WRITE 4 | ||
70 | #define OPAL_CEC_POWER_DOWN 5 | ||
71 | #define OPAL_CEC_REBOOT 6 | ||
72 | #define OPAL_READ_NVRAM 7 | ||
73 | #define OPAL_WRITE_NVRAM 8 | ||
74 | #define OPAL_HANDLE_INTERRUPT 9 | ||
75 | #define OPAL_POLL_EVENTS 10 | ||
76 | #define OPAL_PCI_SET_HUB_TCE_MEMORY 11 | ||
77 | #define OPAL_PCI_SET_PHB_TCE_MEMORY 12 | ||
78 | #define OPAL_PCI_CONFIG_READ_BYTE 13 | ||
79 | #define OPAL_PCI_CONFIG_READ_HALF_WORD 14 | ||
80 | #define OPAL_PCI_CONFIG_READ_WORD 15 | ||
81 | #define OPAL_PCI_CONFIG_WRITE_BYTE 16 | ||
82 | #define OPAL_PCI_CONFIG_WRITE_HALF_WORD 17 | ||
83 | #define OPAL_PCI_CONFIG_WRITE_WORD 18 | ||
84 | #define OPAL_SET_XIVE 19 | ||
85 | #define OPAL_GET_XIVE 20 | ||
86 | #define OPAL_GET_COMPLETION_TOKEN_STATUS 21 /* obsolete */ | ||
87 | #define OPAL_REGISTER_OPAL_EXCEPTION_HANDLER 22 | ||
88 | #define OPAL_PCI_EEH_FREEZE_STATUS 23 | ||
89 | #define OPAL_PCI_SHPC 24 | ||
90 | #define OPAL_CONSOLE_WRITE_BUFFER_SPACE 25 | ||
91 | #define OPAL_PCI_EEH_FREEZE_CLEAR 26 | ||
92 | #define OPAL_PCI_PHB_MMIO_ENABLE 27 | ||
93 | #define OPAL_PCI_SET_PHB_MEM_WINDOW 28 | ||
94 | #define OPAL_PCI_MAP_PE_MMIO_WINDOW 29 | ||
95 | #define OPAL_PCI_SET_PHB_TABLE_MEMORY 30 | ||
96 | #define OPAL_PCI_SET_PE 31 | ||
97 | #define OPAL_PCI_SET_PELTV 32 | ||
98 | #define OPAL_PCI_SET_MVE 33 | ||
99 | #define OPAL_PCI_SET_MVE_ENABLE 34 | ||
100 | #define OPAL_PCI_GET_XIVE_REISSUE 35 | ||
101 | #define OPAL_PCI_SET_XIVE_REISSUE 36 | ||
102 | #define OPAL_PCI_SET_XIVE_PE 37 | ||
103 | #define OPAL_GET_XIVE_SOURCE 38 | ||
104 | #define OPAL_GET_MSI_32 39 | ||
105 | #define OPAL_GET_MSI_64 40 | ||
106 | #define OPAL_START_CPU 41 | ||
107 | #define OPAL_QUERY_CPU_STATUS 42 | ||
108 | #define OPAL_WRITE_OPPANEL 43 | ||
109 | #define OPAL_PCI_MAP_PE_DMA_WINDOW 44 | ||
110 | #define OPAL_PCI_MAP_PE_DMA_WINDOW_REAL 45 | ||
111 | #define OPAL_PCI_RESET 49 | ||
112 | |||
113 | #ifndef __ASSEMBLY__ | ||
114 | |||
115 | /* Other enums */ | ||
116 | enum OpalVendorApiTokens { | ||
117 | OPAL_START_VENDOR_API_RANGE = 1000, OPAL_END_VENDOR_API_RANGE = 1999 | ||
118 | }; | ||
119 | enum OpalFreezeState { | ||
120 | OPAL_EEH_STOPPED_NOT_FROZEN = 0, | ||
121 | OPAL_EEH_STOPPED_MMIO_FREEZE = 1, | ||
122 | OPAL_EEH_STOPPED_DMA_FREEZE = 2, | ||
123 | OPAL_EEH_STOPPED_MMIO_DMA_FREEZE = 3, | ||
124 | OPAL_EEH_STOPPED_RESET = 4, | ||
125 | OPAL_EEH_STOPPED_TEMP_UNAVAIL = 5, | ||
126 | OPAL_EEH_STOPPED_PERM_UNAVAIL = 6 | ||
127 | }; | ||
128 | enum OpalEehFreezeActionToken { | ||
129 | OPAL_EEH_ACTION_CLEAR_FREEZE_MMIO = 1, | ||
130 | OPAL_EEH_ACTION_CLEAR_FREEZE_DMA = 2, | ||
131 | OPAL_EEH_ACTION_CLEAR_FREEZE_ALL = 3 | ||
132 | }; | ||
133 | enum OpalPciStatusToken { | ||
134 | OPAL_EEH_PHB_NO_ERROR = 0, | ||
135 | OPAL_EEH_PHB_FATAL = 1, | ||
136 | OPAL_EEH_PHB_RECOVERABLE = 2, | ||
137 | OPAL_EEH_PHB_BUS_ERROR = 3, | ||
138 | OPAL_EEH_PCI_NO_DEVSEL = 4, | ||
139 | OPAL_EEH_PCI_TA = 5, | ||
140 | OPAL_EEH_PCIEX_UR = 6, | ||
141 | OPAL_EEH_PCIEX_CA = 7, | ||
142 | OPAL_EEH_PCI_MMIO_ERROR = 8, | ||
143 | OPAL_EEH_PCI_DMA_ERROR = 9 | ||
144 | }; | ||
145 | enum OpalShpcAction { | ||
146 | OPAL_SHPC_GET_LINK_STATE = 0, | ||
147 | OPAL_SHPC_GET_SLOT_STATE = 1 | ||
148 | }; | ||
149 | enum OpalShpcLinkState { | ||
150 | OPAL_SHPC_LINK_DOWN = 0, | ||
151 | OPAL_SHPC_LINK_UP = 1 | ||
152 | }; | ||
153 | enum OpalMmioWindowType { | ||
154 | OPAL_M32_WINDOW_TYPE = 1, | ||
155 | OPAL_M64_WINDOW_TYPE = 2, | ||
156 | OPAL_IO_WINDOW_TYPE = 3 | ||
157 | }; | ||
158 | enum OpalShpcSlotState { | ||
159 | OPAL_SHPC_DEV_NOT_PRESENT = 0, | ||
160 | OPAL_SHPC_DEV_PRESENT = 1 | ||
161 | }; | ||
162 | enum OpalExceptionHandler { | ||
163 | OPAL_MACHINE_CHECK_HANDLER = 1, | ||
164 | OPAL_HYPERVISOR_MAINTENANCE_HANDLER = 2, | ||
165 | OPAL_SOFTPATCH_HANDLER = 3 | ||
166 | }; | ||
167 | enum OpalPendingState { | ||
168 | OPAL_EVENT_OPAL_INTERNAL = 0x1, | ||
169 | OPAL_EVENT_NVRAM = 0x2, | ||
170 | OPAL_EVENT_RTC = 0x4, | ||
171 | OPAL_EVENT_CONSOLE_OUTPUT = 0x8, | ||
172 | OPAL_EVENT_CONSOLE_INPUT = 0x10 | ||
173 | }; | ||
174 | |||
175 | /* Machine check related definitions */ | ||
176 | enum OpalMCE_Version { | ||
177 | OpalMCE_V1 = 1, | ||
178 | }; | ||
179 | |||
180 | enum OpalMCE_Severity { | ||
181 | OpalMCE_SEV_NO_ERROR = 0, | ||
182 | OpalMCE_SEV_WARNING = 1, | ||
183 | OpalMCE_SEV_ERROR_SYNC = 2, | ||
184 | OpalMCE_SEV_FATAL = 3, | ||
185 | }; | ||
186 | |||
187 | enum OpalMCE_Disposition { | ||
188 | OpalMCE_DISPOSITION_RECOVERED = 0, | ||
189 | OpalMCE_DISPOSITION_NOT_RECOVERED = 1, | ||
190 | }; | ||
191 | |||
192 | enum OpalMCE_Initiator { | ||
193 | OpalMCE_INITIATOR_UNKNOWN = 0, | ||
194 | OpalMCE_INITIATOR_CPU = 1, | ||
195 | }; | ||
196 | |||
197 | enum OpalMCE_ErrorType { | ||
198 | OpalMCE_ERROR_TYPE_UNKNOWN = 0, | ||
199 | OpalMCE_ERROR_TYPE_UE = 1, | ||
200 | OpalMCE_ERROR_TYPE_SLB = 2, | ||
201 | OpalMCE_ERROR_TYPE_ERAT = 3, | ||
202 | OpalMCE_ERROR_TYPE_TLB = 4, | ||
203 | }; | ||
204 | |||
205 | enum OpalMCE_UeErrorType { | ||
206 | OpalMCE_UE_ERROR_INDETERMINATE = 0, | ||
207 | OpalMCE_UE_ERROR_IFETCH = 1, | ||
208 | OpalMCE_UE_ERROR_PAGE_TABLE_WALK_IFETCH = 2, | ||
209 | OpalMCE_UE_ERROR_LOAD_STORE = 3, | ||
210 | OpalMCE_UE_ERROR_PAGE_TABLE_WALK_LOAD_STORE = 4, | ||
211 | }; | ||
212 | |||
213 | enum OpalMCE_SlbErrorType { | ||
214 | OpalMCE_SLB_ERROR_INDETERMINATE = 0, | ||
215 | OpalMCE_SLB_ERROR_PARITY = 1, | ||
216 | OpalMCE_SLB_ERROR_MULTIHIT = 2, | ||
217 | }; | ||
218 | |||
219 | enum OpalMCE_EratErrorType { | ||
220 | OpalMCE_ERAT_ERROR_INDETERMINATE = 0, | ||
221 | OpalMCE_ERAT_ERROR_PARITY = 1, | ||
222 | OpalMCE_ERAT_ERROR_MULTIHIT = 2, | ||
223 | }; | ||
224 | |||
225 | enum OpalMCE_TlbErrorType { | ||
226 | OpalMCE_TLB_ERROR_INDETERMINATE = 0, | ||
227 | OpalMCE_TLB_ERROR_PARITY = 1, | ||
228 | OpalMCE_TLB_ERROR_MULTIHIT = 2, | ||
229 | }; | ||
230 | |||
231 | enum OpalThreadStatus { | ||
232 | OPAL_THREAD_INACTIVE = 0x0, | ||
233 | OPAL_THREAD_STARTED = 0x1 | ||
234 | }; | ||
235 | |||
236 | enum OpalPciBusCompare { | ||
237 | OpalPciBusAny = 0, /* Any bus number match */ | ||
238 | OpalPciBus3Bits = 2, /* Match top 3 bits of bus number */ | ||
239 | OpalPciBus4Bits = 3, /* Match top 4 bits of bus number */ | ||
240 | OpalPciBus5Bits = 4, /* Match top 5 bits of bus number */ | ||
241 | OpalPciBus6Bits = 5, /* Match top 6 bits of bus number */ | ||
242 | OpalPciBus7Bits = 6, /* Match top 7 bits of bus number */ | ||
243 | OpalPciBusAll = 7, /* Match bus number exactly */ | ||
244 | }; | ||
245 | |||
246 | enum OpalDeviceCompare { | ||
247 | OPAL_IGNORE_RID_DEVICE_NUMBER = 0, | ||
248 | OPAL_COMPARE_RID_DEVICE_NUMBER = 1 | ||
249 | }; | ||
250 | |||
251 | enum OpalFuncCompare { | ||
252 | OPAL_IGNORE_RID_FUNCTION_NUMBER = 0, | ||
253 | OPAL_COMPARE_RID_FUNCTION_NUMBER = 1 | ||
254 | }; | ||
255 | |||
256 | enum OpalPeAction { | ||
257 | OPAL_UNMAP_PE = 0, | ||
258 | OPAL_MAP_PE = 1 | ||
259 | }; | ||
260 | |||
261 | enum OpalPciResetAndReinitScope { | ||
262 | OPAL_PHB_COMPLETE = 1, OPAL_PCI_LINK = 2, OPAL_PHB_ERROR = 3, | ||
263 | OPAL_PCI_HOT_RESET = 4, OPAL_PCI_FUNDAMENTAL_RESET = 5, | ||
264 | OPAL_PCI_IODA_RESET = 6, | ||
265 | }; | ||
266 | |||
267 | enum OpalPciResetState { OPAL_DEASSERT_RESET = 0, OPAL_ASSERT_RESET = 1 }; | ||
268 | |||
269 | struct opal_machine_check_event { | ||
270 | enum OpalMCE_Version version:8; /* 0x00 */ | ||
271 | uint8_t in_use; /* 0x01 */ | ||
272 | enum OpalMCE_Severity severity:8; /* 0x02 */ | ||
273 | enum OpalMCE_Initiator initiator:8; /* 0x03 */ | ||
274 | enum OpalMCE_ErrorType error_type:8; /* 0x04 */ | ||
275 | enum OpalMCE_Disposition disposition:8; /* 0x05 */ | ||
276 | uint8_t reserved_1[2]; /* 0x06 */ | ||
277 | uint64_t gpr3; /* 0x08 */ | ||
278 | uint64_t srr0; /* 0x10 */ | ||
279 | uint64_t srr1; /* 0x18 */ | ||
280 | union { /* 0x20 */ | ||
281 | struct { | ||
282 | enum OpalMCE_UeErrorType ue_error_type:8; | ||
283 | uint8_t effective_address_provided; | ||
284 | uint8_t physical_address_provided; | ||
285 | uint8_t reserved_1[5]; | ||
286 | uint64_t effective_address; | ||
287 | uint64_t physical_address; | ||
288 | uint8_t reserved_2[8]; | ||
289 | } ue_error; | ||
290 | |||
291 | struct { | ||
292 | enum OpalMCE_SlbErrorType slb_error_type:8; | ||
293 | uint8_t effective_address_provided; | ||
294 | uint8_t reserved_1[6]; | ||
295 | uint64_t effective_address; | ||
296 | uint8_t reserved_2[16]; | ||
297 | } slb_error; | ||
298 | |||
299 | struct { | ||
300 | enum OpalMCE_EratErrorType erat_error_type:8; | ||
301 | uint8_t effective_address_provided; | ||
302 | uint8_t reserved_1[6]; | ||
303 | uint64_t effective_address; | ||
304 | uint8_t reserved_2[16]; | ||
305 | } erat_error; | ||
306 | |||
307 | struct { | ||
308 | enum OpalMCE_TlbErrorType tlb_error_type:8; | ||
309 | uint8_t effective_address_provided; | ||
310 | uint8_t reserved_1[6]; | ||
311 | uint64_t effective_address; | ||
312 | uint8_t reserved_2[16]; | ||
313 | } tlb_error; | ||
314 | } u; | ||
315 | }; | ||
316 | |||
317 | typedef struct oppanel_line { | ||
318 | /* XXX */ | ||
319 | } oppanel_line_t; | ||
320 | |||
321 | /* API functions */ | ||
322 | int64_t opal_console_write(int64_t term_number, int64_t *length, | ||
323 | const uint8_t *buffer); | ||
324 | int64_t opal_console_read(int64_t term_number, int64_t *length, | ||
325 | uint8_t *buffer); | ||
326 | int64_t opal_console_write_buffer_space(int64_t term_number, | ||
327 | int64_t *length); | ||
328 | int64_t opal_rtc_read(uint32_t *year_month_day, | ||
329 | uint64_t *hour_minute_second_millisecond); | ||
330 | int64_t opal_rtc_write(uint32_t year_month_day, | ||
331 | uint64_t hour_minute_second_millisecond); | ||
332 | int64_t opal_cec_power_down(uint64_t request); | ||
333 | int64_t opal_cec_reboot(void); | ||
334 | int64_t opal_read_nvram(uint64_t buffer, uint64_t size, uint64_t offset); | ||
335 | int64_t opal_write_nvram(uint64_t buffer, uint64_t size, uint64_t offset); | ||
336 | int64_t opal_handle_interrupt(uint64_t isn, uint64_t *outstanding_event_mask); | ||
337 | int64_t opal_poll_events(uint64_t *outstanding_event_mask); | ||
338 | int64_t opal_pci_set_hub_tce_memory(uint64_t hub_id, uint64_t tce_mem_addr, | ||
339 | uint64_t tce_mem_size); | ||
340 | int64_t opal_pci_set_phb_tce_memory(uint64_t phb_id, uint64_t tce_mem_addr, | ||
341 | uint64_t tce_mem_size); | ||
342 | int64_t opal_pci_config_read_byte(uint64_t phb_id, uint64_t bus_dev_func, | ||
343 | uint64_t offset, uint8_t *data); | ||
344 | int64_t opal_pci_config_read_half_word(uint64_t phb_id, uint64_t bus_dev_func, | ||
345 | uint64_t offset, uint16_t *data); | ||
346 | int64_t opal_pci_config_read_word(uint64_t phb_id, uint64_t bus_dev_func, | ||
347 | uint64_t offset, uint32_t *data); | ||
348 | int64_t opal_pci_config_write_byte(uint64_t phb_id, uint64_t bus_dev_func, | ||
349 | uint64_t offset, uint8_t data); | ||
350 | int64_t opal_pci_config_write_half_word(uint64_t phb_id, uint64_t bus_dev_func, | ||
351 | uint64_t offset, uint16_t data); | ||
352 | int64_t opal_pci_config_write_word(uint64_t phb_id, uint64_t bus_dev_func, | ||
353 | uint64_t offset, uint32_t data); | ||
354 | int64_t opal_set_xive(uint32_t isn, uint16_t server, uint8_t priority); | ||
355 | int64_t opal_get_xive(uint32_t isn, uint16_t *server, uint8_t *priority); | ||
356 | int64_t opal_register_exception_handler(uint64_t opal_exception, | ||
357 | uint64_t handler_address, | ||
358 | uint64_t glue_cache_line); | ||
359 | int64_t opal_pci_eeh_freeze_status(uint64_t phb_id, uint64_t pe_number, | ||
360 | uint8_t *freeze_state, | ||
361 | uint16_t *pci_error_type, | ||
362 | uint64_t *phb_status); | ||
363 | int64_t opal_pci_eeh_freeze_clear(uint64_t phb_id, uint64_t pe_number, | ||
364 | uint64_t eeh_action_token); | ||
365 | int64_t opal_pci_shpc(uint64_t phb_id, uint64_t shpc_action, uint8_t *state); | ||
366 | |||
367 | |||
368 | |||
369 | int64_t opal_pci_phb_mmio_enable(uint64_t phb_id, uint16_t window_type, | ||
370 | uint16_t window_num, uint16_t enable); | ||
371 | int64_t opal_pci_set_phb_mem_window(uint64_t phb_id, uint16_t window_type, | ||
372 | uint16_t window_num, | ||
373 | uint64_t starting_real_address, | ||
374 | uint64_t starting_pci_address, | ||
375 | uint16_t segment_size); | ||
376 | int64_t opal_pci_map_pe_mmio_window(uint64_t phb_id, uint16_t pe_number, | ||
377 | uint16_t window_type, uint16_t window_num, | ||
378 | uint16_t segment_num); | ||
379 | int64_t opal_pci_set_phb_table_memory(uint64_t phb_id, uint64_t rtt_addr, | ||
380 | uint64_t ivt_addr, uint64_t ivt_len, | ||
381 | uint64_t reject_array_addr, | ||
382 | uint64_t peltv_addr); | ||
383 | int64_t opal_pci_set_pe(uint64_t phb_id, uint64_t pe_number, uint64_t bus_dev_func, | ||
384 | uint8_t bus_compare, uint8_t dev_compare, uint8_t func_compare, | ||
385 | uint8_t pe_action); | ||
386 | int64_t opal_pci_set_peltv(uint64_t phb_id, uint32_t parent_pe, uint32_t child_pe, | ||
387 | uint8_t state); | ||
388 | int64_t opal_pci_set_mve(uint64_t phb_id, uint32_t mve_number, uint32_t pe_number); | ||
389 | int64_t opal_pci_set_mve_enable(uint64_t phb_id, uint32_t mve_number, | ||
390 | uint32_t state); | ||
391 | int64_t opal_pci_get_xive_reissue(uint64_t phb_id, uint32_t xive_number, | ||
392 | uint8_t *p_bit, uint8_t *q_bit); | ||
393 | int64_t opal_pci_set_xive_reissue(uint64_t phb_id, uint32_t xive_number, | ||
394 | uint8_t p_bit, uint8_t q_bit); | ||
395 | int64_t opal_pci_set_xive_pe(uint64_t phb_id, uint32_t pe_number, | ||
396 | uint32_t xive_num); | ||
397 | int64_t opal_get_xive_source(uint64_t phb_id, uint32_t xive_num, | ||
398 | int32_t *interrupt_source_number); | ||
399 | int64_t opal_get_msi_32(uint64_t phb_id, uint32_t mve_number, uint32_t xive_num, | ||
400 | uint8_t msi_range, uint32_t *msi_address, | ||
401 | uint32_t *message_data); | ||
402 | int64_t opal_get_msi_64(uint64_t phb_id, uint32_t mve_number, | ||
403 | uint32_t xive_num, uint8_t msi_range, | ||
404 | uint64_t *msi_address, uint32_t *message_data); | ||
405 | int64_t opal_start_cpu(uint64_t thread_number, uint64_t start_address); | ||
406 | int64_t opal_query_cpu_status(uint64_t thread_number, uint8_t *thread_status); | ||
407 | int64_t opal_write_oppanel(oppanel_line_t *lines, uint64_t num_lines); | ||
408 | int64_t opal_pci_map_pe_dma_window(uint64_t phb_id, uint16_t pe_number, uint16_t window_id, | ||
409 | uint16_t tce_levels, uint64_t tce_table_addr, | ||
410 | uint64_t tce_table_size, uint64_t tce_page_size); | ||
411 | int64_t opal_pci_map_pe_dma_window_real(uint64_t phb_id, uint16_t pe_number, | ||
412 | uint16_t dma_window_number, uint64_t pci_start_addr, | ||
413 | uint64_t pci_mem_size); | ||
414 | int64_t opal_pci_reset(uint64_t phb_id, uint8_t reset_scope, uint8_t assert_state); | ||
415 | |||
416 | /* Internal functions */ | ||
417 | extern int early_init_dt_scan_opal(unsigned long node, const char *uname, int depth, void *data); | ||
418 | |||
419 | extern int opal_get_chars(uint32_t vtermno, char *buf, int count); | ||
420 | extern int opal_put_chars(uint32_t vtermno, const char *buf, int total_len); | ||
421 | |||
422 | extern void hvc_opal_init_early(void); | ||
423 | |||
424 | /* Internal functions */ | ||
425 | extern int early_init_dt_scan_opal(unsigned long node, const char *uname, | ||
426 | int depth, void *data); | ||
427 | |||
428 | extern int opal_get_chars(uint32_t vtermno, char *buf, int count); | ||
429 | extern int opal_put_chars(uint32_t vtermno, const char *buf, int total_len); | ||
430 | |||
431 | extern void hvc_opal_init_early(void); | ||
432 | |||
433 | struct rtc_time; | ||
434 | extern int opal_set_rtc_time(struct rtc_time *tm); | ||
435 | extern void opal_get_rtc_time(struct rtc_time *tm); | ||
436 | extern unsigned long opal_get_boot_time(void); | ||
437 | extern void opal_nvram_init(void); | ||
438 | |||
439 | extern int opal_machine_check(struct pt_regs *regs); | ||
440 | |||
441 | #endif /* __ASSEMBLY__ */ | ||
442 | |||
443 | #endif /* __OPAL_H */ | ||
diff --git a/arch/powerpc/include/asm/paca.h b/arch/powerpc/include/asm/paca.h index 516bfb3f47d..17722c73ba2 100644 --- a/arch/powerpc/include/asm/paca.h +++ b/arch/powerpc/include/asm/paca.h | |||
@@ -43,6 +43,7 @@ extern unsigned int debug_smp_processor_id(void); /* from linux/smp.h */ | |||
43 | #define get_slb_shadow() (get_paca()->slb_shadow_ptr) | 43 | #define get_slb_shadow() (get_paca()->slb_shadow_ptr) |
44 | 44 | ||
45 | struct task_struct; | 45 | struct task_struct; |
46 | struct opal_machine_check_event; | ||
46 | 47 | ||
47 | /* | 48 | /* |
48 | * Defines the layout of the paca. | 49 | * Defines the layout of the paca. |
@@ -135,6 +136,13 @@ struct paca_struct { | |||
135 | u8 io_sync; /* writel() needs spin_unlock sync */ | 136 | u8 io_sync; /* writel() needs spin_unlock sync */ |
136 | u8 irq_work_pending; /* IRQ_WORK interrupt while soft-disable */ | 137 | u8 irq_work_pending; /* IRQ_WORK interrupt while soft-disable */ |
137 | 138 | ||
139 | #ifdef CONFIG_PPC_POWERNV | ||
140 | /* Pointer to OPAL machine check event structure set by the | ||
141 | * early exception handler for use by high level C handler | ||
142 | */ | ||
143 | struct opal_machine_check_event *opal_mc_evt; | ||
144 | #endif | ||
145 | |||
138 | /* Stuff for accurate time accounting */ | 146 | /* Stuff for accurate time accounting */ |
139 | u64 user_time; /* accumulated usermode TB ticks */ | 147 | u64 user_time; /* accumulated usermode TB ticks */ |
140 | u64 system_time; /* accumulated system TB ticks */ | 148 | u64 system_time; /* accumulated system TB ticks */ |
diff --git a/arch/powerpc/include/asm/page.h b/arch/powerpc/include/asm/page.h index 2cd664ef0a5..dd9c4fd038e 100644 --- a/arch/powerpc/include/asm/page.h +++ b/arch/powerpc/include/asm/page.h | |||
@@ -36,6 +36,18 @@ | |||
36 | 36 | ||
37 | #define PAGE_SIZE (ASM_CONST(1) << PAGE_SHIFT) | 37 | #define PAGE_SIZE (ASM_CONST(1) << PAGE_SHIFT) |
38 | 38 | ||
39 | #ifndef __ASSEMBLY__ | ||
40 | #ifdef CONFIG_HUGETLB_PAGE | ||
41 | extern unsigned int HPAGE_SHIFT; | ||
42 | #else | ||
43 | #define HPAGE_SHIFT PAGE_SHIFT | ||
44 | #endif | ||
45 | #define HPAGE_SIZE ((1UL) << HPAGE_SHIFT) | ||
46 | #define HPAGE_MASK (~(HPAGE_SIZE - 1)) | ||
47 | #define HUGETLB_PAGE_ORDER (HPAGE_SHIFT - PAGE_SHIFT) | ||
48 | #define HUGE_MAX_HSTATE (MMU_PAGE_COUNT-1) | ||
49 | #endif | ||
50 | |||
39 | /* We do define AT_SYSINFO_EHDR but don't use the gate mechanism */ | 51 | /* We do define AT_SYSINFO_EHDR but don't use the gate mechanism */ |
40 | #define __HAVE_ARCH_GATE_AREA 1 | 52 | #define __HAVE_ARCH_GATE_AREA 1 |
41 | 53 | ||
@@ -158,6 +170,24 @@ extern phys_addr_t kernstart_addr; | |||
158 | #define is_kernel_addr(x) ((x) >= PAGE_OFFSET) | 170 | #define is_kernel_addr(x) ((x) >= PAGE_OFFSET) |
159 | #endif | 171 | #endif |
160 | 172 | ||
173 | /* | ||
174 | * Use the top bit of the higher-level page table entries to indicate whether | ||
175 | * the entries we point to contain hugepages. This works because we know that | ||
176 | * the page tables live in kernel space. If we ever decide to support having | ||
177 | * page tables at arbitrary addresses, this breaks and will have to change. | ||
178 | */ | ||
179 | #ifdef CONFIG_PPC64 | ||
180 | #define PD_HUGE 0x8000000000000000 | ||
181 | #else | ||
182 | #define PD_HUGE 0x80000000 | ||
183 | #endif | ||
184 | |||
185 | /* | ||
186 | * Some number of bits at the level of the page table that points to | ||
187 | * a hugepte are used to encode the size. This masks those bits. | ||
188 | */ | ||
189 | #define HUGEPD_SHIFT_MASK 0x3f | ||
190 | |||
161 | #ifndef __ASSEMBLY__ | 191 | #ifndef __ASSEMBLY__ |
162 | 192 | ||
163 | #undef STRICT_MM_TYPECHECKS | 193 | #undef STRICT_MM_TYPECHECKS |
@@ -243,7 +273,6 @@ typedef unsigned long pgprot_t; | |||
243 | #endif | 273 | #endif |
244 | 274 | ||
245 | typedef struct { signed long pd; } hugepd_t; | 275 | typedef struct { signed long pd; } hugepd_t; |
246 | #define HUGEPD_SHIFT_MASK 0x3f | ||
247 | 276 | ||
248 | #ifdef CONFIG_HUGETLB_PAGE | 277 | #ifdef CONFIG_HUGETLB_PAGE |
249 | static inline int hugepd_ok(hugepd_t hpd) | 278 | static inline int hugepd_ok(hugepd_t hpd) |
diff --git a/arch/powerpc/include/asm/page_64.h b/arch/powerpc/include/asm/page_64.h index 9356262fd3c..fb40ede6bc0 100644 --- a/arch/powerpc/include/asm/page_64.h +++ b/arch/powerpc/include/asm/page_64.h | |||
@@ -64,17 +64,6 @@ extern void copy_page(void *to, void *from); | |||
64 | /* Log 2 of page table size */ | 64 | /* Log 2 of page table size */ |
65 | extern u64 ppc64_pft_size; | 65 | extern u64 ppc64_pft_size; |
66 | 66 | ||
67 | /* Large pages size */ | ||
68 | #ifdef CONFIG_HUGETLB_PAGE | ||
69 | extern unsigned int HPAGE_SHIFT; | ||
70 | #else | ||
71 | #define HPAGE_SHIFT PAGE_SHIFT | ||
72 | #endif | ||
73 | #define HPAGE_SIZE ((1UL) << HPAGE_SHIFT) | ||
74 | #define HPAGE_MASK (~(HPAGE_SIZE - 1)) | ||
75 | #define HUGETLB_PAGE_ORDER (HPAGE_SHIFT - PAGE_SHIFT) | ||
76 | #define HUGE_MAX_HSTATE (MMU_PAGE_COUNT-1) | ||
77 | |||
78 | #endif /* __ASSEMBLY__ */ | 67 | #endif /* __ASSEMBLY__ */ |
79 | 68 | ||
80 | #ifdef CONFIG_PPC_MM_SLICES | 69 | #ifdef CONFIG_PPC_MM_SLICES |
diff --git a/arch/powerpc/include/asm/pte-book3e.h b/arch/powerpc/include/asm/pte-book3e.h index 082d515930a..0156702ba24 100644 --- a/arch/powerpc/include/asm/pte-book3e.h +++ b/arch/powerpc/include/asm/pte-book3e.h | |||
@@ -72,6 +72,9 @@ | |||
72 | #define PTE_RPN_SHIFT (24) | 72 | #define PTE_RPN_SHIFT (24) |
73 | #endif | 73 | #endif |
74 | 74 | ||
75 | #define PTE_WIMGE_SHIFT (19) | ||
76 | #define PTE_BAP_SHIFT (2) | ||
77 | |||
75 | /* On 32-bit, we never clear the top part of the PTE */ | 78 | /* On 32-bit, we never clear the top part of the PTE */ |
76 | #ifdef CONFIG_PPC32 | 79 | #ifdef CONFIG_PPC32 |
77 | #define _PTE_NONE_MASK 0xffffffff00000000ULL | 80 | #define _PTE_NONE_MASK 0xffffffff00000000ULL |
diff --git a/arch/powerpc/include/asm/reg_booke.h b/arch/powerpc/include/asm/reg_booke.h index 9ec0b39f9dd..28cdbd9f399 100644 --- a/arch/powerpc/include/asm/reg_booke.h +++ b/arch/powerpc/include/asm/reg_booke.h | |||
@@ -548,6 +548,9 @@ | |||
548 | #define L1CSR1_ICFI 0x00000002 /* Instr Cache Flash Invalidate */ | 548 | #define L1CSR1_ICFI 0x00000002 /* Instr Cache Flash Invalidate */ |
549 | #define L1CSR1_ICE 0x00000001 /* Instr Cache Enable */ | 549 | #define L1CSR1_ICE 0x00000001 /* Instr Cache Enable */ |
550 | 550 | ||
551 | /* Bit definitions for L1CSR2. */ | ||
552 | #define L1CSR2_DCWS 0x40000000 /* Data Cache write shadow */ | ||
553 | |||
551 | /* Bit definitions for L2CSR0. */ | 554 | /* Bit definitions for L2CSR0. */ |
552 | #define L2CSR0_L2E 0x80000000 /* L2 Cache Enable */ | 555 | #define L2CSR0_L2E 0x80000000 /* L2 Cache Enable */ |
553 | #define L2CSR0_L2PE 0x40000000 /* L2 Cache Parity/ECC Enable */ | 556 | #define L2CSR0_L2PE 0x40000000 /* L2 Cache Parity/ECC Enable */ |
diff --git a/arch/powerpc/include/asm/rtas.h b/arch/powerpc/include/asm/rtas.h index 58625d1e780..41f69ae79d4 100644 --- a/arch/powerpc/include/asm/rtas.h +++ b/arch/powerpc/include/asm/rtas.h | |||
@@ -249,10 +249,12 @@ extern void pSeries_log_error(char *buf, unsigned int err_type, int fatal); | |||
249 | #define ERR_FLAG_ALREADY_LOGGED 0x0 | 249 | #define ERR_FLAG_ALREADY_LOGGED 0x0 |
250 | #define ERR_FLAG_BOOT 0x1 /* log was pulled from NVRAM on boot */ | 250 | #define ERR_FLAG_BOOT 0x1 /* log was pulled from NVRAM on boot */ |
251 | #define ERR_TYPE_RTAS_LOG 0x2 /* from rtas event-scan */ | 251 | #define ERR_TYPE_RTAS_LOG 0x2 /* from rtas event-scan */ |
252 | #define ERR_TYPE_KERNEL_PANIC 0x4 /* from panic() */ | 252 | #define ERR_TYPE_KERNEL_PANIC 0x4 /* from die()/panic() */ |
253 | #define ERR_TYPE_KERNEL_PANIC_GZ 0x8 /* ditto, compressed */ | ||
253 | 254 | ||
254 | /* All the types and not flags */ | 255 | /* All the types and not flags */ |
255 | #define ERR_TYPE_MASK (ERR_TYPE_RTAS_LOG | ERR_TYPE_KERNEL_PANIC) | 256 | #define ERR_TYPE_MASK \ |
257 | (ERR_TYPE_RTAS_LOG | ERR_TYPE_KERNEL_PANIC | ERR_TYPE_KERNEL_PANIC_GZ) | ||
256 | 258 | ||
257 | #define RTAS_DEBUG KERN_DEBUG "RTAS: " | 259 | #define RTAS_DEBUG KERN_DEBUG "RTAS: " |
258 | 260 | ||
diff --git a/arch/powerpc/include/asm/smp.h b/arch/powerpc/include/asm/smp.h index 15a70b7f638..adba970ce91 100644 --- a/arch/powerpc/include/asm/smp.h +++ b/arch/powerpc/include/asm/smp.h | |||
@@ -65,6 +65,7 @@ int generic_cpu_disable(void); | |||
65 | void generic_cpu_die(unsigned int cpu); | 65 | void generic_cpu_die(unsigned int cpu); |
66 | void generic_mach_cpu_die(void); | 66 | void generic_mach_cpu_die(void); |
67 | void generic_set_cpu_dead(unsigned int cpu); | 67 | void generic_set_cpu_dead(unsigned int cpu); |
68 | int generic_check_cpu_restart(unsigned int cpu); | ||
68 | #endif | 69 | #endif |
69 | 70 | ||
70 | #ifdef CONFIG_PPC64 | 71 | #ifdef CONFIG_PPC64 |
diff --git a/arch/powerpc/include/asm/sparsemem.h b/arch/powerpc/include/asm/sparsemem.h index 54a47ea2c3a..0c5fa314561 100644 --- a/arch/powerpc/include/asm/sparsemem.h +++ b/arch/powerpc/include/asm/sparsemem.h | |||
@@ -16,7 +16,7 @@ | |||
16 | #endif /* CONFIG_SPARSEMEM */ | 16 | #endif /* CONFIG_SPARSEMEM */ |
17 | 17 | ||
18 | #ifdef CONFIG_MEMORY_HOTPLUG | 18 | #ifdef CONFIG_MEMORY_HOTPLUG |
19 | extern void create_section_mapping(unsigned long start, unsigned long end); | 19 | extern int create_section_mapping(unsigned long start, unsigned long end); |
20 | extern int remove_section_mapping(unsigned long start, unsigned long end); | 20 | extern int remove_section_mapping(unsigned long start, unsigned long end); |
21 | #ifdef CONFIG_NUMA | 21 | #ifdef CONFIG_NUMA |
22 | extern int hot_add_scn_to_nid(unsigned long scn_addr); | 22 | extern int hot_add_scn_to_nid(unsigned long scn_addr); |
diff --git a/arch/powerpc/include/asm/topology.h b/arch/powerpc/include/asm/topology.h index 7ef0d90defc..1e104af0848 100644 --- a/arch/powerpc/include/asm/topology.h +++ b/arch/powerpc/include/asm/topology.h | |||
@@ -19,14 +19,10 @@ struct device_node; | |||
19 | #define RECLAIM_DISTANCE 10 | 19 | #define RECLAIM_DISTANCE 10 |
20 | 20 | ||
21 | /* | 21 | /* |
22 | * Before going off node we want the VM to try and reclaim from the local | 22 | * Avoid creating an extra level of balancing (SD_ALLNODES) on the largest |
23 | * node. It does this if the remote distance is larger than RECLAIM_DISTANCE. | 23 | * POWER7 boxes which have a maximum of 32 nodes. |
24 | * With the default REMOTE_DISTANCE of 20 and the default RECLAIM_DISTANCE of | ||
25 | * 20, we never reclaim and go off node straight away. | ||
26 | * | ||
27 | * To fix this we choose a smaller value of RECLAIM_DISTANCE. | ||
28 | */ | 24 | */ |
29 | #define RECLAIM_DISTANCE 10 | 25 | #define SD_NODES_PER_DOMAIN 32 |
30 | 26 | ||
31 | #include <asm/mmzone.h> | 27 | #include <asm/mmzone.h> |
32 | 28 | ||
@@ -69,11 +65,11 @@ static inline int pcibus_to_node(struct pci_bus *bus) | |||
69 | .forkexec_idx = 0, \ | 65 | .forkexec_idx = 0, \ |
70 | \ | 66 | \ |
71 | .flags = 1*SD_LOAD_BALANCE \ | 67 | .flags = 1*SD_LOAD_BALANCE \ |
72 | | 1*SD_BALANCE_NEWIDLE \ | 68 | | 0*SD_BALANCE_NEWIDLE \ |
73 | | 1*SD_BALANCE_EXEC \ | 69 | | 1*SD_BALANCE_EXEC \ |
74 | | 1*SD_BALANCE_FORK \ | 70 | | 1*SD_BALANCE_FORK \ |
75 | | 0*SD_BALANCE_WAKE \ | 71 | | 0*SD_BALANCE_WAKE \ |
76 | | 0*SD_WAKE_AFFINE \ | 72 | | 1*SD_WAKE_AFFINE \ |
77 | | 0*SD_PREFER_LOCAL \ | 73 | | 0*SD_PREFER_LOCAL \ |
78 | | 0*SD_SHARE_CPUPOWER \ | 74 | | 0*SD_SHARE_CPUPOWER \ |
79 | | 0*SD_POWERSAVINGS_BALANCE \ | 75 | | 0*SD_POWERSAVINGS_BALANCE \ |
diff --git a/arch/powerpc/include/asm/udbg.h b/arch/powerpc/include/asm/udbg.h index 5354ae91bdd..8338aef5a4d 100644 --- a/arch/powerpc/include/asm/udbg.h +++ b/arch/powerpc/include/asm/udbg.h | |||
@@ -55,6 +55,9 @@ extern void __init udbg_init_cpm(void); | |||
55 | extern void __init udbg_init_usbgecko(void); | 55 | extern void __init udbg_init_usbgecko(void); |
56 | extern void __init udbg_init_wsp(void); | 56 | extern void __init udbg_init_wsp(void); |
57 | extern void __init udbg_init_ehv_bc(void); | 57 | extern void __init udbg_init_ehv_bc(void); |
58 | extern void __init udbg_init_ps3gelic(void); | ||
59 | extern void __init udbg_init_debug_opal_raw(void); | ||
60 | extern void __init udbg_init_debug_opal_hvsi(void); | ||
58 | 61 | ||
59 | #endif /* __KERNEL__ */ | 62 | #endif /* __KERNEL__ */ |
60 | #endif /* _ASM_POWERPC_UDBG_H */ | 63 | #endif /* _ASM_POWERPC_UDBG_H */ |
diff --git a/arch/powerpc/include/asm/xics.h b/arch/powerpc/include/asm/xics.h index b183a406201..bd6c401c0ee 100644 --- a/arch/powerpc/include/asm/xics.h +++ b/arch/powerpc/include/asm/xics.h | |||
@@ -27,10 +27,18 @@ | |||
27 | #define MAX_NUM_PRIORITIES 3 | 27 | #define MAX_NUM_PRIORITIES 3 |
28 | 28 | ||
29 | /* Native ICP */ | 29 | /* Native ICP */ |
30 | #ifdef CONFIG_PPC_ICP_NATIVE | ||
30 | extern int icp_native_init(void); | 31 | extern int icp_native_init(void); |
32 | #else | ||
33 | static inline int icp_native_init(void) { return -ENODEV; } | ||
34 | #endif | ||
31 | 35 | ||
32 | /* PAPR ICP */ | 36 | /* PAPR ICP */ |
37 | #ifdef CONFIG_PPC_ICP_HV | ||
33 | extern int icp_hv_init(void); | 38 | extern int icp_hv_init(void); |
39 | #else | ||
40 | static inline int icp_hv_init(void) { return -ENODEV; } | ||
41 | #endif | ||
34 | 42 | ||
35 | /* ICP ops */ | 43 | /* ICP ops */ |
36 | struct icp_ops { | 44 | struct icp_ops { |
@@ -51,7 +59,18 @@ extern const struct icp_ops *icp_ops; | |||
51 | extern int ics_native_init(void); | 59 | extern int ics_native_init(void); |
52 | 60 | ||
53 | /* RTAS ICS */ | 61 | /* RTAS ICS */ |
62 | #ifdef CONFIG_PPC_ICS_RTAS | ||
54 | extern int ics_rtas_init(void); | 63 | extern int ics_rtas_init(void); |
64 | #else | ||
65 | static inline int ics_rtas_init(void) { return -ENODEV; } | ||
66 | #endif | ||
67 | |||
68 | /* HAL ICS */ | ||
69 | #ifdef CONFIG_PPC_POWERNV | ||
70 | extern int ics_opal_init(void); | ||
71 | #else | ||
72 | static inline int ics_opal_init(void) { return -ENODEV; } | ||
73 | #endif | ||
55 | 74 | ||
56 | /* ICS instance, hooked up to chip_data of an irq */ | 75 | /* ICS instance, hooked up to chip_data of an irq */ |
57 | struct ics { | 76 | struct ics { |