From 11726c37b143029cf62f48d93100f88af3039ca5 Mon Sep 17 00:00:00 2001 From: gallatin Date: Sun, 28 May 2000 02:40:53 +0000 Subject: Allow platform specific isa interrupt setup & teardown routines in preparation for sable/lynx support --- sys/alpha/include/cpuconf.h | 5 +++++ sys/alpha/isa/isa.c | 12 +++++++++++- 2 files changed, 16 insertions(+), 1 deletion(-) (limited to 'sys/alpha') diff --git a/sys/alpha/include/cpuconf.h b/sys/alpha/include/cpuconf.h index 02ceb8b..8bdb794 100644 --- a/sys/alpha/include/cpuconf.h +++ b/sys/alpha/include/cpuconf.h @@ -47,6 +47,7 @@ * */ struct device; /* XXX */ +struct resource; /* XXX */ extern struct platform { /* @@ -75,6 +76,10 @@ extern struct platform { void (*pci_intr_disable) __P((int)); void (*pci_intr_enable) __P((int)); int (*pci_setup_ide_intr) __P((int chan, void (*fn)(void*), void *arg)); + int (*isa_setup_intr) __P((struct device *, struct device *, + struct resource *, int, void *, void *, void **)); + int (*isa_teardown_intr) __P((struct device *, struct device *, + struct resource *, void *)); } platform; /* diff --git a/sys/alpha/isa/isa.c b/sys/alpha/isa/isa.c index eee09dd..7e37660 100644 --- a/sys/alpha/isa/isa.c +++ b/sys/alpha/isa/isa.c @@ -42,6 +42,7 @@ #include #include #include +#include static struct rman isa_irq_rman; static struct rman isa_drq_rman; @@ -298,7 +299,11 @@ isa_setup_intr(device_t dev, device_t child, { struct isa_intr *ii; int error; - + + if (platform.isa_setup_intr) + return platform.isa_setup_intr(dev, child, irq, flags, + intr, arg, cookiep); + error = rman_activate_resource(irq); if (error) return error; @@ -334,6 +339,11 @@ isa_teardown_intr(device_t dev, device_t child, { struct isa_intr *ii = cookie; + if (platform.isa_teardown_intr) { + platform.isa_teardown_intr(dev, child, irq, cookie); + return 0; + } + alpha_teardown_intr(ii->ih); isa_intr_disable(irq->r_start); -- cgit v1.1