2005-04-16 18:20:36 -04:00
|
|
|
/*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*
|
2006-09-27 20:45:21 -04:00
|
|
|
* Copyright (C) 1999, 2000, 06 Ralf Baechle (ralf@linux-mips.org)
|
2005-04-16 18:20:36 -04:00
|
|
|
* Copyright (C) 1999, 2000 Silicon Graphics, Inc.
|
|
|
|
*/
|
|
|
|
#ifndef _ASM_SPINLOCK_H
|
|
|
|
#define _ASM_SPINLOCK_H
|
|
|
|
|
2016-05-26 04:35:03 -04:00
|
|
|
#include <asm/processor.h>
|
2017-06-09 20:26:42 -04:00
|
|
|
#include <asm/qrwlock.h>
|
2019-02-22 08:37:21 -05:00
|
|
|
|
|
|
|
#include <asm-generic/qspinlock_types.h>
|
|
|
|
|
|
|
|
#define queued_spin_unlock queued_spin_unlock
|
|
|
|
/**
|
|
|
|
* queued_spin_unlock - release a queued spinlock
|
|
|
|
* @lock : Pointer to queued spinlock structure
|
|
|
|
*/
|
|
|
|
static inline void queued_spin_unlock(struct qspinlock *lock)
|
|
|
|
{
|
|
|
|
/* This could be optimised with ARCH_HAS_MMIOWB */
|
|
|
|
mmiowb();
|
|
|
|
smp_store_release(&lock->locked, 0);
|
|
|
|
}
|
|
|
|
|
2017-06-09 20:26:43 -04:00
|
|
|
#include <asm/qspinlock.h>
|
2005-04-16 18:20:36 -04:00
|
|
|
|
|
|
|
#endif /* _ASM_SPINLOCK_H */
|