summaryrefslogtreecommitdiffstats
path: root/kernel/locking/qspinlock.c
AgeCommit message (Expand)AuthorLines
2019-05-30treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 157Thomas Gleixner-10/+1
2019-04-10locking/qspinlock_stat: Introduce generic lockevent_*() counting APIsWaiman Long-4/+4
2019-02-28locking/qspinlock: Remove unnecessary BUG_ON() callWaiman Long-3/+0
2019-02-04locking/qspinlock_stat: Track the no MCS node available caseWaiman Long-1/+2
2019-02-04locking/qspinlock: Handle > 4 slowpath nesting levelsWaiman Long-0/+15
2018-10-17locking/pvqspinlock: Extend node size when pvqspinlock is configuredWaiman Long-8/+26
2018-10-17locking/qspinlock_stat: Count instances of nested lock slowpathsWaiman Long-0/+5
2018-10-16locking/qspinlock, x86: Provide liveness guaranteePeter Zijlstra-1/+15
2018-10-16locking/qspinlock: Rework some commentsPeter Zijlstra-10/+26
2018-10-16locking/qspinlock: Re-order codePeter Zijlstra-29/+27
2018-04-27locking/qspinlock: Add stat tracking for pending vs. slowpathWaiman Long-3/+11
2018-04-27locking/qspinlock: Use try_cmpxchg() instead of cmpxchg() when lockingWill Deacon-10/+9
2018-04-27locking/qspinlock: Elide back-to-back RELEASE operations with smp_wmb()Will Deacon-16/+17
2018-04-27locking/qspinlock: Use smp_cond_load_relaxed() to wait for next nodeWill Deacon-4/+2
2018-04-27locking/qspinlock: Use atomic_cond_read_acquire()Will Deacon-6/+6
2018-04-27locking/qspinlock: Kill cmpxchg() loop when claiming lock from head of queueWill Deacon-11/+8
2018-04-27locking/qspinlock: Remove unbounded cmpxchg() loop from locking slowpathWill Deacon-44/+58
2018-04-27locking/qspinlock: Bound spinning on pending->locked transition in slowpathWill Deacon-3/+17
2018-04-27locking/qspinlock: Merge 'struct __qspinlock' into 'struct qspinlock'Will Deacon-43/+3
2018-02-13locking/qspinlock: Ensure node->count is updated before initialising nodeWill Deacon-0/+8
2018-02-13locking/qspinlock: Ensure node is initialised before updating prev->nextWill Deacon-6/+7
2017-12-04locking: Remove smp_read_barrier_depends() from queued_spin_lock_slowpath()Paul E. McKenney-7/+5
2017-08-17locking: Remove spin_unlock_wait() generic definitionsPaul E. McKenney-117/+0
2017-07-08locking/qspinlock: Explicitly include asm/prefetch.hStafford Horne-0/+1
2016-06-27locking/qspinlock: Use __this_cpu_dec() instead of full-blown this_cpu_dec()Pan Xinhui-1/+1
2016-06-14locking/barriers: Introduce smp_acquire__after_ctrl_dep()Peter Zijlstra-1/+1
2016-06-14locking/barriers: Replace smp_cond_acquire() with smp_cond_load_acquire()Peter Zijlstra-6/+6
2016-06-08locking/qspinlock: Add commentsPeter Zijlstra-0/+57
2016-06-08locking/qspinlock: Clarify xchg_tail() orderingPeter Zijlstra-2/+13
2016-06-08locking/qspinlock: Fix spin_unlock_wait() some morePeter Zijlstra-0/+60
2016-02-29locking/qspinlock: Use smp_cond_acquire() in pending codeWaiman Long-4/+3
2015-12-04locking/pvqspinlock: Queue node adaptive spinningWaiman Long-2/+3
2015-12-04locking/pvqspinlock: Allow limited lock stealingWaiman Long-6/+20
2015-12-04locking, sched: Introduce smp_cond_acquire() and use itPeter Zijlstra-2/+1
2015-11-23locking/qspinlock: Avoid redundant read of next pointerWaiman Long-3/+6
2015-11-23locking/qspinlock: Prefetch the next node cachelineWaiman Long-0/+10
2015-11-23locking/qspinlock: Use _acquire/_release() versions of cmpxchg() & xchg()Waiman Long-5/+24
2015-09-11locking/qspinlock/x86: Fix performance regression under unaccelerated VMsPeter Zijlstra-1/+1
2015-08-03locking/pvqspinlock: Only kick CPU at unlock timeWaiman Long-3/+3
2015-05-08locking/pvqspinlock: Implement simple paravirt support for the qspinlockWaiman Long-1/+67
2015-05-08locking/qspinlock: Revert to test-and-set on hypervisorsPeter Zijlstra (Intel)-0/+3
2015-05-08locking/qspinlock: Use a simple write to grab the lockWaiman Long-16/+50
2015-05-08locking/qspinlock: Optimize for smaller NR_CPUSPeter Zijlstra (Intel)-1/+68
2015-05-08locking/qspinlock: Extract out code snippets for the next patchWaiman Long-31/+48
2015-05-08locking/qspinlock: Add pending bitPeter Zijlstra (Intel)-21/+98
2015-05-08locking/qspinlock: Introduce a simple generic 4-byte queued spinlockWaiman Long-0/+209