diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2020-03-15 22:52:56 +0300 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2020-03-15 22:52:56 +0300 | 
| commit | ec181b7f30bdae2fbbba1c0dd76aeaad89c7963e (patch) | |
| tree | 548c6c8e5e94c7da6e7e379a6a0ab91ebf03a692 /arch/x86/kernel/apic/vector.c | |
| parent | e99bc917fe0233ea64799a5bc376b7d7a7cb0aea (diff) | |
| parent | 469ff207b4c4033540b50bc59587dc915faa1367 (diff) | |
| download | linux-ec181b7f30bdae2fbbba1c0dd76aeaad89c7963e.tar.xz | |
Merge tag 'x86-urgent-2020-03-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull x86 fixes from Thomas Gleixner:
 "Two fixes for x86:
   - Map EFI runtime service data as encrypted when SEV is enabled.
     Otherwise e.g. SMBIOS data cannot be properly decoded by dmidecode.
   - Remove the warning in the vector management code which triggered
     when a managed interrupt affinity changed outside of a CPU hotplug
     operation.
     The warning was correct until the recent core code change that
     introduced a CPU isolation feature which needs to migrate managed
     interrupts away from online CPUs under certain conditions to
     achieve the isolation"
* tag 'x86-urgent-2020-03-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  x86/vector: Remove warning on managed interrupt migration
  x86/ioremap: Map EFI runtime services data as encrypted for SEV
Diffstat (limited to 'arch/x86/kernel/apic/vector.c')
| -rw-r--r-- | arch/x86/kernel/apic/vector.c | 14 | 
1 files changed, 8 insertions, 6 deletions
| diff --git a/arch/x86/kernel/apic/vector.c b/arch/x86/kernel/apic/vector.c index 2c5676b0a6e7..48293d15f1e1 100644 --- a/arch/x86/kernel/apic/vector.c +++ b/arch/x86/kernel/apic/vector.c @@ -838,13 +838,15 @@ static void free_moved_vector(struct apic_chip_data *apicd)  	bool managed = apicd->is_managed;  	/* -	 * This should never happen. Managed interrupts are not -	 * migrated except on CPU down, which does not involve the -	 * cleanup vector. But try to keep the accounting correct -	 * nevertheless. +	 * Managed interrupts are usually not migrated away +	 * from an online CPU, but CPU isolation 'managed_irq' +	 * can make that happen. +	 * 1) Activation does not take the isolation into account +	 *    to keep the code simple +	 * 2) Migration away from an isolated CPU can happen when +	 *    a non-isolated CPU which is in the calculated +	 *    affinity mask comes online.  	 */ -	WARN_ON_ONCE(managed); -  	trace_vector_free_moved(apicd->irq, cpu, vector, managed);  	irq_matrix_free(vector_matrix, cpu, vector, managed);  	per_cpu(vector_irq, cpu)[vector] = VECTOR_UNUSED; | 
