summaryrefslogtreecommitdiff
path: root/sys/arch/alpha
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/alpha')
-rw-r--r--sys/arch/alpha/alpha/interrupt.c120
-rw-r--r--sys/arch/alpha/alpha/machdep.c5
-rw-r--r--sys/arch/alpha/dev/shared_intr.c10
-rw-r--r--sys/arch/alpha/include/cpuconf.h4
-rw-r--r--sys/arch/alpha/include/intr.h41
-rw-r--r--sys/arch/alpha/pci/pci_1000.c43
-rw-r--r--sys/arch/alpha/pci/pci_1000a.c38
-rw-r--r--sys/arch/alpha/pci/pci_2100_a50.c3
-rw-r--r--sys/arch/alpha/pci/pci_550.c46
-rw-r--r--sys/arch/alpha/pci/pci_6600.c45
-rw-r--r--sys/arch/alpha/pci/pci_axppci_33.c3
-rw-r--r--sys/arch/alpha/pci/pci_eb164.c46
-rw-r--r--sys/arch/alpha/pci/pci_eb64plus.c44
-rw-r--r--sys/arch/alpha/pci/pci_kn20aa.c49
-rw-r--r--sys/arch/alpha/pci/pci_up1000.c3
-rw-r--r--sys/arch/alpha/pci/sio_pic.c20
-rw-r--r--sys/arch/alpha/tc/tcasic.c6
17 files changed, 301 insertions, 225 deletions
diff --git a/sys/arch/alpha/alpha/interrupt.c b/sys/arch/alpha/alpha/interrupt.c
index a37a1984b3d..6dc85203c96 100644
--- a/sys/arch/alpha/alpha/interrupt.c
+++ b/sys/arch/alpha/alpha/interrupt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: interrupt.c,v 1.19 2006/02/23 20:14:13 miod Exp $ */
+/* $OpenBSD: interrupt.c,v 1.20 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: interrupt.c,v 1.46 2000/06/03 20:47:36 thorpej Exp $ */
/*-
@@ -124,8 +124,105 @@ static u_int schedclk2;
extern struct evcount clk_count;
+struct scbvec scb_iovectab[SCB_VECTOIDX(SCB_SIZE - SCB_IOVECBASE)];
+
void netintr(void);
+void scb_stray(void *, u_long);
+
+void
+scb_init(void)
+{
+ u_long i;
+
+ for (i = 0; i < SCB_NIOVECS; i++) {
+ scb_iovectab[i].scb_func = scb_stray;
+ scb_iovectab[i].scb_arg = NULL;
+ }
+}
+
+void
+scb_stray(void *arg, u_long vec)
+{
+
+ printf("WARNING: stray interrupt, vector 0x%lx\n", vec);
+}
+
+void
+scb_set(u_long vec, void (*func)(void *, u_long), void *arg)
+{
+ u_long idx;
+ int s;
+
+ s = splhigh();
+
+ if (vec < SCB_IOVECBASE || vec >= SCB_SIZE ||
+ (vec & (SCB_VECSIZE - 1)) != 0)
+ panic("scb_set: bad vector 0x%lx", vec);
+
+ idx = SCB_VECTOIDX(vec - SCB_IOVECBASE);
+
+ if (scb_iovectab[idx].scb_func != scb_stray)
+ panic("scb_set: vector 0x%lx already occupied", vec);
+
+ scb_iovectab[idx].scb_func = func;
+ scb_iovectab[idx].scb_arg = arg;
+
+ splx(s);
+}
+
+u_long
+scb_alloc(void (*func)(void *, u_long), void *arg)
+{
+ u_long vec, idx;
+ int s;
+
+ s = splhigh();
+
+ /*
+ * Allocate "downwards", to avoid bumping into
+ * interrupts which are likely to be at the lower
+ * vector numbers.
+ */
+ for (vec = SCB_SIZE - SCB_VECSIZE;
+ vec >= SCB_IOVECBASE; vec -= SCB_VECSIZE) {
+ idx = SCB_VECTOIDX(vec - SCB_IOVECBASE);
+ if (scb_iovectab[idx].scb_func == scb_stray) {
+ scb_iovectab[idx].scb_func = func;
+ scb_iovectab[idx].scb_arg = arg;
+ splx(s);
+ return (vec);
+ }
+ }
+
+ splx(s);
+
+ return (SCB_ALLOC_FAILED);
+}
+
+void
+scb_free(u_long vec)
+{
+ u_long idx;
+ int s;
+
+ s = splhigh();
+
+ if (vec < SCB_IOVECBASE || vec >= SCB_SIZE ||
+ (vec & (SCB_VECSIZE - 1)) != 0)
+ panic("scb_free: bad vector 0x%lx", vec);
+
+ idx = SCB_VECTOIDX(vec - SCB_IOVECBASE);
+
+ if (scb_iovectab[idx].scb_func == scb_stray)
+ panic("scb_free: vector 0x%lx is empty", vec);
+
+ scb_iovectab[idx].scb_func = scb_stray;
+ scb_iovectab[idx].scb_arg = (void *) vec;
+
+ splx(s);
+}
+
void
interrupt(unsigned long a0, unsigned long a1, unsigned long a2,
struct trapframe *framep)
@@ -205,15 +302,22 @@ interrupt(unsigned long a0, unsigned long a1, unsigned long a2,
break;
case ALPHA_INTR_DEVICE: /* I/O device interrupt */
+ {
+ struct scbvec *scb;
+
+ KDASSERT(a1 >= SCB_IOVECBASE && a1 < SCB_SIZE);
+
#if defined(MULTIPROCESSOR)
/* XXX XXX XXX */
if (CPU_IS_PRIMARY(ci) == 0)
return;
#endif
uvmexp.intrs++;
- if (platform.iointr)
- (*platform.iointr)(framep, a1);
+
+ scb = &scb_iovectab[SCB_VECTOIDX(a1 - SCB_IOVECBASE)];
+ (*scb->scb_func)(scb->scb_arg, a1);
break;
+ }
case ALPHA_INTR_PERF: /* performance counter interrupt */
printf("WARNING: received performance counter interrupt!\n");
@@ -243,16 +347,6 @@ interrupt(unsigned long a0, unsigned long a1, unsigned long a2,
}
void
-set_iointr(void (*niointr)(void *, unsigned long))
-{
-
- if (platform.iointr)
- panic("set iointr twice");
- platform.iointr = niointr;
-}
-
-
-void
machine_check(unsigned long mces, struct trapframe *framep,
unsigned long vector, unsigned long param)
{
diff --git a/sys/arch/alpha/alpha/machdep.c b/sys/arch/alpha/alpha/machdep.c
index 2f9cfb65729..26ef3141f1f 100644
--- a/sys/arch/alpha/alpha/machdep.c
+++ b/sys/arch/alpha/alpha/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.100 2006/06/07 21:50:52 miod Exp $ */
+/* $OpenBSD: machdep.c,v 1.101 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: machdep.c,v 1.210 2000/06/01 17:12:38 thorpej Exp $ */
/*-
@@ -250,6 +250,9 @@ alpha_init(pfn, ptb, bim, bip, biv)
ALPHA_TBIA();
alpha_pal_imb();
+ /* Initialize the SCB. */
+ scb_init();
+
cpu_id = cpu_number();
#if defined(MULTIPROCESSOR)
diff --git a/sys/arch/alpha/dev/shared_intr.c b/sys/arch/alpha/dev/shared_intr.c
index 685e3e92f28..b5d8f8c9480 100644
--- a/sys/arch/alpha/dev/shared_intr.c
+++ b/sys/arch/alpha/dev/shared_intr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: shared_intr.c,v 1.14 2006/01/29 10:47:35 martin Exp $ */
+/* $OpenBSD: shared_intr.c,v 1.15 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: shared_intr.c,v 1.13 2000/03/19 01:46:18 thorpej Exp $ */
/*
@@ -215,6 +215,14 @@ alpha_shared_intr_isactive(intr, num)
return (!TAILQ_EMPTY(&intr[num].intr_q));
}
+int
+alpha_shared_intr_firstactive(struct alpha_shared_intr *intr, unsigned int num)
+{
+
+ return (!TAILQ_EMPTY(&intr[num].intr_q) &&
+ TAILQ_NEXT(intr[num].intr_q.tqh_first, ih_q) == NULL);
+}
+
void
alpha_shared_intr_set_dfltsharetype(intr, num, newdfltsharetype)
struct alpha_shared_intr *intr;
diff --git a/sys/arch/alpha/include/cpuconf.h b/sys/arch/alpha/include/cpuconf.h
index 565f03dcd0a..cd3e9f5103a 100644
--- a/sys/arch/alpha/include/cpuconf.h
+++ b/sys/arch/alpha/include/cpuconf.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpuconf.h,v 1.4 2000/11/08 21:27:18 ericj Exp $ */
+/* $OpenBSD: cpuconf.h,v 1.5 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: cpuconf.h,v 1.12 2000/06/08 03:10:06 thorpej Exp $ */
/*
@@ -62,13 +62,11 @@ struct platform {
* Platform Specific Function Hooks
* cons_init - console initialization
* device_register - boot configuration aid
- * iointr - I/O interrupt handler
* clockintr - Clock Interrupt Handler
* mcheck_handler - Platform Specific Machine Check Handler
*/
void (*cons_init)(void);
void (*device_register)(struct device *, void *);
- void (*iointr)(void *, unsigned long);
void (*clockintr)(struct clockframe *);
void (*mcheck_handler)(unsigned long, struct trapframe *,
unsigned long, unsigned long);
diff --git a/sys/arch/alpha/include/intr.h b/sys/arch/alpha/include/intr.h
index 5576f4bcc6e..5fb16d23e34 100644
--- a/sys/arch/alpha/include/intr.h
+++ b/sys/arch/alpha/include/intr.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: intr.h,v 1.22 2006/03/12 03:14:36 brad Exp $ */
+/* $OpenBSD: intr.h,v 1.23 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: intr.h,v 1.26 2000/06/03 20:47:41 thorpej Exp $ */
/*-
@@ -74,6 +74,34 @@
#include <machine/atomic.h>
/*
+ * The Alpha System Control Block. This is 8k long, and you get
+ * 16 bytes per vector (i.e. the vector numbers are spaced 16
+ * apart).
+ *
+ * This is sort of a "shadow" SCB -- rather than the CPU jumping
+ * to (SCBaddr + (16 * vector)), like it does on the VAX, we get
+ * a vector number in a1. We use the SCB to look up a routine/arg
+ * and jump to it.
+ *
+ * Since we use the SCB only for I/O interrupts, we make it shorter
+ * than normal, starting it at vector 0x800 (the start of the I/O
+ * interrupt vectors).
+ */
+#define SCB_IOVECBASE 0x0800
+#define SCB_VECSIZE 0x0010
+#define SCB_SIZE 0x2000
+
+#define SCB_VECTOIDX(x) ((x) >> 4)
+#define SCB_IDXTOVEC(x) ((x) << 4)
+
+#define SCB_NIOVECS SCB_VECTOIDX(SCB_SIZE - SCB_IOVECBASE)
+
+struct scbvec {
+ void (*scb_func)(void *, u_long);
+ void *scb_arg;
+};
+
+/*
* Alpha interrupts come in at one of 4 levels:
*
* software interrupt level
@@ -237,6 +265,8 @@ int alpha_shared_intr_get_sharetype(struct alpha_shared_intr *,
unsigned int);
int alpha_shared_intr_isactive(struct alpha_shared_intr *,
unsigned int);
+int alpha_shared_intr_firstactive(struct alpha_shared_intr *,
+ unsigned int);
void alpha_shared_intr_set_dfltsharetype(struct alpha_shared_intr *,
unsigned int, int);
void alpha_shared_intr_set_maxstrays(struct alpha_shared_intr *,
@@ -250,7 +280,14 @@ void alpha_shared_intr_set_private(struct alpha_shared_intr *,
void *alpha_shared_intr_get_private(struct alpha_shared_intr *,
unsigned int);
-void set_iointr(void (*)(void *, unsigned long));
+extern struct scbvec scb_iovectab[];
+
+void scb_init(void);
+void scb_set(u_long, void (*)(void *, u_long), void *);
+u_long scb_alloc(void (*)(void *, u_long), void *);
+void scb_free(u_long);
+
+#define SCB_ALLOC_FAILED ((u_long) -1)
#endif /* _KERNEL */
#endif /* ! _ALPHA_INTR_H_ */
diff --git a/sys/arch/alpha/pci/pci_1000.c b/sys/arch/alpha/pci/pci_1000.c
index ce33786300e..b61b0c75c0e 100644
--- a/sys/arch/alpha/pci/pci_1000.c
+++ b/sys/arch/alpha/pci/pci_1000.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_1000.c,v 1.4 2006/03/26 20:23:08 brad Exp $ */
+/* $OpenBSD: pci_1000.c,v 1.5 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_1000.c,v 1.12 2001/07/27 00:25:20 thorpej Exp $ */
/*
@@ -103,7 +103,7 @@ void dec_1000_intr_disestablish(void *, void *);
struct alpha_shared_intr *dec_1000_pci_intr;
-void dec_1000_iointr(void *framep, unsigned long vec);
+void dec_1000_iointr(void *arg, unsigned long vec);
void dec_1000_enable_intr(int irq);
void dec_1000_disable_intr(int irq);
void pci_1000_imi(void);
@@ -146,7 +146,6 @@ pci_1000_pickintr(core, iot, memt, pc)
#if NSIO > 0 || NPCEB > 0
sio_intr_setup(pc, iot);
#endif
- set_iointr(dec_1000_iointr);
}
int
@@ -227,7 +226,8 @@ dec_1000_intr_establish(ccv, ih, level, func, arg, name)
level, func, arg, name);
if (cookie != NULL &&
- alpha_shared_intr_isactive(dec_1000_pci_intr, ih)) {
+ alpha_shared_intr_firstactive(dec_1000_pci_intr, ih)) {
+ scb_set(0x900 + SCB_IDXTOVEC(ih), dec_1000_iointr, NULL);
dec_1000_enable_intr(ih);
}
return (cookie);
@@ -249,39 +249,28 @@ dec_1000_intr_disestablish(ccv, cookie)
dec_1000_disable_intr(irq);
alpha_shared_intr_set_dfltsharetype(dec_1000_pci_intr, irq,
IST_NONE);
+ scb_free(0x900 + SCB_IDXTOVEC(irq));
}
splx(s);
}
void
-dec_1000_iointr(framep, vec)
- void *framep;
+dec_1000_iointr(arg, vec)
+ void *arg;
unsigned long vec;
{
int irq;
- if (vec >= 0x900) {
- if (vec >= 0x900 + (PCI_NIRQ << 4))
- panic("dec_1000_iointr: vec 0x%lx out of range", vec);
- irq = (vec - 0x900) >> 4;
-
- if (!alpha_shared_intr_dispatch(dec_1000_pci_intr, irq)) {
- alpha_shared_intr_stray(dec_1000_pci_intr, irq,
- "dec_1000 irq");
- if (ALPHA_SHARED_INTR_DISABLE(dec_1000_pci_intr, irq))
- dec_1000_disable_intr(irq);
- } else
- alpha_shared_intr_reset_strays(dec_1000_pci_intr, irq);
- return;
- }
-#if NSIO > 0 || NPCEB > 0
- if (vec >= 0x800) {
- sio_iointr(framep, vec);
- return;
- }
-#endif
- panic("dec_1000_intr: weird vec 0x%lx", vec);
+ irq = SCB_VECTOIDX(vec - 0x900);
+
+ if (!alpha_shared_intr_dispatch(dec_1000_pci_intr, irq)) {
+ alpha_shared_intr_stray(dec_1000_pci_intr, irq,
+ "dec_1000 irq");
+ if (ALPHA_SHARED_INTR_DISABLE(dec_1000_pci_intr, irq))
+ dec_1000_disable_intr(irq);
+ } else
+ alpha_shared_intr_reset_strays(dec_1000_pci_intr, irq);
}
/*
diff --git a/sys/arch/alpha/pci/pci_1000a.c b/sys/arch/alpha/pci/pci_1000a.c
index 41ee3118968..fb3cbd72d21 100644
--- a/sys/arch/alpha/pci/pci_1000a.c
+++ b/sys/arch/alpha/pci/pci_1000a.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_1000a.c,v 1.4 2006/03/26 20:23:08 brad Exp $ */
+/* $OpenBSD: pci_1000a.c,v 1.5 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_1000a.c,v 1.14 2001/07/27 00:25:20 thorpej Exp $ */
/*
@@ -150,7 +150,6 @@ pci_1000a_pickintr(core, iot, memt, pc)
#if NSIO > 0 || NPCEB > 0
sio_intr_setup(pc, iot);
#endif
- set_iointr(dec_1000a_iointr);
}
int
@@ -248,8 +247,10 @@ dec_1000a_intr_establish(ccv, ih, level, func, arg, name)
level, func, arg, name);
if (cookie != NULL &&
- alpha_shared_intr_isactive(dec_1000a_pci_intr, ih)) {
+ alpha_shared_intr_firstactive(dec_1000a_pci_intr, ih)) {
+ scb_set(0x900 + SCB_IDXTOVEC(ih), dec_1000a_iointr, NULL);
dec_1000a_enable_intr(ih);
+
}
return (cookie);
}
@@ -270,6 +271,7 @@ dec_1000a_intr_disestablish(ccv, cookie)
dec_1000a_disable_intr(irq);
alpha_shared_intr_set_dfltsharetype(dec_1000a_pci_intr, irq,
IST_NONE);
+ scb_free(0x900 + SCB_IDXTOVEC(irq));
}
splx(s);
@@ -282,27 +284,15 @@ dec_1000a_iointr(framep, vec)
{
int irq;
- if (vec >= 0x900) {
- if (vec >= 0x900 + (PCI_NIRQ << 4))
- panic("dec_1000_iointr: vec 0x%lx out of range", vec);
- irq = (vec - 0x900) >> 4;
-
- if (!alpha_shared_intr_dispatch(dec_1000a_pci_intr, irq)) {
- alpha_shared_intr_stray(dec_1000a_pci_intr, irq,
- "dec_1000a irq");
- if (ALPHA_SHARED_INTR_DISABLE(dec_1000a_pci_intr, irq))
- dec_1000a_disable_intr(irq);
- } else
- alpha_shared_intr_reset_strays(dec_1000a_pci_intr, irq);
- return;
- }
-#if NSIO > 0 || NPCEB > 0
- if (vec >= 0x800) {
- sio_iointr(framep, vec);
- return;
- }
-#endif
- panic("dec_1000a_intr: weird vec 0x%lx", vec);
+ irq = SCB_VECTOIDX(vec - 0x900);
+
+ if (!alpha_shared_intr_dispatch(dec_1000a_pci_intr, irq)) {
+ alpha_shared_intr_stray(dec_1000a_pci_intr, irq,
+ "dec_1000a irq");
+ if (ALPHA_SHARED_INTR_DISABLE(dec_1000a_pci_intr, irq))
+ dec_1000a_disable_intr(irq);
+ } else
+ alpha_shared_intr_reset_strays(dec_1000a_pci_intr, irq);
}
/*
diff --git a/sys/arch/alpha/pci/pci_2100_a50.c b/sys/arch/alpha/pci/pci_2100_a50.c
index 7183e73e66f..fdeaa46396a 100644
--- a/sys/arch/alpha/pci/pci_2100_a50.c
+++ b/sys/arch/alpha/pci/pci_2100_a50.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_2100_a50.c,v 1.19 2002/03/14 03:15:50 millert Exp $ */
+/* $OpenBSD: pci_2100_a50.c,v 1.20 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_2100_a50.c,v 1.12 1996/11/13 21:13:29 cgd Exp $ */
/*
@@ -91,7 +91,6 @@ pci_2100_a50_pickintr(acp)
#if NSIO
sio_intr_setup(pc, iot);
- set_iointr(&sio_iointr);
#else
panic("pci_2100_a50_pickintr: no I/O interrupt handler (no sio)");
#endif
diff --git a/sys/arch/alpha/pci/pci_550.c b/sys/arch/alpha/pci/pci_550.c
index afecb9d760e..b7c712a9f30 100644
--- a/sys/arch/alpha/pci/pci_550.c
+++ b/sys/arch/alpha/pci/pci_550.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_550.c,v 1.15 2006/03/26 20:23:08 brad Exp $ */
+/* $OpenBSD: pci_550.c,v 1.16 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_550.c,v 1.18 2000/06/29 08:58:48 mrg Exp $ */
/*-
@@ -126,7 +126,7 @@ void dec_550_pciide_compat_intr_disestablish(void *, void *);
struct alpha_shared_intr *dec_550_pci_intr;
-void dec_550_iointr(void *framep, unsigned long vec);
+void dec_550_iointr(void *arg, unsigned long vec);
void dec_550_intr_enable(int irq);
void dec_550_intr_disable(int irq);
@@ -171,8 +171,6 @@ pci_550_pickintr(ccp)
#if NSIO
sio_intr_setup(pc, iot);
#endif
-
- set_iointr(dec_550_iointr);
}
int
@@ -319,8 +317,11 @@ dec_550_intr_establish(ccv, ih, level, func, arg, name)
cookie = alpha_shared_intr_establish(dec_550_pci_intr, ih, IST_LEVEL,
level, func, arg, name);
- if (cookie != NULL && alpha_shared_intr_isactive(dec_550_pci_intr, ih))
+ if (cookie != NULL &&
+ alpha_shared_intr_firstactive(dec_550_pci_intr, ih)) {
+ scb_set(0x900 + SCB_IDXTOVEC(ih), dec_550_iointr, NULL);
dec_550_intr_enable(ih);
+ }
return (cookie);
}
@@ -354,6 +355,7 @@ dec_550_intr_disestablish(ccv, cookie)
dec_550_intr_disable(irq);
alpha_shared_intr_set_dfltsharetype(dec_550_pci_intr, irq,
IST_NONE);
+ scb_free(0x900 + SCB_IDXTOVEC(irq));
}
splx(s);
@@ -397,34 +399,24 @@ dec_550_pciide_compat_intr_disestablish(v, cookie)
}
void
-dec_550_iointr(framep, vec)
- void *framep;
+dec_550_iointr(arg, vec)
+ void *arg;
unsigned long vec;
{
int irq;
- if (vec >= 0x900) {
- irq = ((vec - 0x900) >> 4);
+ irq = SCB_VECTOIDX(vec - 0x900);
- if (irq >= DEC_550_MAX_IRQ)
- panic("550_iointr: vec 0x%lx out of range", vec);
+ if (irq >= DEC_550_MAX_IRQ)
+ panic("550_iointr: vec 0x%lx out of range\n", vec);
- if (!alpha_shared_intr_dispatch(dec_550_pci_intr, irq)) {
- alpha_shared_intr_stray(dec_550_pci_intr, irq,
- "dec 550 irq");
- if (ALPHA_SHARED_INTR_DISABLE(dec_550_pci_intr, irq))
- dec_550_intr_disable(irq);
- } else
- alpha_shared_intr_reset_strays(dec_550_pci_intr, irq);
- return;
- }
-#if NSIO
- if (vec >= 0x800) {
- sio_iointr(framep, vec);
- return;
- }
-#endif
- panic("dec_550_iointr: weird vec 0x%lx", vec);
+ if (!alpha_shared_intr_dispatch(dec_550_pci_intr, irq)) {
+ alpha_shared_intr_stray(dec_550_pci_intr, irq,
+ "dec 550 irq");
+ if (ALPHA_SHARED_INTR_DISABLE(dec_550_pci_intr, irq))
+ dec_550_intr_disable(irq);
+ } else
+ alpha_shared_intr_reset_strays(dec_550_pci_intr, irq);
}
void
diff --git a/sys/arch/alpha/pci/pci_6600.c b/sys/arch/alpha/pci/pci_6600.c
index 50d1366ad08..6fd5fd8849a 100644
--- a/sys/arch/alpha/pci/pci_6600.c
+++ b/sys/arch/alpha/pci/pci_6600.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_6600.c,v 1.14 2006/03/26 20:23:08 brad Exp $ */
+/* $OpenBSD: pci_6600.c,v 1.15 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_6600.c,v 1.5 2000/06/06 00:50:15 thorpej Exp $ */
/*-
@@ -88,7 +88,7 @@ void dec_6600_pciide_compat_intr_disestablish(void *, void *);
struct alpha_shared_intr *dec_6600_pci_intr;
-void dec_6600_iointr(void *framep, unsigned long vec);
+void dec_6600_iointr(void *arg, unsigned long vec);
extern void dec_6600_intr_enable(int irq);
extern void dec_6600_intr_disable(int irq);
@@ -129,7 +129,6 @@ pci_6600_pickintr(pcp)
sio_intr_setup(pc, iot);
dec_6600_intr_enable(55); /* irq line for sio */
#endif
- set_iointr(dec_6600_iointr);
}
}
@@ -239,8 +238,11 @@ dec_6600_intr_establish(acv, ih, level, func, arg, name)
cookie = alpha_shared_intr_establish(dec_6600_pci_intr, ih, IST_LEVEL,
level, func, arg, name);
- if (cookie != NULL && alpha_shared_intr_isactive(dec_6600_pci_intr, ih))
+ if (cookie != NULL &&
+ alpha_shared_intr_firstactive(dec_6600_pci_intr, ih)) {
+ scb_set(0x900 + SCB_IDXTOVEC(ih), dec_6600_iointr, NULL);
dec_6600_intr_enable(ih);
+ }
return (cookie);
}
@@ -272,40 +274,31 @@ dec_6600_intr_disestablish(acv, cookie)
dec_6600_intr_disable(irq);
alpha_shared_intr_set_dfltsharetype(dec_6600_pci_intr, irq,
IST_NONE);
+ scb_free(0x900 + SCB_IDXTOVEC(irq));
}
splx(s);
}
void
-dec_6600_iointr(framep, vec)
- void *framep;
+dec_6600_iointr(arg, vec)
+ void *arg;
unsigned long vec;
{
int irq;
- if (vec >= 0x900) {
- irq = (vec - 0x900) >> 4;
+ irq = SCB_VECTOIDX(vec - 0x900);
- if (irq >= PCI_NIRQ)
- panic("iointr: irq %d is too high", irq);
+ if (irq >= PCI_NIRQ)
+ panic("iointr: irq %d is too high", irq);
- if (!alpha_shared_intr_dispatch(dec_6600_pci_intr, irq)) {
- alpha_shared_intr_stray(dec_6600_pci_intr, irq,
- irqtype);
- if (ALPHA_SHARED_INTR_DISABLE(dec_6600_pci_intr, irq))
- dec_6600_intr_disable(irq);
- } else
- alpha_shared_intr_reset_strays(dec_6600_pci_intr, irq);
- return;
- }
-#if NSIO
- if (vec >= 0x800) {
- sio_iointr(framep, vec);
- return;
- }
-#endif
- panic("iointr: weird vec 0x%lx", vec);
+ if (!alpha_shared_intr_dispatch(dec_6600_pci_intr, irq)) {
+ alpha_shared_intr_stray(dec_6600_pci_intr, irq,
+ irqtype);
+ if (ALPHA_SHARED_INTR_DISABLE(dec_6600_pci_intr, irq))
+ dec_6600_intr_disable(irq);
+ } else
+ alpha_shared_intr_reset_strays(dec_6600_pci_intr, irq);
}
void
diff --git a/sys/arch/alpha/pci/pci_axppci_33.c b/sys/arch/alpha/pci/pci_axppci_33.c
index dd129f525f1..17a506fbdaa 100644
--- a/sys/arch/alpha/pci/pci_axppci_33.c
+++ b/sys/arch/alpha/pci/pci_axppci_33.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_axppci_33.c,v 1.17 2002/03/14 03:15:50 millert Exp $ */
+/* $OpenBSD: pci_axppci_33.c,v 1.18 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_axppci_33.c,v 1.10 1996/11/13 21:13:29 cgd Exp $ */
/*
@@ -92,7 +92,6 @@ pci_axppci_33_pickintr(lcp)
#if NSIO
sio_intr_setup(pc, iot);
- set_iointr(&sio_iointr);
#else
panic("pci_axppci_33_pickintr: no I/O interrupt handler (no sio)");
#endif
diff --git a/sys/arch/alpha/pci/pci_eb164.c b/sys/arch/alpha/pci/pci_eb164.c
index 2920fcffb0b..2d1f3345e06 100644
--- a/sys/arch/alpha/pci/pci_eb164.c
+++ b/sys/arch/alpha/pci/pci_eb164.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_eb164.c,v 1.18 2006/03/26 20:23:08 brad Exp $ */
+/* $OpenBSD: pci_eb164.c,v 1.19 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_eb164.c,v 1.27 2000/06/06 00:50:15 thorpej Exp $ */
/*-
@@ -115,7 +115,7 @@ struct alpha_shared_intr *eb164_pci_intr;
bus_space_tag_t eb164_intrgate_iot;
bus_space_handle_t eb164_intrgate_ioh;
-void eb164_iointr(void *framep, unsigned long vec);
+void eb164_iointr(void *arg, unsigned long vec);
extern void eb164_intr_enable(int irq); /* pci_eb164_intr.S */
extern void eb164_intr_disable(int irq); /* pci_eb164_intr.S */
@@ -161,8 +161,6 @@ pci_eb164_pickintr(ccp)
sio_intr_setup(pc, iot);
eb164_intr_enable(EB164_SIO_IRQ);
#endif
-
- set_iointr(eb164_iointr);
}
int
@@ -283,8 +281,11 @@ dec_eb164_intr_establish(ccv, ih, level, func, arg, name)
cookie = alpha_shared_intr_establish(eb164_pci_intr, ih, IST_LEVEL,
level, func, arg, name);
- if (cookie != NULL && alpha_shared_intr_isactive(eb164_pci_intr, ih))
+ if (cookie != NULL &&
+ alpha_shared_intr_firstactive(eb164_pci_intr, ih)) {
+ scb_set(0x900 + SCB_IDXTOVEC(ih), eb164_iointr, NULL);
eb164_intr_enable(ih);
+ }
return (cookie);
}
@@ -307,6 +308,7 @@ dec_eb164_intr_disestablish(ccv, cookie)
eb164_intr_disable(irq);
alpha_shared_intr_set_dfltsharetype(eb164_pci_intr, irq,
IST_NONE);
+ scb_free(0x900 + SCB_IDXTOVEC(irq));
}
splx(s);
@@ -350,33 +352,21 @@ dec_eb164_pciide_compat_intr_disestablish(void *v, void *cookie)
}
void
-eb164_iointr(framep, vec)
- void *framep;
+eb164_iointr(arg, vec)
+ void *arg;
unsigned long vec;
{
int irq;
- if (vec >= 0x900) {
- if (vec >= 0x900 + (EB164_MAX_IRQ << 4))
- panic("eb164_iointr: vec 0x%lx out of range", vec);
- irq = (vec - 0x900) >> 4;
-
- if (!alpha_shared_intr_dispatch(eb164_pci_intr, irq)) {
- alpha_shared_intr_stray(eb164_pci_intr, irq,
- "eb164 irq");
- if (ALPHA_SHARED_INTR_DISABLE(eb164_pci_intr, irq))
- eb164_intr_disable(irq);
- } else
- alpha_shared_intr_reset_strays(eb164_pci_intr, irq);
- return;
- }
-#if NSIO
- if (vec >= 0x800) {
- sio_iointr(framep, vec);
- return;
- }
-#endif
- panic("eb164_iointr: weird vec 0x%lx", vec);
+ irq = SCB_VECTOIDX(vec - 0x900);
+
+ if (!alpha_shared_intr_dispatch(eb164_pci_intr, irq)) {
+ alpha_shared_intr_stray(eb164_pci_intr, irq,
+ "eb164 irq");
+ if (ALPHA_SHARED_INTR_DISABLE(eb164_pci_intr, irq))
+ eb164_intr_disable(irq);
+ } else
+ alpha_shared_intr_reset_strays(eb164_pci_intr, irq);
}
#if 0 /* THIS DOES NOT WORK! see pci_eb164_intr.S. */
diff --git a/sys/arch/alpha/pci/pci_eb64plus.c b/sys/arch/alpha/pci/pci_eb64plus.c
index 32a080055f4..6ad999ef7c5 100644
--- a/sys/arch/alpha/pci/pci_eb64plus.c
+++ b/sys/arch/alpha/pci/pci_eb64plus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_eb64plus.c,v 1.8 2006/03/26 20:23:08 brad Exp $ */
+/* $OpenBSD: pci_eb64plus.c,v 1.9 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_eb64plus.c,v 1.10 2001/07/27 00:25:20 thorpej Exp $ */
/*-
@@ -143,7 +143,6 @@ pci_eb64plus_pickintr(acp)
#if NSIO
sio_intr_setup(pc, iot);
#endif
- set_iointr(eb64plus_iointr);
}
int
@@ -217,9 +216,11 @@ dec_eb64plus_intr_establish(acv, ih, level, func, arg, name)
cookie = alpha_shared_intr_establish(eb64plus_pci_intr, ih, IST_LEVEL,
level, func, arg, name);
- if (cookie != NULL && alpha_shared_intr_isactive(eb64plus_pci_intr, ih))
+ if (cookie != NULL &&
+ alpha_shared_intr_firstactive(eb64plus_pci_intr, ih)) {
+ scb_set(0x900 + SCB_IDXTOVEC(ih), eb64plus_iointr, NULL);
eb64plus_intr_enable(ih);
-
+ }
return (cookie);
}
@@ -239,39 +240,28 @@ dec_eb64plus_intr_disestablish(acv, cookie)
eb64plus_intr_disable(irq);
alpha_shared_intr_set_dfltsharetype(eb64plus_pci_intr, irq,
IST_NONE);
+ scb_free(0x900 + SCB_IDXTOVEC(irq));
}
splx(s);
}
void
-eb64plus_iointr(framep, vec)
- void *framep;
+eb64plus_iointr(arg, vec)
+ void *arg;
unsigned long vec;
{
int irq;
- if (vec >= 0x900) {
- if (vec >= 0x900 + (EB64PLUS_MAX_IRQ << 4))
- panic("eb64plus_iointr: vec 0x%lx out of range", vec);
- irq = (vec - 0x900) >> 4;
-
- if (!alpha_shared_intr_dispatch(eb64plus_pci_intr, irq)) {
- alpha_shared_intr_stray(eb64plus_pci_intr, irq,
- "eb64+ irq");
- if (ALPHA_SHARED_INTR_DISABLE(eb64plus_pci_intr, irq))
- eb64plus_intr_disable(irq);
- } else
- alpha_shared_intr_reset_strays(eb64plus_pci_intr, irq);
- return;
- }
-#if NSIO
- if (vec >= 0x800) {
- sio_iointr(framep, vec);
- return;
- }
-#endif
- panic("eb64plus_iointr: weird vec 0x%lx", vec);
+ irq = SCB_VECTOIDX(vec - 0x900);
+
+ if (!alpha_shared_intr_dispatch(eb64plus_pci_intr, irq)) {
+ alpha_shared_intr_stray(eb64plus_pci_intr, irq,
+ "eb64+ irq");
+ if (ALPHA_SHARED_INTR_DISABLE(eb64plus_pci_intr, irq))
+ eb64plus_intr_disable(irq);
+ } else
+ alpha_shared_intr_reset_strays(eb64plus_pci_intr, irq);
}
#if 0 /* THIS DOES NOT WORK! see pci_eb64plus_intr.S. */
diff --git a/sys/arch/alpha/pci/pci_kn20aa.c b/sys/arch/alpha/pci/pci_kn20aa.c
index e9b39642e39..c9678760ade 100644
--- a/sys/arch/alpha/pci/pci_kn20aa.c
+++ b/sys/arch/alpha/pci/pci_kn20aa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_kn20aa.c,v 1.21 2006/01/29 10:47:35 martin Exp $ */
+/* $OpenBSD: pci_kn20aa.c,v 1.22 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_kn20aa.c,v 1.21 1996/11/17 02:05:27 cgd Exp $ */
/*
@@ -69,7 +69,7 @@ void dec_kn20aa_intr_disestablish(void *, void *);
struct alpha_shared_intr *kn20aa_pci_intr;
struct evcount kn20aa_intr_count;
-void kn20aa_iointr(void *framep, unsigned long vec);
+void kn20aa_iointr(void *arg, unsigned long vec);
void kn20aa_enable_intr(int irq);
void kn20aa_disable_intr(int irq);
@@ -101,8 +101,6 @@ pci_kn20aa_pickintr(ccp)
sio_intr_setup(pc, iot);
kn20aa_enable_intr(KN20AA_PCEB_IRQ);
#endif
-
- set_iointr(kn20aa_iointr);
}
int
@@ -211,8 +209,10 @@ dec_kn20aa_intr_establish(ccv, ih, level, func, arg, name)
level, func, arg, name);
if (cookie != NULL &&
- alpha_shared_intr_isactive(kn20aa_pci_intr, ih))
+ alpha_shared_intr_firstactive(kn20aa_pci_intr, ih)) {
+ scb_set(0x900 + SCB_IDXTOVEC(ih), kn20aa_iointr, NULL);
kn20aa_enable_intr(ih);
+ }
return (cookie);
}
@@ -232,42 +232,27 @@ dec_kn20aa_intr_disestablish(ccv, cookie)
kn20aa_disable_intr(irq);
alpha_shared_intr_set_dfltsharetype(kn20aa_pci_intr, irq,
IST_NONE);
- /* scb_free(0x900 + SCB_IDXTOVEC(irq)); */
+ scb_free(0x900 + SCB_IDXTOVEC(irq));
}
splx(s);
}
void
-kn20aa_iointr(framep, vec)
- void *framep;
+kn20aa_iointr(arg, vec)
+ void *arg;
unsigned long vec;
{
int irq;
- if (vec >= 0x900) {
- if (vec >= 0x900 + (KN20AA_MAX_IRQ << 4))
- panic("kn20aa_iointr: vec 0x%x out of range", vec);
- irq = (vec - 0x900) >> 4;
-
- kn20aa_intr_count.ec_count++;
-
- if (!alpha_shared_intr_dispatch(kn20aa_pci_intr, irq)) {
- alpha_shared_intr_stray(kn20aa_pci_intr, irq,
- "kn20aa irq");
- if (kn20aa_pci_intr[irq].intr_nstrays ==
- kn20aa_pci_intr[irq].intr_maxstrays)
- kn20aa_disable_intr(irq);
- } else
- alpha_shared_intr_reset_strays(kn20aa_pci_intr, irq);
- return;
- }
-#if NSIO
- if (vec >= 0x800) {
- sio_iointr(framep, vec);
- return;
- }
-#endif
- panic("kn20aa_iointr: weird vec 0x%x", vec);
+ irq = SCB_VECTOIDX(vec - 0x900);
+
+ if (!alpha_shared_intr_dispatch(kn20aa_pci_intr, irq)) {
+ alpha_shared_intr_stray(kn20aa_pci_intr, irq,
+ "kn20aa irq");
+ if (ALPHA_SHARED_INTR_DISABLE(kn20aa_pci_intr, irq))
+ kn20aa_disable_intr(irq);
+ } else
+ alpha_shared_intr_reset_strays(kn20aa_pci_intr, irq);
}
void
diff --git a/sys/arch/alpha/pci/pci_up1000.c b/sys/arch/alpha/pci/pci_up1000.c
index 3173cd91672..35fea1fff73 100644
--- a/sys/arch/alpha/pci/pci_up1000.c
+++ b/sys/arch/alpha/pci/pci_up1000.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_up1000.c,v 1.10 2006/03/26 20:23:08 brad Exp $ */
+/* $OpenBSD: pci_up1000.c,v 1.11 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: pci_up1000.c,v 1.6 2000/12/28 22:59:07 sommerfeld Exp $ */
/*-
@@ -96,7 +96,6 @@ pci_up1000_pickintr(struct irongate_config *icp)
#if NSIO
sio_intr_setup(pc, iot);
- set_iointr(&sio_iointr);
#else
panic("pci_up1000_pickintr: no I/O interrupt handler (no sio)");
#endif
diff --git a/sys/arch/alpha/pci/sio_pic.c b/sys/arch/alpha/pci/sio_pic.c
index afa3299560c..a0a3f32eabc 100644
--- a/sys/arch/alpha/pci/sio_pic.c
+++ b/sys/arch/alpha/pci/sio_pic.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sio_pic.c,v 1.25 2006/01/29 10:47:35 martin Exp $ */
+/* $OpenBSD: sio_pic.c,v 1.26 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: sio_pic.c,v 1.28 2000/06/06 03:10:13 thorpej Exp $ */
/*-
@@ -67,6 +67,7 @@
#include <sys/param.h>
#include <sys/systm.h>
+
#include <sys/device.h>
#include <sys/malloc.h>
#include <sys/syslog.h>
@@ -463,9 +464,12 @@ sio_intr_establish(v, irq, type, level, fn, arg, name)
cookie = alpha_shared_intr_establish(sio_intr, irq, type, level, fn,
arg, name);
- if (cookie)
- sio_setirqstat(irq, alpha_shared_intr_isactive(sio_intr, irq),
+ if (cookie != NULL &&
+ alpha_shared_intr_firstactive(sio_intr, irq)) {
+ scb_set(0x800 + SCB_IDXTOVEC(irq), sio_iointr, NULL);
+ sio_setirqstat(irq, 1,
alpha_shared_intr_get_sharetype(sio_intr, irq));
+ }
return (cookie);
}
@@ -513,19 +517,23 @@ sio_intr_disestablish(v, cookie)
}
sio_setirqstat(irq, 0, ist);
alpha_shared_intr_set_dfltsharetype(sio_intr, irq, ist);
+
+ /* Release our SCB vector. */
+ scb_free(0x800 + SCB_IDXTOVEC(irq));
}
splx(s);
}
void
-sio_iointr(framep, vec)
- void *framep;
+sio_iointr(arg, vec)
+ void *arg;
unsigned long vec;
{
int irq;
- irq = (vec - 0x800) >> 4;
+ irq = SCB_VECTOIDX(vec - 0x800);
+
#ifdef DIAGNOSTIC
if (irq >= ICU_LEN || irq < 0)
panic("sio_iointr: irq out of range (%d)", irq);
diff --git a/sys/arch/alpha/tc/tcasic.c b/sys/arch/alpha/tc/tcasic.c
index 4662dabcd59..76aab2da124 100644
--- a/sys/arch/alpha/tc/tcasic.c
+++ b/sys/arch/alpha/tc/tcasic.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: tcasic.c,v 1.14 2006/03/16 22:32:01 miod Exp $ */
+/* $OpenBSD: tcasic.c,v 1.15 2006/06/15 20:08:29 brad Exp $ */
/* $NetBSD: tcasic.c,v 1.36 2001/08/23 01:16:52 nisimura Exp $ */
/*
@@ -140,7 +140,9 @@ tcasicattach(parent, self, aux)
tc_dma_init();
(*intr_setup)();
- set_iointr(iointr);
+
+ /* They all come in at 0x800. */
+ scb_set(0x800, iointr, NULL);
config_found(self, &tba, tcasicprint);
}