From 41ba2b7c48e08729e822be4cb557e4d9333f9614 Mon Sep 17 00:00:00 2001 From: soren Date: Thu, 29 Jun 2000 15:44:10 +0000 Subject: [PATCH] Move a few things from ip32.c. --- sys/arch/sgimips/dev/crime.c | 62 +++++++++++++++++++++++++++++++++++- 1 file changed, 61 insertions(+), 1 deletion(-) diff --git a/sys/arch/sgimips/dev/crime.c b/sys/arch/sgimips/dev/crime.c index 4c9fc59a7640..a4fbbb9f2019 100644 --- a/sys/arch/sgimips/dev/crime.c +++ b/sys/arch/sgimips/dev/crime.c @@ -1,4 +1,4 @@ -/* $NetBSD: crime.c,v 1.1 2000/06/14 16:13:54 soren Exp $ */ +/* $NetBSD: crime.c,v 1.2 2000/06/29 15:44:10 soren Exp $ */ /* * Copyright (c) 2000 Soren S. Jorvang @@ -44,15 +44,20 @@ #include #include #include +#include #include +#if 0 #include +#endif #include "locators.h" static int crime_match(struct device *, struct cfdata *, void *); static void crime_attach(struct device *, struct device *, void *); +void * crime_intr_establish(int, int, int, int (*)(void *), void *); +int crime_intr(void *); struct cfattach crime_ca = { sizeof(struct device), crime_match, crime_attach @@ -104,3 +109,58 @@ crime_attach(parent, self, aux) *(volatile u_int64_t *)0xb4000018 = 0x000000000000ffff; #endif } + +/* + * XXX + */ + +#define CRIME_NINTR 32 /* XXX */ + +struct { + int (*func)(void *); + void *arg; +} crime[CRIME_NINTR]; + +void * +crime_intr_establish(irq, type, level, func, arg) + int irq; + int type; + int level; + int (*func)(void *); + void *arg; +{ + int i; + + for (i = 0; i <= CRIME_NINTR; i++) { + if (i == CRIME_NINTR) + panic("too many IRQs"); + + if (crime[i].func != NULL) + continue; + + crime[i].func = func; + crime[i].arg = arg; + break; + } + + return (void *)-1; +} + +int +crime_intr(arg) + void *arg; +{ + int i; + + for (i = 0; i < CRIME_NINTR; i++) { +int s; + if (crime[i].func == NULL) + return 0; + +s = spltty(); + (*crime[i].func)(crime[i].arg); +splx(s); + } + + return 0; +}