diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-10-23 08:08:53 -0400 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-10-23 08:08:53 -0400 | 
| commit | 0200fbdd431519d730b5d399a12840ec832b27cc (patch) | |
| tree | 2b58f9e24b61b00e0550f106c95bfabc3b52cfdd /arch/x86/include/asm/alternative-asm.h | |
| parent | de3fbb2aa802a267dee2213ae7d5a1e19eb4294a (diff) | |
| parent | 01a14bda11add9dcd4a59200f13834d634559935 (diff) | |
Merge branch 'locking-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull locking and misc x86 updates from Ingo Molnar:
 "Lots of changes in this cycle - in part because locking/core attracted
  a number of related x86 low level work which was easier to handle in a
  single tree:
   - Linux Kernel Memory Consistency Model updates (Alan Stern, Paul E.
     McKenney, Andrea Parri)
   - lockdep scalability improvements and micro-optimizations (Waiman
     Long)
   - rwsem improvements (Waiman Long)
   - spinlock micro-optimization (Matthew Wilcox)
   - qspinlocks: Provide a liveness guarantee (more fairness) on x86.
     (Peter Zijlstra)
   - Add support for relative references in jump tables on arm64, x86
     and s390 to optimize jump labels (Ard Biesheuvel, Heiko Carstens)
   - Be a lot less permissive on weird (kernel address) uaccess faults
     on x86: BUG() when uaccess helpers fault on kernel addresses (Jann
     Horn)
   - macrofy x86 asm statements to un-confuse the GCC inliner. (Nadav
     Amit)
   - ... and a handful of other smaller changes as well"
* 'locking-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (57 commits)
  locking/lockdep: Make global debug_locks* variables read-mostly
  locking/lockdep: Fix debug_locks off performance problem
  locking/pvqspinlock: Extend node size when pvqspinlock is configured
  locking/qspinlock_stat: Count instances of nested lock slowpaths
  locking/qspinlock, x86: Provide liveness guarantee
  x86/asm: 'Simplify' GEN_*_RMWcc() macros
  locking/qspinlock: Rework some comments
  locking/qspinlock: Re-order code
  locking/lockdep: Remove duplicated 'lock_class_ops' percpu array
  x86/defconfig: Enable CONFIG_USB_XHCI_HCD=y
  futex: Replace spin_is_locked() with lockdep
  locking/lockdep: Make class->ops a percpu counter and move it under CONFIG_DEBUG_LOCKDEP=y
  x86/jump-labels: Macrofy inline assembly code to work around GCC inlining bugs
  x86/cpufeature: Macrofy inline assembly code to work around GCC inlining bugs
  x86/extable: Macrofy inline assembly code to work around GCC inlining bugs
  x86/paravirt: Work around GCC inlining bugs when compiling paravirt ops
  x86/bug: Macrofy the BUG table section handling, to work around GCC inlining bugs
  x86/alternatives: Macrofy lock prefixes to work around GCC inlining bugs
  x86/refcount: Work around GCC inlining bug
  x86/objtool: Use asm macros to work around GCC inlining bugs
  ...
Diffstat (limited to 'arch/x86/include/asm/alternative-asm.h')
| -rw-r--r-- | arch/x86/include/asm/alternative-asm.h | 20 | 
1 files changed, 14 insertions, 6 deletions
| diff --git a/arch/x86/include/asm/alternative-asm.h b/arch/x86/include/asm/alternative-asm.h index 31b627b43a8e..8e4ea39e55d0 100644 --- a/arch/x86/include/asm/alternative-asm.h +++ b/arch/x86/include/asm/alternative-asm.h | |||
| @@ -7,16 +7,24 @@ | |||
| 7 | #include <asm/asm.h> | 7 | #include <asm/asm.h> | 
| 8 | 8 | ||
| 9 | #ifdef CONFIG_SMP | 9 | #ifdef CONFIG_SMP | 
| 10 | .macro LOCK_PREFIX | 10 | .macro LOCK_PREFIX_HERE | 
| 11 | 672: lock | ||
| 12 | .pushsection .smp_locks,"a" | 11 | .pushsection .smp_locks,"a" | 
| 13 | .balign 4 | 12 | .balign 4 | 
| 14 | .long 672b - . | 13 | .long 671f - . # offset | 
| 15 | .popsection | 14 | .popsection | 
| 16 | .endm | 15 | 671: | 
| 16 | .endm | ||
| 17 | |||
| 18 | .macro LOCK_PREFIX insn:vararg | ||
| 19 | LOCK_PREFIX_HERE | ||
| 20 | lock \insn | ||
| 21 | .endm | ||
| 17 | #else | 22 | #else | 
| 18 | .macro LOCK_PREFIX | 23 | .macro LOCK_PREFIX_HERE | 
| 19 | .endm | 24 | .endm | 
| 25 | |||
| 26 | .macro LOCK_PREFIX insn:vararg | ||
| 27 | .endm | ||
| 20 | #endif | 28 | #endif | 
| 21 | 29 | ||
| 22 | /* | 30 | /* | 
