diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-12-27 13:43:24 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-12-27 13:43:24 -0500 |
commit | 8d6973327ee84c2f40dd9efd8928d4a1186c96e2 (patch) | |
tree | 1c6accd71b6e9c4e05d5aaae766b958ad440d320 /arch/powerpc/include/asm/pgtable.h | |
parent | 6d101ba6be2a26a3e1f513b5e293f0fd2b79ec5c (diff) | |
parent | 12526b0d6c580df860b31e59d68e5696e16c6e5b (diff) |
Merge tag 'powerpc-4.21-1' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux
Pull powerpc updates from Michael Ellerman:
"Notable changes:
- Mitigations for Spectre v2 on some Freescale (NXP) CPUs.
- A large series adding support for pass-through of Nvidia V100 GPUs
to guests on Power9.
- Another large series to enable hardware assistance for TLB table
walk on MPC8xx CPUs.
- Some preparatory changes to our DMA code, to make way for further
cleanups from Christoph.
- Several fixes for our Transactional Memory handling discovered by
fuzzing the signal return path.
- Support for generating our system call table(s) from a text file
like other architectures.
- A fix to our page fault handler so that instead of generating a
WARN_ON_ONCE, user accesses of kernel addresses instead print a
ratelimited and appropriately scary warning.
- A cosmetic change to make our unhandled page fault messages more
similar to other arches and also more compact and informative.
- Freescale updates from Scott:
"Highlights include elimination of legacy clock bindings use from
dts files, an 83xx watchdog handler, fixes to old dts interrupt
errors, and some minor cleanup."
And many clean-ups, reworks and minor fixes etc.
Thanks to: Alexandre Belloni, Alexey Kardashevskiy, Andrew Donnellan,
Aneesh Kumar K.V, Arnd Bergmann, Benjamin Herrenschmidt, Breno Leitao,
Christian Lamparter, Christophe Leroy, Christoph Hellwig, Daniel
Axtens, Darren Stevens, David Gibson, Diana Craciun, Dmitry V. Levin,
Firoz Khan, Geert Uytterhoeven, Greg Kurz, Gustavo Romero, Hari
Bathini, Joel Stanley, Kees Cook, Madhavan Srinivasan, Mahesh
Salgaonkar, Markus Elfring, Mathieu Malaterre, Michal Suchánek, Naveen
N. Rao, Nick Desaulniers, Oliver O'Halloran, Paul Mackerras, Ram Pai,
Ravi Bangoria, Rob Herring, Russell Currey, Sabyasachi Gupta, Sam
Bobroff, Satheesh Rajendran, Scott Wood, Segher Boessenkool, Stephen
Rothwell, Tang Yuantian, Thiago Jung Bauermann, Yangtao Li, Yuantian
Tang, Yue Haibing"
* tag 'powerpc-4.21-1' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux: (201 commits)
Revert "powerpc/fsl_pci: simplify fsl_pci_dma_set_mask"
powerpc/zImage: Also check for stdout-path
powerpc: Fix HMIs on big-endian with CONFIG_RELOCATABLE=y
macintosh: Use of_node_name_{eq, prefix} for node name comparisons
ide: Use of_node_name_eq for node name comparisons
powerpc: Use of_node_name_eq for node name comparisons
powerpc/pseries/pmem: Convert to %pOFn instead of device_node.name
powerpc/mm: Remove very old comment in hash-4k.h
powerpc/pseries: Fix node leak in update_lmb_associativity_index()
powerpc/configs/85xx: Enable CONFIG_DEBUG_KERNEL
powerpc/dts/fsl: Fix dtc-flagged interrupt errors
clk: qoriq: add more compatibles strings
powerpc/fsl: Use new clockgen binding
powerpc/83xx: handle machine check caused by watchdog timer
powerpc/fsl-rio: fix spelling mistake "reserverd" -> "reserved"
powerpc/fsl_pci: simplify fsl_pci_dma_set_mask
arch/powerpc/fsl_rmu: Use dma_zalloc_coherent
vfio_pci: Add NVIDIA GV100GL [Tesla V100 SXM2] subdriver
vfio_pci: Allow regions to add own capabilities
vfio_pci: Allow mapping extra regions
...
Diffstat (limited to 'arch/powerpc/include/asm/pgtable.h')
-rw-r--r-- | arch/powerpc/include/asm/pgtable.h | 32 |
1 files changed, 30 insertions, 2 deletions
diff --git a/arch/powerpc/include/asm/pgtable.h b/arch/powerpc/include/asm/pgtable.h index 9679b7519a35..dad1d27e196d 100644 --- a/arch/powerpc/include/asm/pgtable.h +++ b/arch/powerpc/include/asm/pgtable.h | |||
@@ -66,7 +66,6 @@ extern unsigned long empty_zero_page[]; | |||
66 | 66 | ||
67 | extern pgd_t swapper_pg_dir[]; | 67 | extern pgd_t swapper_pg_dir[]; |
68 | 68 | ||
69 | void limit_zone_pfn(enum zone_type zone, unsigned long max_pfn); | ||
70 | int dma_pfn_limit_to_zone(u64 pfn_limit); | 69 | int dma_pfn_limit_to_zone(u64 pfn_limit); |
71 | extern void paging_init(void); | 70 | extern void paging_init(void); |
72 | 71 | ||
@@ -101,7 +100,7 @@ extern int gup_hugepte(pte_t *ptep, unsigned long sz, unsigned long addr, | |||
101 | /* can we use this in kvm */ | 100 | /* can we use this in kvm */ |
102 | unsigned long vmalloc_to_phys(void *vmalloc_addr); | 101 | unsigned long vmalloc_to_phys(void *vmalloc_addr); |
103 | 102 | ||
104 | void pgtable_cache_add(unsigned shift, void (*ctor)(void *)); | 103 | void pgtable_cache_add(unsigned int shift); |
105 | void pgtable_cache_init(void); | 104 | void pgtable_cache_init(void); |
106 | 105 | ||
107 | #if defined(CONFIG_STRICT_KERNEL_RWX) || defined(CONFIG_PPC32) | 106 | #if defined(CONFIG_STRICT_KERNEL_RWX) || defined(CONFIG_PPC32) |
@@ -110,6 +109,35 @@ void mark_initmem_nx(void); | |||
110 | static inline void mark_initmem_nx(void) { } | 109 | static inline void mark_initmem_nx(void) { } |
111 | #endif | 110 | #endif |
112 | 111 | ||
112 | /* | ||
113 | * When used, PTE_FRAG_NR is defined in subarch pgtable.h | ||
114 | * so we are sure it is included when arriving here. | ||
115 | */ | ||
116 | #ifdef PTE_FRAG_NR | ||
117 | static inline void *pte_frag_get(mm_context_t *ctx) | ||
118 | { | ||
119 | return ctx->pte_frag; | ||
120 | } | ||
121 | |||
122 | static inline void pte_frag_set(mm_context_t *ctx, void *p) | ||
123 | { | ||
124 | ctx->pte_frag = p; | ||
125 | } | ||
126 | #else | ||
127 | #define PTE_FRAG_NR 1 | ||
128 | #define PTE_FRAG_SIZE_SHIFT PAGE_SHIFT | ||
129 | #define PTE_FRAG_SIZE (1UL << PTE_FRAG_SIZE_SHIFT) | ||
130 | |||
131 | static inline void *pte_frag_get(mm_context_t *ctx) | ||
132 | { | ||
133 | return NULL; | ||
134 | } | ||
135 | |||
136 | static inline void pte_frag_set(mm_context_t *ctx, void *p) | ||
137 | { | ||
138 | } | ||
139 | #endif | ||
140 | |||
113 | #endif /* __ASSEMBLY__ */ | 141 | #endif /* __ASSEMBLY__ */ |
114 | 142 | ||
115 | #endif /* _ASM_POWERPC_PGTABLE_H */ | 143 | #endif /* _ASM_POWERPC_PGTABLE_H */ |