summaryrefslogtreecommitdiff
path: root/sys/arch/powerpc
diff options
context:
space:
mode:
authorDale Rahn <drahn@cvs.openbsd.org>2001-02-20 04:20:36 +0000
committerDale Rahn <drahn@cvs.openbsd.org>2001-02-20 04:20:36 +0000
commitfc61358e90ca7a0f612ce404e5222bd98617af9f (patch)
treebf88d642a250e52d482d8b7c768362477a2f66b4 /sys/arch/powerpc
parent2f4e656a4107f51f881a252f0fa77f091918b875 (diff)
Add edge/level sense detection capability to the interrupt controller,
changes from NetBSD, been in my tree for a while.
Diffstat (limited to 'sys/arch/powerpc')
-rw-r--r--sys/arch/powerpc/mac/openpic.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/sys/arch/powerpc/mac/openpic.c b/sys/arch/powerpc/mac/openpic.c
index 0c609e3473a..e7004707b72 100644
--- a/sys/arch/powerpc/mac/openpic.c
+++ b/sys/arch/powerpc/mac/openpic.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: openpic.c,v 1.8 2000/09/07 18:03:28 deraadt Exp $ */
+/* $OpenBSD: openpic.c,v 1.9 2001/02/20 04:20:35 drahn Exp $ */
/*-
* Copyright (c) 1995 Per Fogelstrom
@@ -85,7 +85,7 @@ extern u_int32_t *heathrow_FCR;
static __inline u_int openpic_read __P((int));
static __inline void openpic_write __P((int, u_int));
-void openpic_enable_irq __P((int));
+void openpic_enable_irq __P((int, int));
void openpic_disable_irq __P((int));
void openpic_init();
void openpic_set_priority __P((int, int));
@@ -425,7 +425,7 @@ intr_calculatemasks()
for (irq = 0; irq < ICU_LEN; irq++) {
if (intrhand[irq]) {
irqs |= 1 << irq;
- openpic_enable_irq(hwirq[irq]);
+ openpic_enable_irq(hwirq[irq], intrtype[irq]);
} else {
openpic_disable_irq(hwirq[irq]);
}
@@ -555,20 +555,26 @@ int irq_mask;
int irq;
for ( irq = 0; irq <= virq_max; irq++) {
if (irq_mask & (1 << irq)) {
- openpic_enable_irq(hwirq[irq]);
+ openpic_enable_irq(hwirq[irq], intrtype[irq]);
} else {
openpic_disable_irq(hwirq[irq]);
}
}
}
void
-openpic_enable_irq(irq)
+openpic_enable_irq(irq, type)
int irq;
+ int type;
{
u_int x;
x = openpic_read(OPENPIC_SRC_VECTOR(irq));
- x &= ~OPENPIC_IMASK;
+ x &= ~(OPENPIC_IMASK|OPENPIC_SENSE_LEVEL|OPENPIC_SENSE_EDGE);
+ if (type == IST_LEVEL) {
+ x |= OPENPIC_SENSE_LEVEL;
+ } else {
+ x |= OPENPIC_SENSE_EDGE;
+ }
openpic_write(OPENPIC_SRC_VECTOR(irq), x);
}