From a222601bea58d10488a2942c409fda3e5890ea4c Mon Sep 17 00:00:00 2001 From: jhb Date: Wed, 18 Apr 2001 21:47:48 +0000 Subject: Convert the protection of hte i8254 from critical_enter/exit like it is on the x86. --- sys/alpha/alpha/clock.c | 31 ++++++++++++++----------------- sys/alpha/alpha/machdep.c | 1 + sys/alpha/include/mutex.h | 3 +++ sys/powerpc/include/mutex.h | 3 +++ 4 files changed, 21 insertions(+), 17 deletions(-) diff --git a/sys/alpha/alpha/clock.c b/sys/alpha/alpha/clock.c index d986ea0..7b5b749 100644 --- a/sys/alpha/alpha/clock.c +++ b/sys/alpha/alpha/clock.c @@ -49,6 +49,8 @@ #include #include +#include +#include #include #include #include @@ -80,6 +82,7 @@ int tickfixinterval; int adjkerntz; /* local offset from GMT in seconds */ int disable_rtc_set; /* disable resettodr() if != 0 */ int wall_cmos_clock; /* wall CMOS clock assumed if != 0 */ +struct mtx clock_lock; static int beeping = 0; #define TIMER_DIV(x) ((timer_freq + (x) / 2) / (x)) @@ -267,9 +270,8 @@ static int getit(void) { int high, low; - critical_t s; - s = critical_enter(); + mtx_lock_spin(&clock_lock); /* Select timer0 and latch counter value. */ outb(TIMER_MODE, TIMER_SEL0 | TIMER_LATCH); @@ -277,7 +279,7 @@ getit(void) low = inb(TIMER_CNTR0); high = inb(TIMER_CNTR0); - critical_exit(s); + mtx_unlock_spin(&clock_lock); return ((high << 8) | low); } @@ -368,9 +370,8 @@ static void set_timer_freq(u_int freq, int intr_freq) { int new_timer0_max_count; - critical_t s; - s = critical_enter(); + mtx_lock_spin(&clock_lock); timer_freq = freq; new_timer0_max_count = TIMER_DIV(intr_freq); if (new_timer0_max_count != timer0_max_count) { @@ -379,16 +380,14 @@ set_timer_freq(u_int freq, int intr_freq) outb(TIMER_CNTR0, timer0_max_count & 0xff); outb(TIMER_CNTR0, timer0_max_count >> 8); } - critical_exit(s); + mtx_unlock_spin(&clock_lock); } static void handleclock(void* arg) { if (timecounter->tc_get_timecount == i8254_get_timecount) { - critical_t s; - - s = critical_enter(); + mtx_lock_spin(&clock_lock); if (i8254_ticked) i8254_ticked = 0; else { @@ -396,7 +395,7 @@ handleclock(void* arg) i8254_lastcount = 0; } clkintr_pending = 0; - critical_exit(s); + mtx_unlock_spin(&clock_lock); } hardclock(arg); @@ -566,9 +565,8 @@ i8254_get_timecount(struct timecounter *tc) { u_int count; u_int high, low; - critical_t s; - s = critical_enter(); + mtx_lock_spin(&clock_lock); /* Select timer0 and latch counter value. */ outb(TIMER_MODE, TIMER_SEL0 | TIMER_LATCH); @@ -586,7 +584,7 @@ i8254_get_timecount(struct timecounter *tc) i8254_lastcount = count; count += i8254_offset; - critical_exit(s); + mtx_unlock_spin(&clock_lock); return (count); } @@ -638,14 +636,13 @@ sysbeepstop(void *chan) int sysbeep(int pitch, int period) { - critical_t s; - s = critical_enter(); + mtx_lock_spin(&clock_lock); if (acquire_timer2(TIMER_SQWAVE|TIMER_16BIT)) if (!beeping) { /* Something else owns it. */ - critical_exit(s); + mtx_unlock_spin(&clock_lock); return (-1); /* XXX Should be EBUSY, but nobody cares anyway. */ } @@ -659,7 +656,7 @@ sysbeep(int pitch, int period) beeping = period; timeout(sysbeepstop, (void *)NULL, period); } - critical_exit(s); + mtx_unlock_spin(&clock_lock); return (0); } diff --git a/sys/alpha/alpha/machdep.c b/sys/alpha/alpha/machdep.c index 37fa008..7803621 100644 --- a/sys/alpha/alpha/machdep.c +++ b/sys/alpha/alpha/machdep.c @@ -1017,6 +1017,7 @@ alpha_init(pfn, ptb, bim, bip, biv) mtx_init(&Giant, "Giant", MTX_DEF | MTX_RECURSE); mtx_init(&sched_lock, "sched lock", MTX_SPIN | MTX_RECURSE); mtx_init(&proc0.p_mtx, "process lock", MTX_DEF); + mtx_init(&clock_lock, "clk", MTX_SPIN); mtx_lock(&Giant); /* diff --git a/sys/alpha/include/mutex.h b/sys/alpha/include/mutex.h index fd398d7..c8bcbdd 100644 --- a/sys/alpha/include/mutex.h +++ b/sys/alpha/include/mutex.h @@ -36,6 +36,9 @@ #ifdef _KERNEL +/* Global locks */ +extern struct mtx clock_lock; + #define mtx_intr_enable(mutex) (mutex)->mtx_savecrit = ALPHA_PSL_IPL_0 #endif /* _KERNEL */ diff --git a/sys/powerpc/include/mutex.h b/sys/powerpc/include/mutex.h index fd398d7..c8bcbdd 100644 --- a/sys/powerpc/include/mutex.h +++ b/sys/powerpc/include/mutex.h @@ -36,6 +36,9 @@ #ifdef _KERNEL +/* Global locks */ +extern struct mtx clock_lock; + #define mtx_intr_enable(mutex) (mutex)->mtx_savecrit = ALPHA_PSL_IPL_0 #endif /* _KERNEL */ -- cgit v1.1