mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-04 04:04:19 +00:00
asm-generic: introduce io_stop_wc() and add implementation for ARM64
For memory accesses with write-combining attributes (e.g. those returned by ioremap_wc()), the CPU may wait for prior accesses to be merged with subsequent ones. But in some situation, such wait is bad for the performance. We introduce io_stop_wc() to prevent the merging of write-combining memory accesses before this macro with those after it. We add implementation for ARM64 using DGH instruction and provide NOP implementation for other architectures. Signed-off-by: Xiongfeng Wang <wangxiongfeng2@huawei.com> Suggested-by: Will Deacon <will@kernel.org> Suggested-by: Catalin Marinas <catalin.marinas@arm.com> Acked-by: Arnd Bergmann <arnd@arndb.de> Link: https://lore.kernel.org/r/20211221035556.60346-1-wangxiongfeng2@huawei.com Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
This commit is contained in:
parent
c2c529b27c
commit
d5624bb29f
@ -1950,6 +1950,14 @@ There are some more advanced barrier functions:
|
|||||||
For load from persistent memory, existing read memory barriers are sufficient
|
For load from persistent memory, existing read memory barriers are sufficient
|
||||||
to ensure read ordering.
|
to ensure read ordering.
|
||||||
|
|
||||||
|
(*) io_stop_wc();
|
||||||
|
|
||||||
|
For memory accesses with write-combining attributes (e.g. those returned
|
||||||
|
by ioremap_wc(), the CPU may wait for prior accesses to be merged with
|
||||||
|
subsequent ones. io_stop_wc() can be used to prevent the merging of
|
||||||
|
write-combining memory accesses before this macro with those after it when
|
||||||
|
such wait has performance implications.
|
||||||
|
|
||||||
===============================
|
===============================
|
||||||
IMPLICIT KERNEL MEMORY BARRIERS
|
IMPLICIT KERNEL MEMORY BARRIERS
|
||||||
===============================
|
===============================
|
||||||
|
@ -26,6 +26,14 @@
|
|||||||
#define __tsb_csync() asm volatile("hint #18" : : : "memory")
|
#define __tsb_csync() asm volatile("hint #18" : : : "memory")
|
||||||
#define csdb() asm volatile("hint #20" : : : "memory")
|
#define csdb() asm volatile("hint #20" : : : "memory")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Data Gathering Hint:
|
||||||
|
* This instruction prevents merging memory accesses with Normal-NC or
|
||||||
|
* Device-GRE attributes before the hint instruction with any memory accesses
|
||||||
|
* appearing after the hint instruction.
|
||||||
|
*/
|
||||||
|
#define dgh() asm volatile("hint #6" : : : "memory")
|
||||||
|
|
||||||
#ifdef CONFIG_ARM64_PSEUDO_NMI
|
#ifdef CONFIG_ARM64_PSEUDO_NMI
|
||||||
#define pmr_sync() \
|
#define pmr_sync() \
|
||||||
do { \
|
do { \
|
||||||
@ -46,6 +54,7 @@
|
|||||||
#define dma_rmb() dmb(oshld)
|
#define dma_rmb() dmb(oshld)
|
||||||
#define dma_wmb() dmb(oshst)
|
#define dma_wmb() dmb(oshst)
|
||||||
|
|
||||||
|
#define io_stop_wc() dgh()
|
||||||
|
|
||||||
#define tsb_csync() \
|
#define tsb_csync() \
|
||||||
do { \
|
do { \
|
||||||
|
@ -251,5 +251,16 @@ do { \
|
|||||||
#define pmem_wmb() wmb()
|
#define pmem_wmb() wmb()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ioremap_wc() maps I/O memory as memory with write-combining attributes. For
|
||||||
|
* this kind of memory accesses, the CPU may wait for prior accesses to be
|
||||||
|
* merged with subsequent ones. In some situation, such wait is bad for the
|
||||||
|
* performance. io_stop_wc() can be used to prevent the merging of
|
||||||
|
* write-combining memory accesses before this macro with those after it.
|
||||||
|
*/
|
||||||
|
#ifndef io_stop_wc
|
||||||
|
#define io_stop_wc do { } while (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* !__ASSEMBLY__ */
|
#endif /* !__ASSEMBLY__ */
|
||||||
#endif /* __ASM_GENERIC_BARRIER_H */
|
#endif /* __ASM_GENERIC_BARRIER_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user