diff options
| author | Takashi Iwai <tiwai@suse.de> | 2018-03-12 17:30:38 +0100 | 
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2018-03-12 17:30:38 +0100 | 
| commit | db45dc9540ea4864bb9d22eed30d3e70ed5d56d4 (patch) | |
| tree | c611d75097036ff464e9af31aa729e34c863ec93 /kernel/locking/qspinlock.c | |
| parent | 40088dc4e1ead7df31728c73f5b51d71da18831d (diff) | |
| parent | a3e39ed1f40e14f24bec0f91c4fa0408fb6c4d02 (diff) | |
Merge tag 'asoc-fix-v4.16-rc5' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-linus
ASoC: Fixes for v4.16
This is a fairly standard collection of fixes, there's no changes to the
core here just a bunch of small device specific changes for single
drivers plus an update to the MAINTAINERS file for the sgl5000.
Diffstat (limited to 'kernel/locking/qspinlock.c')
| -rw-r--r-- | kernel/locking/qspinlock.c | 21 | 
1 files changed, 15 insertions, 6 deletions
| diff --git a/kernel/locking/qspinlock.c b/kernel/locking/qspinlock.c index 38ece035039e..d880296245c5 100644 --- a/kernel/locking/qspinlock.c +++ b/kernel/locking/qspinlock.c @@ -379,6 +379,14 @@ queue:  	tail = encode_tail(smp_processor_id(), idx);  	node += idx; + +	/* +	 * Ensure that we increment the head node->count before initialising +	 * the actual node. If the compiler is kind enough to reorder these +	 * stores, then an IRQ could overwrite our assignments. +	 */ +	barrier(); +  	node->locked = 0;  	node->next = NULL;  	pv_init_node(node); @@ -408,14 +416,15 @@ queue:  	 */  	if (old & _Q_TAIL_MASK) {  		prev = decode_tail(old); +  		/* -		 * The above xchg_tail() is also a load of @lock which -		 * generates, through decode_tail(), a pointer.  The address -		 * dependency matches the RELEASE of xchg_tail() such that -		 * the subsequent access to @prev happens after. +		 * We must ensure that the stores to @node are observed before +		 * the write to prev->next. The address dependency from +		 * xchg_tail is not sufficient to ensure this because the read +		 * component of xchg_tail is unordered with respect to the +		 * initialisation of @node.  		 */ - -		WRITE_ONCE(prev->next, node); +		smp_store_release(&prev->next, node);  		pv_wait_node(node, prev);  		arch_mcs_spin_lock_contended(&node->locked); | 
