0033-x86-paravirt-Remove-no-longer-used-paravirt-function.patch 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390
  1. From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
  2. From: Juergen Gross <[email protected]>
  3. Date: Mon, 4 Sep 2017 12:25:27 +0200
  4. Subject: [PATCH] x86/paravirt: Remove no longer used paravirt functions
  5. MIME-Version: 1.0
  6. Content-Type: text/plain; charset=UTF-8
  7. Content-Transfer-Encoding: 8bit
  8. CVE-2017-5754
  9. With removal of lguest some of the paravirt functions are no longer
  10. needed:
  11. ->read_cr4()
  12. ->store_idt()
  13. ->set_pmd_at()
  14. ->set_pud_at()
  15. ->pte_update()
  16. Remove them.
  17. Signed-off-by: Juergen Gross <[email protected]>
  18. Cc: Linus Torvalds <[email protected]>
  19. Cc: Peter Zijlstra <[email protected]>
  20. Cc: Thomas Gleixner <[email protected]>
  21. Cc: [email protected]
  22. Cc: [email protected]
  23. Cc: [email protected]
  24. Cc: [email protected]
  25. Cc: [email protected]
  26. Cc: [email protected]
  27. Cc: [email protected]
  28. Link: http://lkml.kernel.org/r/[email protected]
  29. Signed-off-by: Ingo Molnar <[email protected]>
  30. (cherry picked from commit 87930019c713873a1c3b9bd55dde46e81f70c8f1)
  31. Signed-off-by: Andy Whitcroft <[email protected]>
  32. Signed-off-by: Kleber Sacilotto de Souza <[email protected]>
  33. (cherry picked from commit edf3ab0080a6e79a300753e66929b0b7499eaec5)
  34. Signed-off-by: Fabian Grünbichler <[email protected]>
  35. ---
  36. arch/x86/include/asm/desc.h | 3 +--
  37. arch/x86/include/asm/paravirt.h | 37 -----------------------------------
  38. arch/x86/include/asm/paravirt_types.h | 9 ---------
  39. arch/x86/include/asm/pgtable.h | 27 ++++---------------------
  40. arch/x86/include/asm/special_insns.h | 10 +++++-----
  41. arch/x86/kernel/paravirt.c | 5 -----
  42. arch/x86/kvm/vmx.c | 2 +-
  43. arch/x86/mm/pgtable.c | 7 +------
  44. arch/x86/xen/enlighten_pv.c | 2 --
  45. arch/x86/xen/mmu_pv.c | 2 --
  46. 10 files changed, 12 insertions(+), 92 deletions(-)
  47. diff --git a/arch/x86/include/asm/desc.h b/arch/x86/include/asm/desc.h
  48. index 57e502a4e92f..f995e5a09136 100644
  49. --- a/arch/x86/include/asm/desc.h
  50. +++ b/arch/x86/include/asm/desc.h
  51. @@ -120,7 +120,6 @@ static inline int desc_empty(const void *ptr)
  52. #define load_ldt(ldt) asm volatile("lldt %0"::"m" (ldt))
  53. #define store_gdt(dtr) native_store_gdt(dtr)
  54. -#define store_idt(dtr) native_store_idt(dtr)
  55. #define store_tr(tr) (tr = native_store_tr())
  56. #define load_TLS(t, cpu) native_load_tls(t, cpu)
  57. @@ -241,7 +240,7 @@ static inline void native_store_gdt(struct desc_ptr *dtr)
  58. asm volatile("sgdt %0":"=m" (*dtr));
  59. }
  60. -static inline void native_store_idt(struct desc_ptr *dtr)
  61. +static inline void store_idt(struct desc_ptr *dtr)
  62. {
  63. asm volatile("sidt %0":"=m" (*dtr));
  64. }
  65. diff --git a/arch/x86/include/asm/paravirt.h b/arch/x86/include/asm/paravirt.h
  66. index c25dd22f7c70..12deec722cf0 100644
  67. --- a/arch/x86/include/asm/paravirt.h
  68. +++ b/arch/x86/include/asm/paravirt.h
  69. @@ -71,11 +71,6 @@ static inline void write_cr3(unsigned long x)
  70. PVOP_VCALL1(pv_mmu_ops.write_cr3, x);
  71. }
  72. -static inline unsigned long __read_cr4(void)
  73. -{
  74. - return PVOP_CALL0(unsigned long, pv_cpu_ops.read_cr4);
  75. -}
  76. -
  77. static inline void __write_cr4(unsigned long x)
  78. {
  79. PVOP_VCALL1(pv_cpu_ops.write_cr4, x);
  80. @@ -228,10 +223,6 @@ static inline void set_ldt(const void *addr, unsigned entries)
  81. {
  82. PVOP_VCALL2(pv_cpu_ops.set_ldt, addr, entries);
  83. }
  84. -static inline void store_idt(struct desc_ptr *dtr)
  85. -{
  86. - PVOP_VCALL1(pv_cpu_ops.store_idt, dtr);
  87. -}
  88. static inline unsigned long paravirt_store_tr(void)
  89. {
  90. return PVOP_CALL0(unsigned long, pv_cpu_ops.store_tr);
  91. @@ -365,12 +356,6 @@ static inline void paravirt_release_p4d(unsigned long pfn)
  92. PVOP_VCALL1(pv_mmu_ops.release_p4d, pfn);
  93. }
  94. -static inline void pte_update(struct mm_struct *mm, unsigned long addr,
  95. - pte_t *ptep)
  96. -{
  97. - PVOP_VCALL3(pv_mmu_ops.pte_update, mm, addr, ptep);
  98. -}
  99. -
  100. static inline pte_t __pte(pteval_t val)
  101. {
  102. pteval_t ret;
  103. @@ -472,28 +457,6 @@ static inline void set_pte_at(struct mm_struct *mm, unsigned long addr,
  104. PVOP_VCALL4(pv_mmu_ops.set_pte_at, mm, addr, ptep, pte.pte);
  105. }
  106. -static inline void set_pmd_at(struct mm_struct *mm, unsigned long addr,
  107. - pmd_t *pmdp, pmd_t pmd)
  108. -{
  109. - if (sizeof(pmdval_t) > sizeof(long))
  110. - /* 5 arg words */
  111. - pv_mmu_ops.set_pmd_at(mm, addr, pmdp, pmd);
  112. - else
  113. - PVOP_VCALL4(pv_mmu_ops.set_pmd_at, mm, addr, pmdp,
  114. - native_pmd_val(pmd));
  115. -}
  116. -
  117. -static inline void set_pud_at(struct mm_struct *mm, unsigned long addr,
  118. - pud_t *pudp, pud_t pud)
  119. -{
  120. - if (sizeof(pudval_t) > sizeof(long))
  121. - /* 5 arg words */
  122. - pv_mmu_ops.set_pud_at(mm, addr, pudp, pud);
  123. - else
  124. - PVOP_VCALL4(pv_mmu_ops.set_pud_at, mm, addr, pudp,
  125. - native_pud_val(pud));
  126. -}
  127. -
  128. static inline void set_pmd(pmd_t *pmdp, pmd_t pmd)
  129. {
  130. pmdval_t val = native_pmd_val(pmd);
  131. diff --git a/arch/x86/include/asm/paravirt_types.h b/arch/x86/include/asm/paravirt_types.h
  132. index 6b64fc6367f2..42873edd9f9d 100644
  133. --- a/arch/x86/include/asm/paravirt_types.h
  134. +++ b/arch/x86/include/asm/paravirt_types.h
  135. @@ -107,7 +107,6 @@ struct pv_cpu_ops {
  136. unsigned long (*read_cr0)(void);
  137. void (*write_cr0)(unsigned long);
  138. - unsigned long (*read_cr4)(void);
  139. void (*write_cr4)(unsigned long);
  140. #ifdef CONFIG_X86_64
  141. @@ -119,8 +118,6 @@ struct pv_cpu_ops {
  142. void (*load_tr_desc)(void);
  143. void (*load_gdt)(const struct desc_ptr *);
  144. void (*load_idt)(const struct desc_ptr *);
  145. - /* store_gdt has been removed. */
  146. - void (*store_idt)(struct desc_ptr *);
  147. void (*set_ldt)(const void *desc, unsigned entries);
  148. unsigned long (*store_tr)(void);
  149. void (*load_tls)(struct thread_struct *t, unsigned int cpu);
  150. @@ -245,12 +242,6 @@ struct pv_mmu_ops {
  151. void (*set_pte_at)(struct mm_struct *mm, unsigned long addr,
  152. pte_t *ptep, pte_t pteval);
  153. void (*set_pmd)(pmd_t *pmdp, pmd_t pmdval);
  154. - void (*set_pmd_at)(struct mm_struct *mm, unsigned long addr,
  155. - pmd_t *pmdp, pmd_t pmdval);
  156. - void (*set_pud_at)(struct mm_struct *mm, unsigned long addr,
  157. - pud_t *pudp, pud_t pudval);
  158. - void (*pte_update)(struct mm_struct *mm, unsigned long addr,
  159. - pte_t *ptep);
  160. pte_t (*ptep_modify_prot_start)(struct mm_struct *mm, unsigned long addr,
  161. pte_t *ptep);
  162. diff --git a/arch/x86/include/asm/pgtable.h b/arch/x86/include/asm/pgtable.h
  163. index 77037b6f1caa..bb8e9ea7deb4 100644
  164. --- a/arch/x86/include/asm/pgtable.h
  165. +++ b/arch/x86/include/asm/pgtable.h
  166. @@ -43,8 +43,6 @@ extern struct mm_struct *pgd_page_get_mm(struct page *page);
  167. #else /* !CONFIG_PARAVIRT */
  168. #define set_pte(ptep, pte) native_set_pte(ptep, pte)
  169. #define set_pte_at(mm, addr, ptep, pte) native_set_pte_at(mm, addr, ptep, pte)
  170. -#define set_pmd_at(mm, addr, pmdp, pmd) native_set_pmd_at(mm, addr, pmdp, pmd)
  171. -#define set_pud_at(mm, addr, pudp, pud) native_set_pud_at(mm, addr, pudp, pud)
  172. #define set_pte_atomic(ptep, pte) \
  173. native_set_pte_atomic(ptep, pte)
  174. @@ -75,8 +73,6 @@ extern struct mm_struct *pgd_page_get_mm(struct page *page);
  175. #define pte_clear(mm, addr, ptep) native_pte_clear(mm, addr, ptep)
  176. #define pmd_clear(pmd) native_pmd_clear(pmd)
  177. -#define pte_update(mm, addr, ptep) do { } while (0)
  178. -
  179. #define pgd_val(x) native_pgd_val(x)
  180. #define __pgd(x) native_make_pgd(x)
  181. @@ -965,31 +961,18 @@ static inline void native_set_pte_at(struct mm_struct *mm, unsigned long addr,
  182. native_set_pte(ptep, pte);
  183. }
  184. -static inline void native_set_pmd_at(struct mm_struct *mm, unsigned long addr,
  185. - pmd_t *pmdp , pmd_t pmd)
  186. +static inline void set_pmd_at(struct mm_struct *mm, unsigned long addr,
  187. + pmd_t *pmdp, pmd_t pmd)
  188. {
  189. native_set_pmd(pmdp, pmd);
  190. }
  191. -static inline void native_set_pud_at(struct mm_struct *mm, unsigned long addr,
  192. - pud_t *pudp, pud_t pud)
  193. +static inline void set_pud_at(struct mm_struct *mm, unsigned long addr,
  194. + pud_t *pudp, pud_t pud)
  195. {
  196. native_set_pud(pudp, pud);
  197. }
  198. -#ifndef CONFIG_PARAVIRT
  199. -/*
  200. - * Rules for using pte_update - it must be called after any PTE update which
  201. - * has not been done using the set_pte / clear_pte interfaces. It is used by
  202. - * shadow mode hypervisors to resynchronize the shadow page tables. Kernel PTE
  203. - * updates should either be sets, clears, or set_pte_atomic for P->P
  204. - * transitions, which means this hook should only be called for user PTEs.
  205. - * This hook implies a P->P protection or access change has taken place, which
  206. - * requires a subsequent TLB flush.
  207. - */
  208. -#define pte_update(mm, addr, ptep) do { } while (0)
  209. -#endif
  210. -
  211. /*
  212. * We only update the dirty/accessed state if we set
  213. * the dirty bit by hand in the kernel, since the hardware
  214. @@ -1017,7 +1000,6 @@ static inline pte_t ptep_get_and_clear(struct mm_struct *mm, unsigned long addr,
  215. pte_t *ptep)
  216. {
  217. pte_t pte = native_ptep_get_and_clear(ptep);
  218. - pte_update(mm, addr, ptep);
  219. return pte;
  220. }
  221. @@ -1044,7 +1026,6 @@ static inline void ptep_set_wrprotect(struct mm_struct *mm,
  222. unsigned long addr, pte_t *ptep)
  223. {
  224. clear_bit(_PAGE_BIT_RW, (unsigned long *)&ptep->pte);
  225. - pte_update(mm, addr, ptep);
  226. }
  227. #define flush_tlb_fix_spurious_fault(vma, address) do { } while (0)
  228. diff --git a/arch/x86/include/asm/special_insns.h b/arch/x86/include/asm/special_insns.h
  229. index 9efaabf5b54b..a24dfcf79f4a 100644
  230. --- a/arch/x86/include/asm/special_insns.h
  231. +++ b/arch/x86/include/asm/special_insns.h
  232. @@ -135,6 +135,11 @@ static inline void native_wbinvd(void)
  233. extern asmlinkage void native_load_gs_index(unsigned);
  234. +static inline unsigned long __read_cr4(void)
  235. +{
  236. + return native_read_cr4();
  237. +}
  238. +
  239. #ifdef CONFIG_PARAVIRT
  240. #include <asm/paravirt.h>
  241. #else
  242. @@ -173,11 +178,6 @@ static inline void write_cr3(unsigned long x)
  243. native_write_cr3(x);
  244. }
  245. -static inline unsigned long __read_cr4(void)
  246. -{
  247. - return native_read_cr4();
  248. -}
  249. -
  250. static inline void __write_cr4(unsigned long x)
  251. {
  252. native_write_cr4(x);
  253. diff --git a/arch/x86/kernel/paravirt.c b/arch/x86/kernel/paravirt.c
  254. index a14df9eecfed..19a3e8f961c7 100644
  255. --- a/arch/x86/kernel/paravirt.c
  256. +++ b/arch/x86/kernel/paravirt.c
  257. @@ -327,7 +327,6 @@ __visible struct pv_cpu_ops pv_cpu_ops = {
  258. .set_debugreg = native_set_debugreg,
  259. .read_cr0 = native_read_cr0,
  260. .write_cr0 = native_write_cr0,
  261. - .read_cr4 = native_read_cr4,
  262. .write_cr4 = native_write_cr4,
  263. #ifdef CONFIG_X86_64
  264. .read_cr8 = native_read_cr8,
  265. @@ -343,7 +342,6 @@ __visible struct pv_cpu_ops pv_cpu_ops = {
  266. .set_ldt = native_set_ldt,
  267. .load_gdt = native_load_gdt,
  268. .load_idt = native_load_idt,
  269. - .store_idt = native_store_idt,
  270. .store_tr = native_store_tr,
  271. .load_tls = native_load_tls,
  272. #ifdef CONFIG_X86_64
  273. @@ -411,8 +409,6 @@ struct pv_mmu_ops pv_mmu_ops __ro_after_init = {
  274. .set_pte = native_set_pte,
  275. .set_pte_at = native_set_pte_at,
  276. .set_pmd = native_set_pmd,
  277. - .set_pmd_at = native_set_pmd_at,
  278. - .pte_update = paravirt_nop,
  279. .ptep_modify_prot_start = __ptep_modify_prot_start,
  280. .ptep_modify_prot_commit = __ptep_modify_prot_commit,
  281. @@ -424,7 +420,6 @@ struct pv_mmu_ops pv_mmu_ops __ro_after_init = {
  282. .pmd_clear = native_pmd_clear,
  283. #endif
  284. .set_pud = native_set_pud,
  285. - .set_pud_at = native_set_pud_at,
  286. .pmd_val = PTE_IDENT,
  287. .make_pmd = PTE_IDENT,
  288. diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c
  289. index 7b447d126d17..dd4996a96c71 100644
  290. --- a/arch/x86/kvm/vmx.c
  291. +++ b/arch/x86/kvm/vmx.c
  292. @@ -5174,7 +5174,7 @@ static void vmx_set_constant_host_state(struct vcpu_vmx *vmx)
  293. vmcs_write16(HOST_SS_SELECTOR, __KERNEL_DS); /* 22.2.4 */
  294. vmcs_write16(HOST_TR_SELECTOR, GDT_ENTRY_TSS*8); /* 22.2.4 */
  295. - native_store_idt(&dt);
  296. + store_idt(&dt);
  297. vmcs_writel(HOST_IDTR_BASE, dt.address); /* 22.2.4 */
  298. vmx->host_idt_base = dt.address;
  299. diff --git a/arch/x86/mm/pgtable.c b/arch/x86/mm/pgtable.c
  300. index 508a708eb9a6..942391b5b639 100644
  301. --- a/arch/x86/mm/pgtable.c
  302. +++ b/arch/x86/mm/pgtable.c
  303. @@ -426,10 +426,8 @@ int ptep_set_access_flags(struct vm_area_struct *vma,
  304. {
  305. int changed = !pte_same(*ptep, entry);
  306. - if (changed && dirty) {
  307. + if (changed && dirty)
  308. *ptep = entry;
  309. - pte_update(vma->vm_mm, address, ptep);
  310. - }
  311. return changed;
  312. }
  313. @@ -486,9 +484,6 @@ int ptep_test_and_clear_young(struct vm_area_struct *vma,
  314. ret = test_and_clear_bit(_PAGE_BIT_ACCESSED,
  315. (unsigned long *) &ptep->pte);
  316. - if (ret)
  317. - pte_update(vma->vm_mm, addr, ptep);
  318. -
  319. return ret;
  320. }
  321. diff --git a/arch/x86/xen/enlighten_pv.c b/arch/x86/xen/enlighten_pv.c
  322. index ae2a2e2d6362..69b9deff7e5c 100644
  323. --- a/arch/x86/xen/enlighten_pv.c
  324. +++ b/arch/x86/xen/enlighten_pv.c
  325. @@ -1038,7 +1038,6 @@ static const struct pv_cpu_ops xen_cpu_ops __initconst = {
  326. .read_cr0 = xen_read_cr0,
  327. .write_cr0 = xen_write_cr0,
  328. - .read_cr4 = native_read_cr4,
  329. .write_cr4 = xen_write_cr4,
  330. #ifdef CONFIG_X86_64
  331. @@ -1073,7 +1072,6 @@ static const struct pv_cpu_ops xen_cpu_ops __initconst = {
  332. .alloc_ldt = xen_alloc_ldt,
  333. .free_ldt = xen_free_ldt,
  334. - .store_idt = native_store_idt,
  335. .store_tr = xen_store_tr,
  336. .write_ldt_entry = xen_write_ldt_entry,
  337. diff --git a/arch/x86/xen/mmu_pv.c b/arch/x86/xen/mmu_pv.c
  338. index cab28cf2cffb..5f61b7e2e6b2 100644
  339. --- a/arch/x86/xen/mmu_pv.c
  340. +++ b/arch/x86/xen/mmu_pv.c
  341. @@ -2430,8 +2430,6 @@ static const struct pv_mmu_ops xen_mmu_ops __initconst = {
  342. .flush_tlb_single = xen_flush_tlb_single,
  343. .flush_tlb_others = xen_flush_tlb_others,
  344. - .pte_update = paravirt_nop,
  345. -
  346. .pgd_alloc = xen_pgd_alloc,
  347. .pgd_free = xen_pgd_free,
  348. --
  349. 2.14.2