Use generic atomic_cas_uint() for mutex(9) and rwlock(9), and

remodel old RAS based _lock_cas() implementation for m68010
into genereic atomic_cas_32().
Now sun2 kernel compiles and even works on multiuser. (hehe)

Tested on tme (emulationg 2/120 and 3/150) and (real) 3/80.
This commit is contained in:
tsutsui 2008-04-05 22:47:52 +00:00
parent 7dfcdee2a2
commit c3b129605a
6 changed files with 50 additions and 51 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: frame.h,v 1.28 2007/03/13 17:17:28 thorpej Exp $ */
/* $NetBSD: frame.h,v 1.29 2008/04/05 22:47:52 tsutsui Exp $ */
/*
* Copyright (c) 1982, 1990, 1993
@ -258,23 +258,23 @@ void sendsig_sigcontext(const ksiginfo_t *, const sigset_t *);
#if defined(__mc68010__)
/*
* Restartable atomic sequence-cased compare-and-swap for locking
* primitives. We defined this here because it manipulates a
* Restartable atomic sequence-cased compare-and-swap for atomic_cas ops
* and locking primitives. We defined this here because it manipulates a
* "clockframe" as prepared by interrupt handlers.
*/
extern char _lock_cas_ras_start;
extern char _lock_cas_ras_end;
extern char _atomic_cas_ras_start;
extern char _atomic_cas_ras_end;
#define LOCK_CAS_CHECK(cfp) \
#define ATOMIC_CAS_CHECK(cfp) \
do { \
if (! CLKF_USERMODE(cfp) && \
(CLKF_PC(cfp) < (u_long)&_lock_cas_ras_end && \
CLKF_PC(cfp) > (u_long)&_lock_cas_ras_start)) { \
(cfp)->cf_pc = (u_long)&_lock_cas_ras_start; \
(CLKF_PC(cfp) < (u_long)&_atomic_cas_ras_end && \
CLKF_PC(cfp) > (u_long)&_atomic_cas_ras_start)) { \
(cfp)->cf_pc = (u_long)&_atomic_cas_ras_start; \
} \
} while (/*CONSTCOND*/0)
#else
#define LOCK_CAS_CHECK(cfp) /* nothing */
#define ATOMIC_CAS_CHECK(cfp) /* nothing */
#endif /* __mc68010__ */
#endif /* _KERNEL */

View File

@ -1,4 +1,4 @@
/* $NetBSD: mutex.h,v 1.5 2007/11/21 10:19:07 yamt Exp $ */
/* $NetBSD: mutex.h,v 1.6 2008/04/05 22:47:53 tsutsui Exp $ */
/*-
* Copyright (c) 2002, 2007 The NetBSD Foundation, Inc.
@ -72,9 +72,7 @@ struct kmutex {
#define MUTEX_RECEIVE(mtx) mb_read()
#define MUTEX_GIVE(mtx) mb_memory()
#define MUTEX_CAS(p, o, n) _lock_cas((p), (o), (n))
int _lock_cas(volatile uintptr_t *, uintptr_t, uintptr_t);
#define MUTEX_CAS(p, o, n) (atomic_cas_uint((p), (o), (n)) == (o))
#endif /* __MUTEX_PRIVATE */

View File

@ -1,4 +1,4 @@
/* $NetBSD: rwlock.h,v 1.3 2007/11/21 10:19:07 yamt Exp $ */
/* $NetBSD: rwlock.h,v 1.4 2008/04/05 22:47:53 tsutsui Exp $ */
/*-
* Copyright (c) 2002, 2006 The NetBSD Foundation, Inc.
@ -50,9 +50,7 @@ struct krwlock {
#define RW_RECEIVE(rw) /* nothing */
#define RW_GIVE(rw) /* nothing */
#define RW_CAS(p, o, n) _lock_cas((p), (o), (n))
int _lock_cas(volatile uintptr_t *, uintptr_t, uintptr_t);
#define RW_CAS(p, o, n) (atomic_cas_uint((p), (o), (n)) == (o))
#endif /* __RWLOCK_PRIVATE */

View File

