x86/cpu: Remove the CONFIG_X86_PPRO_FENCE=y quirk
There were only a few Pentium Pro multiprocessors systems where this errata applied. They are more than 20 years old now, and we've slowly dropped places which put the workarounds in and discouraged anyone from enabling the workaround. Get rid of it for good. Tested-by: Tom Lendacky <thomas.lendacky@amd.com> Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> Cc: David Woodhouse <dwmw2@infradead.org> Cc: Joerg Roedel <joro@8bytes.org> Cc: Jon Mason <jdmason@kudzu.us> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Muli Ben-Yehuda <mulix@mulix.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: iommu@lists.linux-foundation.org Link: http://lkml.kernel.org/r/20180319103826.12853-2-hch@lst.de Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
c55b8550fa
commit
5927145efd
@ -315,19 +315,6 @@ config X86_L1_CACHE_SHIFT
|
|||||||
default "4" if MELAN || M486 || MGEODEGX1
|
default "4" if MELAN || M486 || MGEODEGX1
|
||||||
default "5" if MWINCHIP3D || MWINCHIPC6 || MCRUSOE || MEFFICEON || MCYRIXIII || MK6 || MPENTIUMIII || MPENTIUMII || M686 || M586MMX || M586TSC || M586 || MVIAC3_2 || MGEODE_LX
|
default "5" if MWINCHIP3D || MWINCHIPC6 || MCRUSOE || MEFFICEON || MCYRIXIII || MK6 || MPENTIUMIII || MPENTIUMII || M686 || M586MMX || M586TSC || M586 || MVIAC3_2 || MGEODE_LX
|
||||||
|
|
||||||
config X86_PPRO_FENCE
|
|
||||||
bool "PentiumPro memory ordering errata workaround"
|
|
||||||
depends on M686 || M586MMX || M586TSC || M586 || M486 || MGEODEGX1
|
|
||||||
---help---
|
|
||||||
Old PentiumPro multiprocessor systems had errata that could cause
|
|
||||||
memory operations to violate the x86 ordering standard in rare cases.
|
|
||||||
Enabling this option will attempt to work around some (but not all)
|
|
||||||
occurrences of this problem, at the cost of much heavier spinlock and
|
|
||||||
memory barrier operations.
|
|
||||||
|
|
||||||
If unsure, say n here. Even distro kernels should think twice before
|
|
||||||
enabling this: there are few systems, and an unlikely bug.
|
|
||||||
|
|
||||||
config X86_F00F_BUG
|
config X86_F00F_BUG
|
||||||
def_bool y
|
def_bool y
|
||||||
depends on M586MMX || M586TSC || M586 || M486
|
depends on M586MMX || M586TSC || M586 || M486
|
||||||
|
@ -5,8 +5,6 @@
|
|||||||
#undef CONFIG_OPTIMIZE_INLINING
|
#undef CONFIG_OPTIMIZE_INLINING
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#undef CONFIG_X86_PPRO_FENCE
|
|
||||||
|
|
||||||
#ifdef CONFIG_X86_64
|
#ifdef CONFIG_X86_64
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -52,11 +52,7 @@ static inline unsigned long array_index_mask_nospec(unsigned long index,
|
|||||||
#define barrier_nospec() alternative_2("", "mfence", X86_FEATURE_MFENCE_RDTSC, \
|
#define barrier_nospec() alternative_2("", "mfence", X86_FEATURE_MFENCE_RDTSC, \
|
||||||
"lfence", X86_FEATURE_LFENCE_RDTSC)
|
"lfence", X86_FEATURE_LFENCE_RDTSC)
|
||||||
|
|
||||||
#ifdef CONFIG_X86_PPRO_FENCE
|
|
||||||
#define dma_rmb() rmb()
|
|
||||||
#else
|
|
||||||
#define dma_rmb() barrier()
|
#define dma_rmb() barrier()
|
||||||
#endif
|
|
||||||
#define dma_wmb() barrier()
|
#define dma_wmb() barrier()
|
||||||
|
|
||||||
#ifdef CONFIG_X86_32
|
#ifdef CONFIG_X86_32
|
||||||
@ -68,30 +64,6 @@ static inline unsigned long array_index_mask_nospec(unsigned long index,
|
|||||||
#define __smp_wmb() barrier()
|
#define __smp_wmb() barrier()
|
||||||
#define __smp_store_mb(var, value) do { (void)xchg(&var, value); } while (0)
|
#define __smp_store_mb(var, value) do { (void)xchg(&var, value); } while (0)
|
||||||
|
|
||||||
#if defined(CONFIG_X86_PPRO_FENCE)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* For this option x86 doesn't have a strong TSO memory
|
|
||||||
* model and we should fall back to full barriers.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define __smp_store_release(p, v) \
|
|
||||||
do { \
|
|
||||||
compiletime_assert_atomic_type(*p); \
|
|
||||||
__smp_mb(); \
|
|
||||||
WRITE_ONCE(*p, v); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define __smp_load_acquire(p) \
|
|
||||||
({ \
|
|
||||||
typeof(*p) ___p1 = READ_ONCE(*p); \
|
|
||||||
compiletime_assert_atomic_type(*p); \
|
|
||||||
__smp_mb(); \
|
|
||||||
___p1; \
|
|
||||||
})
|
|
||||||
|
|
||||||
#else /* regular x86 TSO memory ordering */
|
|
||||||
|
|
||||||
#define __smp_store_release(p, v) \
|
#define __smp_store_release(p, v) \
|
||||||
do { \
|
do { \
|
||||||
compiletime_assert_atomic_type(*p); \
|
compiletime_assert_atomic_type(*p); \
|
||||||
@ -107,8 +79,6 @@ do { \
|
|||||||
___p1; \
|
___p1; \
|
||||||
})
|
})
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Atomic operations are already serializing on x86 */
|
/* Atomic operations are already serializing on x86 */
|
||||||
#define __smp_mb__before_atomic() barrier()
|
#define __smp_mb__before_atomic() barrier()
|
||||||
#define __smp_mb__after_atomic() barrier()
|
#define __smp_mb__after_atomic() barrier()
|
||||||
|
@ -232,21 +232,6 @@ extern void set_iounmap_nonlazy(void);
|
|||||||
*/
|
*/
|
||||||
#define __ISA_IO_base ((char __iomem *)(PAGE_OFFSET))
|
#define __ISA_IO_base ((char __iomem *)(PAGE_OFFSET))
|
||||||
|
|
||||||
/*
|
|
||||||
* Cache management
|
|
||||||
*
|
|
||||||
* This needed for two cases
|
|
||||||
* 1. Out of order aware processors
|
|
||||||
* 2. Accidentally out of order processors (PPro errata #51)
|
|
||||||
*/
|
|
||||||
|
|
||||||
static inline void flush_write_buffers(void)
|
|
||||||
{
|
|
||||||
#if defined(CONFIG_X86_PPRO_FENCE)
|
|
||||||
asm volatile("lock; addl $0,0(%%esp)": : :"memory");
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* __KERNEL__ */
|
#endif /* __KERNEL__ */
|
||||||
|
|
||||||
extern void native_io_delay(void);
|
extern void native_io_delay(void);
|
||||||
|
@ -37,7 +37,6 @@ static dma_addr_t nommu_map_page(struct device *dev, struct page *page,
|
|||||||
WARN_ON(size == 0);
|
WARN_ON(size == 0);
|
||||||
if (!check_addr("map_single", dev, bus, size))
|
if (!check_addr("map_single", dev, bus, size))
|
||||||
return NOMMU_MAPPING_ERROR;
|
return NOMMU_MAPPING_ERROR;
|
||||||
flush_write_buffers();
|
|
||||||
return bus;
|
return bus;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,25 +71,9 @@ static int nommu_map_sg(struct device *hwdev, struct scatterlist *sg,
|
|||||||
return 0;
|
return 0;
|
||||||
s->dma_length = s->length;
|
s->dma_length = s->length;
|
||||||
}
|
}
|
||||||
flush_write_buffers();
|
|
||||||
return nents;
|
return nents;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void nommu_sync_single_for_device(struct device *dev,
|
|
||||||
dma_addr_t addr, size_t size,
|
|
||||||
enum dma_data_direction dir)
|
|
||||||
{
|
|
||||||
flush_write_buffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void nommu_sync_sg_for_device(struct device *dev,
|
|
||||||
struct scatterlist *sg, int nelems,
|
|
||||||
enum dma_data_direction dir)
|
|
||||||
{
|
|
||||||
flush_write_buffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
static int nommu_mapping_error(struct device *dev, dma_addr_t dma_addr)
|
static int nommu_mapping_error(struct device *dev, dma_addr_t dma_addr)
|
||||||
{
|
{
|
||||||
return dma_addr == NOMMU_MAPPING_ERROR;
|
return dma_addr == NOMMU_MAPPING_ERROR;
|
||||||
@ -101,8 +84,6 @@ const struct dma_map_ops nommu_dma_ops = {
|
|||||||
.free = dma_generic_free_coherent,
|
.free = dma_generic_free_coherent,
|
||||||
.map_sg = nommu_map_sg,
|
.map_sg = nommu_map_sg,
|
||||||
.map_page = nommu_map_page,
|
.map_page = nommu_map_page,
|
||||||
.sync_single_for_device = nommu_sync_single_for_device,
|
|
||||||
.sync_sg_for_device = nommu_sync_sg_for_device,
|
|
||||||
.is_phys = 1,
|
.is_phys = 1,
|
||||||
.mapping_error = nommu_mapping_error,
|
.mapping_error = nommu_mapping_error,
|
||||||
.dma_supported = x86_dma_supported,
|
.dma_supported = x86_dma_supported,
|
||||||
|
@ -30,11 +30,7 @@
|
|||||||
|
|
||||||
#endif /* CONFIG_X86_32 */
|
#endif /* CONFIG_X86_32 */
|
||||||
|
|
||||||
#ifdef CONFIG_X86_PPRO_FENCE
|
|
||||||
#define dma_rmb() rmb()
|
|
||||||
#else /* CONFIG_X86_PPRO_FENCE */
|
|
||||||
#define dma_rmb() barrier()
|
#define dma_rmb() barrier()
|
||||||
#endif /* CONFIG_X86_PPRO_FENCE */
|
|
||||||
#define dma_wmb() barrier()
|
#define dma_wmb() barrier()
|
||||||
|
|
||||||
#include <asm-generic/barrier.h>
|
#include <asm-generic/barrier.h>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user