Fix a very old, very stupid race clearing the mask bit for the current

interrupt.  Other bits in imen and icu+1 are volatile.

INTREN() and INTRDIS() in icu.h need to be changed similarly.

Change #include's to 2.0 style.
This commit is contained in:
bde 1994-11-01 23:29:50 +00:00
parent 2fc13b8dd2
commit 4d89ead91e
3 changed files with 15 additions and 12 deletions

View File

@ -1,11 +1,10 @@
/* /*
* from: vector.s, 386BSD 0.1 unknown origin * from: vector.s, 386BSD 0.1 unknown origin
* $Id: vector.s,v 1.8 1994/08/18 05:09:36 davidg Exp $ * $Id: vector.s,v 1.9 1994/09/20 21:35:49 bde Exp $
*/ */
#include "i386/isa/icu.h" #include <i386/isa/icu.h>
#include "i386/isa/isa.h" #include <i386/isa/isa.h>
#include "vector.h"
#define ICU_EOI 0x20 /* XXX - define elsewhere */ #define ICU_EOI 0x20 /* XXX - define elsewhere */
@ -185,11 +184,13 @@ Xresume/**/irq_num: ; \
movl %eax,_cpl ; \ movl %eax,_cpl ; \
sti ; \ sti ; \
call *_intr_handler + (irq_num) * 4 ; \ call *_intr_handler + (irq_num) * 4 ; \
cli ; /* must unmask _imen and icu atomically */ \
movb _imen + IRQ_BYTE(irq_num),%al ; \ movb _imen + IRQ_BYTE(irq_num),%al ; \
andb $~IRQ_BIT(irq_num),%al ; \ andb $~IRQ_BIT(irq_num),%al ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \ movb %al,_imen + IRQ_BYTE(irq_num) ; \
FASTER_NOP ; \ FASTER_NOP ; \
outb %al,$icu+1 ; \ outb %al,$icu+1 ; \
sti ; /* XXX _doreti repeats the cli/sti */ \
MEXITCOUNT ; \ MEXITCOUNT ; \
/* We could usually avoid the following jmp by inlining some of */ \ /* We could usually avoid the following jmp by inlining some of */ \
/* _doreti, but it's probably better to use less cache. */ \ /* _doreti, but it's probably better to use less cache. */ \

View File

@ -1,11 +1,10 @@
/* /*
* from: vector.s, 386BSD 0.1 unknown origin * from: vector.s, 386BSD 0.1 unknown origin
* $Id: vector.s,v 1.8 1994/08/18 05:09:36 davidg Exp $ * $Id: vector.s,v 1.9 1994/09/20 21:35:49 bde Exp $
*/ */
#include "i386/isa/icu.h" #include <i386/isa/icu.h>
#include "i386/isa/isa.h" #include <i386/isa/isa.h>
#include "vector.h"
#define ICU_EOI 0x20 /* XXX - define elsewhere */ #define ICU_EOI 0x20 /* XXX - define elsewhere */
@ -185,11 +184,13 @@ Xresume/**/irq_num: ; \
movl %eax,_cpl ; \ movl %eax,_cpl ; \
sti ; \ sti ; \
call *_intr_handler + (irq_num) * 4 ; \ call *_intr_handler + (irq_num) * 4 ; \
cli ; /* must unmask _imen and icu atomically */ \
movb _imen + IRQ_BYTE(irq_num),%al ; \ movb _imen + IRQ_BYTE(irq_num),%al ; \
andb $~IRQ_BIT(irq_num),%al ; \ andb $~IRQ_BIT(irq_num),%al ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \ movb %al,_imen + IRQ_BYTE(irq_num) ; \
FASTER_NOP ; \ FASTER_NOP ; \
outb %al,$icu+1 ; \ outb %al,$icu+1 ; \
sti ; /* XXX _doreti repeats the cli/sti */ \
MEXITCOUNT ; \ MEXITCOUNT ; \
/* We could usually avoid the following jmp by inlining some of */ \ /* We could usually avoid the following jmp by inlining some of */ \
/* _doreti, but it's probably better to use less cache. */ \ /* _doreti, but it's probably better to use less cache. */ \

View File

@ -1,11 +1,10 @@
/* /*
* from: vector.s, 386BSD 0.1 unknown origin * from: vector.s, 386BSD 0.1 unknown origin
* $Id: vector.s,v 1.8 1994/08/18 05:09:36 davidg Exp $ * $Id: vector.s,v 1.9 1994/09/20 21:35:49 bde Exp $
*/ */
#include "i386/isa/icu.h" #include <i386/isa/icu.h>
#include "i386/isa/isa.h" #include <i386/isa/isa.h>
#include "vector.h"
#define ICU_EOI 0x20 /* XXX - define elsewhere */ #define ICU_EOI 0x20 /* XXX - define elsewhere */
@ -185,11 +184,13 @@ Xresume/**/irq_num: ; \
movl %eax,_cpl ; \ movl %eax,_cpl ; \
sti ; \ sti ; \
call *_intr_handler + (irq_num) * 4 ; \ call *_intr_handler + (irq_num) * 4 ; \
cli ; /* must unmask _imen and icu atomically */ \
movb _imen + IRQ_BYTE(irq_num),%al ; \ movb _imen + IRQ_BYTE(irq_num),%al ; \
andb $~IRQ_BIT(irq_num),%al ; \ andb $~IRQ_BIT(irq_num),%al ; \
movb %al,_imen + IRQ_BYTE(irq_num) ; \ movb %al,_imen + IRQ_BYTE(irq_num) ; \
FASTER_NOP ; \ FASTER_NOP ; \
outb %al,$icu+1 ; \ outb %al,$icu+1 ; \
sti ; /* XXX _doreti repeats the cli/sti */ \
MEXITCOUNT ; \ MEXITCOUNT ; \
/* We could usually avoid the following jmp by inlining some of */ \ /* We could usually avoid the following jmp by inlining some of */ \
/* _doreti, but it's probably better to use less cache. */ \ /* _doreti, but it's probably better to use less cache. */ \