Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/fdt Fix an issue with interrupt controller lookup wr...
details: https://anonhg.NetBSD.org/src/rev/174710575006
branches: trunk
changeset: 354311:174710575006
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sun Jun 11 12:56:36 2017 +0000
description:
Fix an issue with interrupt controller lookup wrt cascading interrupt
controllers.
diffstat:
sys/dev/fdt/fdt_intr.c | 42 ++++++++++++++++++++++--------------------
1 files changed, 22 insertions(+), 20 deletions(-)
diffs (98 lines):
diff -r 0e06953dbc8e -r 174710575006 sys/dev/fdt/fdt_intr.c
--- a/sys/dev/fdt/fdt_intr.c Sun Jun 11 11:04:20 2017 +0000
+++ b/sys/dev/fdt/fdt_intr.c Sun Jun 11 12:56:36 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: fdt_intr.c,v 1.10 2017/06/02 13:12:33 jmcneill Exp $ */
+/* $NetBSD: fdt_intr.c,v 1.11 2017/06/11 12:56:36 jmcneill Exp $ */
/*-
* Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: fdt_intr.c,v 1.10 2017/06/02 13:12:33 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: fdt_intr.c,v 1.11 2017/06/11 12:56:36 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -44,6 +44,11 @@
struct fdtbus_interrupt_controller *ic_next;
};
+struct fdtbus_interrupt_cookie {
+ struct fdtbus_interrupt_controller *c_ic;
+ void *c_ih;
+};
+
static struct fdtbus_interrupt_controller *fdtbus_ic = NULL;
static bool has_interrupt_map(int);
@@ -79,7 +84,7 @@
}
static struct fdtbus_interrupt_controller *
-fdtbus_get_interrupt_controller_ic(int phandle)
+fdtbus_get_interrupt_controller(int phandle)
{
struct fdtbus_interrupt_controller * ic;
for (ic = fdtbus_ic; ic; ic = ic->ic_next) {
@@ -90,17 +95,6 @@
return NULL;
}
-static struct fdtbus_interrupt_controller *
-fdtbus_get_interrupt_controller(int phandle)
-{
- const int ic_phandle = fdtbus_get_interrupt_parent(phandle);
- if (ic_phandle < 0) {
- return NULL;
- }
-
- return fdtbus_get_interrupt_controller_ic(ic_phandle);
-}
-
int
fdtbus_register_interrupt_controller(device_t dev, int phandle,
const struct fdtbus_interrupt_controller_func *funcs)
@@ -123,8 +117,10 @@
int (*func)(void *), void *arg)
{
struct fdtbus_interrupt_controller *ic;
+ struct fdtbus_interrupt_cookie *c = NULL;
u_int *specifier;
int ihandle;
+ void *ih;
specifier = get_specifier_by_index(phandle, index, &ihandle);
if (specifier == NULL)
@@ -134,17 +130,23 @@
if (ic == NULL)
return NULL;
- return ic->ic_funcs->establish(ic->ic_dev, specifier,
+ ih = ic->ic_funcs->establish(ic->ic_dev, specifier,
ipl, flags, func, arg);
+ if (ih != NULL) {
+ c = kmem_alloc(sizeof(*c), KM_SLEEP);
+ c->c_ic = ic;
+ c->c_ih = ih;
+ }
+
+ return c;
}
void
-fdtbus_intr_disestablish(int phandle, void *ih)
+fdtbus_intr_disestablish(int phandle, void *cookie)
{
- struct fdtbus_interrupt_controller *ic;
-
- ic = fdtbus_get_interrupt_controller(phandle);
- KASSERT(ic != NULL);
+ struct fdtbus_interrupt_cookie *c = cookie;
+ struct fdtbus_interrupt_controller *ic = c->c_ic;
+ void *ih = c->c_ih;
return ic->ic_funcs->disestablish(ic->ic_dev, ih);
}
Home |
Main Index |
Thread Index |
Old Index