| 1 | /* $Id: spinlock.c 142 2000-04-23 14:55:46Z ktk $ */
|
|---|
| 2 |
|
|---|
| 3 | //******************************************************************************
|
|---|
| 4 | // OS/2 implementation of Linux spinlock kernel services
|
|---|
| 5 | //
|
|---|
| 6 | // Copyright 2000 Sander van Leeuwen (sandervl@xs4all.nl)
|
|---|
| 7 | //
|
|---|
| 8 | // This program is free software; you can redistribute it and/or
|
|---|
| 9 | // modify it under the terms of the GNU General Public License as
|
|---|
| 10 | // published by the Free Software Foundation; either version 2 of
|
|---|
| 11 | // the License, or (at your option) any later version.
|
|---|
| 12 | //
|
|---|
| 13 | // This program is distributed in the hope that it will be useful,
|
|---|
| 14 | // but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|---|
| 15 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|---|
| 16 | // GNU General Public License for more details.
|
|---|
| 17 | //
|
|---|
| 18 | // You should have received a copy of the GNU General Public
|
|---|
| 19 | // License along with this program; if not, write to the Free
|
|---|
| 20 | // Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139,
|
|---|
| 21 | // USA.
|
|---|
| 22 | //
|
|---|
| 23 | //******************************************************************************
|
|---|
| 24 | #include "hwaccess.h"
|
|---|
| 25 | #include <linux/init.h>
|
|---|
| 26 | #include <linux/poll.h>
|
|---|
| 27 | #include <asm/uaccess.h>
|
|---|
| 28 | #include <asm/hardirq.h>
|
|---|
| 29 |
|
|---|
| 30 | void spin_lock_init(spinlock_t *lock)
|
|---|
| 31 | {
|
|---|
| 32 | *lock = 0;
|
|---|
| 33 | }
|
|---|
| 34 |
|
|---|
| 35 | void spin_lock(spinlock_t *lock)
|
|---|
| 36 | {
|
|---|
| 37 | unsigned long cpuflags;
|
|---|
| 38 |
|
|---|
| 39 | _asm {
|
|---|
| 40 | pushfd
|
|---|
| 41 | pop eax
|
|---|
| 42 | mov [cpuflags], eax
|
|---|
| 43 | cli
|
|---|
| 44 | }
|
|---|
| 45 | *lock = cpuflags;
|
|---|
| 46 | }
|
|---|
| 47 |
|
|---|
| 48 | void spin_lock_flag(spinlock_t *lock, unsigned long *flag)
|
|---|
| 49 | {
|
|---|
| 50 | spin_lock(lock);
|
|---|
| 51 | }
|
|---|
| 52 |
|
|---|
| 53 | #if 0
|
|---|
| 54 | int spin_trylock(spinlock_t *lock)
|
|---|
| 55 | {
|
|---|
| 56 | return 0;
|
|---|
| 57 | }
|
|---|
| 58 |
|
|---|
| 59 | void spin_unlock_wait(spinlock_t *lock)
|
|---|
| 60 | {
|
|---|
| 61 |
|
|---|
| 62 | }
|
|---|
| 63 | #endif
|
|---|
| 64 |
|
|---|
| 65 | void spin_unlock(spinlock_t *lock)
|
|---|
| 66 | {
|
|---|
| 67 | unsigned long cpuflags = *lock;
|
|---|
| 68 |
|
|---|
| 69 | _asm {
|
|---|
| 70 | mov eax, [cpuflags]
|
|---|
| 71 | push eax
|
|---|
| 72 | popfd
|
|---|
| 73 | }
|
|---|
| 74 | }
|
|---|