Source to iokit/IOKit/ppc/IOSharedLockImp.h
/*
* Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
*
* @APPLE_LICENSE_HEADER_START@
*
* The contents of this file constitute Original Code as defined in and
* are subject to the Apple Public Source License Version 1.1 (the
* "License"). You may not use this file except in compliance with the
* License. Please obtain a copy of the License at
* http://www.apple.com/publicsource and read it before using this file.
*
* This Original Code and all software distributed under the License are
* distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
* License for the specific language governing rights and limitations
* under the License.
*
* @APPLE_LICENSE_HEADER_END@
*/
/*
* Copyright (c) 1998 Apple Computer, Inc. All rights reserved.
*
* HISTORY
*
*/
/* Copyright (c) 1992 NeXT Computer, Inc. All rights reserved.
*
* EventShmemLock.h - Shared memory area locks for use between the
* WindowServer and the Event Driver.
*
* HISTORY
* 30 Nov 1992 Ben Fathi ([email protected])
* Ported to m98k.
*
* 29 April 1992 Mike Paquette at NeXT
* Created.
*
* Multiprocessor locks used within the shared memory area between the
* kernel and event system. These must work in both user and kernel mode.
* The locks are defined in an include file so they get exported to the local
* include file area.
*/
#ifndef _IOKIT_IOSHAREDLOCKIMP_H
#define _IOKIT_IOSHAREDLOCKIMP_H
#include <architecture/ppc/asm_help.h>
// 'Till we're building in kernel
.macro DISABLE_PREEMPTION
#ifdef KERNEL
#endif
.endmacro
.macro ENABLE_PREEMPTION
#ifdef KERNEL
#endif
.endmacro
/*
* void
* ev_lock(p)
* register int *p;
*
* Lock the lock pointed to by p. Spin (possibly forever) until
* the lock is available. Test and test and set logic used.
*/
TEXT
#ifndef KERNEL
LEAF(_ev_lock)
LEAF(_IOSpinLock)
li a6,1 // lock value
lwarx a7,0,a0 // CEMV10
9:
sync
lwarx a7,0,a0 // read the lock
cmpwi cr0,a7,0 // is it busy?
bne- 9b // yes, spin
sync
stwcx. a6,0,a0 // try to get the lock
bne- 9b // failed, try again
isync
blr // got it, return
END(_ev_lock)
#endif
/*
* void
* spin_unlock(p)
* int *p;
*
* Unlock the lock pointed to by p.
*/
LEAF(_ev_unlock)
LEAF(_IOSpinUnlock)
sync
li a7,0
stw a7,0(a0)
ENABLE_PREEMPTION()
blr
END(_ev_unlock)
/*
* ev_try_lock(p)
* int *p;
*
* Try to lock p. Return TRUE if successful in obtaining lock.
*/
LEAF(_ev_try_lock)
LEAF(_IOTrySpinLock)
li a6,1 // lock value
DISABLE_PREEMPTION()
lwarx a7,0,a0 // CEMV10
8:
sync
lwarx a7,0,a0 // read the lock
cmpwi cr0,a7,0 // is it busy?
bne- 9f // yes, give up
sync
stwcx. a6,0,a0 // try to get the lock
bne- 8b // failed, try again
li a0,1 // return TRUE
isync
blr
9:
ENABLE_PREEMPTION()
li a0,0 // return FALSE
blr
END(_ev_try_lock)
#endif /* ! _IOKIT_IOSHAREDLOCKIMP_H */