@ -1,4 +1,4 @@
/* $NetBSD: lock_stubs.s,v 1.4 2007/12/02 19:28:32 ad Exp $ */
/* $NetBSD: lock_stubs.s,v 1.5 2008/04/05 22:47:53 tsutsui Exp $ */
/*-
* Copyright (c) 2007 The NetBSD Foundation, Inc.
@ -45,46 +45,49 @@
.file "lock_stubs.s"
.text
#if !defined(__mc68010__)
#if defined(__mc68010__)
/*
* int _lock_cas(uintptr_t *val, uintptr_t old, uintptr_t new);
*/
ENTRY(_lock_cas)
movl %sp@(4),%a0 | a0 = val address
movl %sp@(8),%d0 | d0 = old value
movl %sp@(12),%d1 | d1 = new value
casl %d0,%d1,%a0@ | compare old, set new
beqb 1f | matched and set
movq #0,%d0
rts
1: movq #1,%d0
rts
#else /* __mc68010__ */
/*
* int _lock_cas(uintptr_t *val, uintptr_t old, uintptr_t new);
* int _atomic_cas_32(volatile uint32_t *val, uint32_t old, uint32_t new);
*
* The 68010 does not have a cas instruction, so we implement this as
* a restartable atomic sequence. For an example of how this is used,
* see sun68k/sun68k/isr.c
*/
ENTRY_NOPROFILE(_lock_cas)
ENTRY_NOPROFILE(_atomic_cas_32)
movl %sp@(4),%a0
.globl _C_LABEL(_lock_cas_ras_start)
_C_LABEL(_lock_cas_ras_start):
.globl _C_LABEL(_atomic_cas_ras_start)
_C_LABEL(_atomic_cas_ras_start):
movl %a0@,%d0
cmpl %sp@(8),%d0
jne 1f
movl %sp@(12),%a0@
.globl _C_LABEL(_lock_cas_ras_end)
_C_LABEL(_lock_cas_ras_end):
.globl _C_LABEL(_atomic_cas_ras_end)
_C_LABEL(_atomic_cas_ras_end):
movq #1,%d0
rts
1:
clrl %d0
movl %d0, %a0 /* pointers return also in %a0 */
rts
#endif /* ! __mc68010__ */
STRONG_ALIAS(atomic_cas_ptr,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_ptr,_atomic_cas_32)
STRONG_ALIAS(atomic_cas_uint,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_uint,_atomic_cas_32)
STRONG_ALIAS(atomic_cas_ulong,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_ulong,_atomic_cas_32)
STRONG_ALIAS(atomic_cas_32,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_32,_atomic_cas_32)
STRONG_ALIAS(atomic_cas_32_ni,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_32_ni,_atomic_cas_32)
STRONG_ALIAS(atomic_cas_ptr_ni,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_ptr_ni,_atomic_cas_32)
STRONG_ALIAS(atomic_cas_uint_ni,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_uint_ni,_atomic_cas_32)
STRONG_ALIAS(atomic_cas_ulong_ni,_atomic_cas_32)
STRONG_ALIAS(_atomic_cas_ulong_ni,_atomic_cas_32)
#endif /* __mc68010__ */
#if !defined(LOCKDEBUG)

View File

@ -1,4 +1,4 @@
/* $NetBSD: clock.c,v 1.13 2008/01/26 14:02:54 tsutsui Exp $ */
/* $NetBSD: clock.c,v 1.14 2008/04/05 22:47:53 tsutsui Exp $ */
/*
* Copyright (c) 1982, 1990, 1993
@ -85,7 +85,7 @@
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.13 2008/01/26 14:02:54 tsutsui Exp $");
__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.14 2008/04/05 22:47:53 tsutsui Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@ -313,5 +313,5 @@ clock_intr(struct clockframe cf)
idepth--;
LOCK_CAS_CHECK(&cf);
ATOMIC_CAS_CHECK(&cf);
}

View File

@ -1,4 +1,4 @@
/* $NetBSD: isr.c,v 1.19 2008/01/11 10:21:26 tsutsui Exp $ */
/* $NetBSD: isr.c,v 1.20 2008/04/05 22:47:53 tsutsui Exp $ */
/*-
* Copyright (c) 1996 The NetBSD Foundation, Inc.
@ -41,7 +41,7 @@
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: isr.c,v 1.19 2008/01/11 10:21:26 tsutsui Exp $");
__KERNEL_RCSID(0, "$NetBSD: isr.c,v 1.20 2008/04/05 22:47:53 tsutsui Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@ -140,7 +140,7 @@ isr_autovec(struct clockframe cf)
out:
idepth--;
LOCK_CAS_CHECK(&cf);
ATOMIC_CAS_CHECK(&cf);
}
/*
@ -209,7 +209,7 @@ isr_vectored(struct clockframe cf)
out:
idepth--;
LOCK_CAS_CHECK(&cf);
ATOMIC_CAS_CHECK(&cf);
}
/*