Commit 1bddcc64 authored by Borislav Petkov's avatar Borislav Petkov

Merge x86/urgent into x86/cache

Merge it to pick up dependent urgent changes before applying more
resctrl stuff.
Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
parents dc4060a5 a943245a
...@@ -1499,7 +1499,7 @@ config X86_CPA_STATISTICS ...@@ -1499,7 +1499,7 @@ config X86_CPA_STATISTICS
depends on DEBUG_FS depends on DEBUG_FS
---help--- ---help---
Expose statistics about the Change Page Attribute mechanims, which Expose statistics about the Change Page Attribute mechanims, which
helps to determine the effectivness of preserving large and huge helps to determine the effectiveness of preserving large and huge
page mappings when mapping protections are changed. page mappings when mapping protections are changed.
config ARCH_HAS_MEM_ENCRYPT config ARCH_HAS_MEM_ENCRYPT
......
...@@ -2610,9 +2610,10 @@ static int rdtgroup_init_alloc(struct rdtgroup *rdtgrp) ...@@ -2610,9 +2610,10 @@ static int rdtgroup_init_alloc(struct rdtgroup *rdtgrp)
rdt_last_cmd_puts("Failed to initialize allocations\n"); rdt_last_cmd_puts("Failed to initialize allocations\n");
return ret; return ret;
} }
rdtgrp->mode = RDT_MODE_SHAREABLE;
} }
rdtgrp->mode = RDT_MODE_SHAREABLE;
return 0; return 0;
} }
......
...@@ -426,6 +426,8 @@ static __always_inline void __speculation_ctrl_update(unsigned long tifp, ...@@ -426,6 +426,8 @@ static __always_inline void __speculation_ctrl_update(unsigned long tifp,
u64 msr = x86_spec_ctrl_base; u64 msr = x86_spec_ctrl_base;
bool updmsr = false; bool updmsr = false;
lockdep_assert_irqs_disabled();
/* /*
* If TIF_SSBD is different, select the proper mitigation * If TIF_SSBD is different, select the proper mitigation
* method. Note that if SSBD mitigation is disabled or permanentely * method. Note that if SSBD mitigation is disabled or permanentely
...@@ -477,10 +479,12 @@ static unsigned long speculation_ctrl_update_tif(struct task_struct *tsk) ...@@ -477,10 +479,12 @@ static unsigned long speculation_ctrl_update_tif(struct task_struct *tsk)
void speculation_ctrl_update(unsigned long tif) void speculation_ctrl_update(unsigned long tif)
{ {
unsigned long flags;
/* Forced update. Make sure all relevant TIF flags are different */ /* Forced update. Make sure all relevant TIF flags are different */
preempt_disable(); local_irq_save(flags);
__speculation_ctrl_update(~tif, tif); __speculation_ctrl_update(~tif, tif);
preempt_enable(); local_irq_restore(flags);
} }
/* Called from seccomp/prctl update */ /* Called from seccomp/prctl update */
......
...@@ -81,6 +81,19 @@ static int __init set_bios_reboot(const struct dmi_system_id *d) ...@@ -81,6 +81,19 @@ static int __init set_bios_reboot(const struct dmi_system_id *d)
return 0; return 0;
} }
/*
* Some machines don't handle the default ACPI reboot method and
* require the EFI reboot method:
*/
static int __init set_efi_reboot(const struct dmi_system_id *d)
{
if (reboot_type != BOOT_EFI && !efi_runtime_disabled()) {
reboot_type = BOOT_EFI;
pr_info("%s series board detected. Selecting EFI-method for reboot.\n", d->ident);
}
return 0;
}
void __noreturn machine_real_restart(unsigned int type) void __noreturn machine_real_restart(unsigned int type)
{ {
local_irq_disable(); local_irq_disable();
...@@ -166,6 +179,14 @@ static const struct dmi_system_id reboot_dmi_table[] __initconst = { ...@@ -166,6 +179,14 @@ static const struct dmi_system_id reboot_dmi_table[] __initconst = {
DMI_MATCH(DMI_PRODUCT_NAME, "AOA110"), DMI_MATCH(DMI_PRODUCT_NAME, "AOA110"),
}, },
}, },
{ /* Handle reboot issue on Acer TravelMate X514-51T */
.callback = set_efi_reboot,
.ident = "Acer TravelMate X514-51T",
.matches = {
DMI_MATCH(DMI_SYS_VENDOR, "Acer"),
DMI_MATCH(DMI_PRODUCT_NAME, "TravelMate X514-51T"),
},
},
/* Apple */ /* Apple */
{ /* Handle problems with rebooting on Apple MacBook5 */ { /* Handle problems with rebooting on Apple MacBook5 */
......
...@@ -362,7 +362,7 @@ SECTIONS ...@@ -362,7 +362,7 @@ SECTIONS
.bss : AT(ADDR(.bss) - LOAD_OFFSET) { .bss : AT(ADDR(.bss) - LOAD_OFFSET) {
__bss_start = .; __bss_start = .;
*(.bss..page_aligned) *(.bss..page_aligned)
*(.bss) *(BSS_MAIN)
BSS_DECRYPTED BSS_DECRYPTED
. = ALIGN(PAGE_SIZE); . = ALIGN(PAGE_SIZE);
__bss_stop = .; __bss_stop = .;
......
...@@ -259,7 +259,8 @@ static void note_wx(struct pg_state *st) ...@@ -259,7 +259,8 @@ static void note_wx(struct pg_state *st)
#endif #endif
/* Account the WX pages */ /* Account the WX pages */
st->wx_pages += npages; st->wx_pages += npages;
WARN_ONCE(1, "x86/mm: Found insecure W+X mapping at address %pS\n", WARN_ONCE(__supported_pte_mask & _PAGE_NX,
"x86/mm: Found insecure W+X mapping at address %pS\n",
(void *)st->start_address); (void *)st->start_address);
} }
......
...@@ -825,7 +825,7 @@ void __init __early_set_fixmap(enum fixed_addresses idx, ...@@ -825,7 +825,7 @@ void __init __early_set_fixmap(enum fixed_addresses idx,
pte = early_ioremap_pte(addr); pte = early_ioremap_pte(addr);
/* Sanitize 'prot' against any unsupported bits: */ /* Sanitize 'prot' against any unsupported bits: */
pgprot_val(flags) &= __default_kernel_pte_mask; pgprot_val(flags) &= __supported_pte_mask;
if (pgprot_val(flags)) if (pgprot_val(flags))
set_pte(pte, pfn_pte(phys >> PAGE_SHIFT, flags)); set_pte(pte, pfn_pte(phys >> PAGE_SHIFT, flags));
......
...@@ -728,7 +728,7 @@ void flush_tlb_mm_range(struct mm_struct *mm, unsigned long start, ...@@ -728,7 +728,7 @@ void flush_tlb_mm_range(struct mm_struct *mm, unsigned long start,
{ {
int cpu; int cpu;
struct flush_tlb_info info __aligned(SMP_CACHE_BYTES) = { struct flush_tlb_info info = {
.mm = mm, .mm = mm,
.stride_shift = stride_shift, .stride_shift = stride_shift,
.freed_tables = freed_tables, .freed_tables = freed_tables,
......
...@@ -1611,7 +1611,12 @@ efi_status_t efi_setup_gop(efi_system_table_t *sys_table_arg, ...@@ -1611,7 +1611,12 @@ efi_status_t efi_setup_gop(efi_system_table_t *sys_table_arg,
struct screen_info *si, efi_guid_t *proto, struct screen_info *si, efi_guid_t *proto,
unsigned long size); unsigned long size);
bool efi_runtime_disabled(void); #ifdef CONFIG_EFI
extern bool efi_runtime_disabled(void);
#else
static inline bool efi_runtime_disabled(void) { return true; }
#endif
extern void efi_call_virt_check_flags(unsigned long flags, const char *call); extern void efi_call_virt_check_flags(unsigned long flags, const char *call);
extern unsigned long efi_call_virt_save_flags(void); extern unsigned long efi_call_virt_save_flags(void);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment