Home | History | Annotate | Line # | Download | only in dev
hb.c revision 1.9
      1  1.9  thorpej /*	$NetBSD: hb.c,v 1.9 2002/10/02 04:27:52 thorpej Exp $	*/
      2  1.1   tsubai 
      3  1.1   tsubai #include <sys/param.h>
      4  1.1   tsubai #include <sys/systm.h>
      5  1.1   tsubai #include <sys/device.h>
      6  1.1   tsubai 
      7  1.1   tsubai #include <machine/autoconf.h>
      8  1.1   tsubai 
      9  1.1   tsubai static int	hb_match __P((struct device *, struct cfdata *, void *));
     10  1.1   tsubai static void	hb_attach __P((struct device *, struct device *, void *));
     11  1.2   tsubai static int	hb_search __P((struct device *, struct cfdata *, void *));
     12  1.1   tsubai static int	hb_print __P((void *, const char *));
     13  1.5     matt void		hb_intr_dispatch __P((int));	/* XXX */
     14  1.1   tsubai 
     15  1.9  thorpej CFATTACH_DECL(hb, sizeof(struct device),
     16  1.9  thorpej     hb_match, hb_attach, NULL, NULL);
     17  1.1   tsubai 
     18  1.1   tsubai extern struct cfdriver hb_cd;
     19  1.1   tsubai 
     20  1.4   tsubai struct intrhand {
     21  1.4   tsubai 	int (*func) __P((void *));
     22  1.4   tsubai 	void *arg;
     23  1.4   tsubai };
     24  1.4   tsubai 
     25  1.4   tsubai #define NHBINTR	4
     26  1.4   tsubai struct intrhand hb_intrhand[6][NHBINTR];
     27  1.4   tsubai 
     28  1.1   tsubai static int
     29  1.1   tsubai hb_match(parent, cf, aux)
     30  1.1   tsubai 	struct device *parent;
     31  1.1   tsubai 	struct cfdata *cf;
     32  1.1   tsubai 	void *aux;
     33  1.1   tsubai {
     34  1.1   tsubai 	struct confargs *ca = aux;
     35  1.1   tsubai 
     36  1.1   tsubai 	if (strcmp(ca->ca_name, hb_cd.cd_name) != 0)
     37  1.1   tsubai 		return 0;
     38  1.1   tsubai 
     39  1.1   tsubai 	return 1;
     40  1.1   tsubai }
     41  1.1   tsubai 
     42  1.1   tsubai static void
     43  1.1   tsubai hb_attach(parent, self, aux)
     44  1.1   tsubai 	struct device *parent;
     45  1.1   tsubai 	struct device *self;
     46  1.1   tsubai 	void *aux;
     47  1.1   tsubai {
     48  1.3   tsubai 	struct confargs *ca = aux;
     49  1.1   tsubai 
     50  1.1   tsubai 	printf("\n");
     51  1.3   tsubai 	config_search(hb_search, self, ca);
     52  1.1   tsubai }
     53  1.1   tsubai 
     54  1.2   tsubai static int
     55  1.2   tsubai hb_search(parent, cf, aux)
     56  1.2   tsubai 	struct device *parent;
     57  1.2   tsubai 	struct cfdata *cf;
     58  1.2   tsubai 	void *aux;
     59  1.2   tsubai {
     60  1.2   tsubai 	struct confargs *ca = aux;
     61  1.2   tsubai 
     62  1.2   tsubai 	ca->ca_addr = cf->cf_addr;
     63  1.6  thorpej 	ca->ca_name = cf->cf_name;
     64  1.2   tsubai 
     65  1.7  thorpej 	if (config_match(parent, cf, ca) > 0)
     66  1.2   tsubai 		config_attach(parent, cf, ca, hb_print);
     67  1.2   tsubai 
     68  1.2   tsubai 	return 0;
     69  1.2   tsubai }
     70  1.2   tsubai 
     71  1.1   tsubai /*
     72  1.1   tsubai  * Print out the confargs.  The (parent) name is non-NULL
     73  1.1   tsubai  * when there was no match found by config_found().
     74  1.1   tsubai  */
     75  1.1   tsubai static int
     76  1.1   tsubai hb_print(args, name)
     77  1.1   tsubai 	void *args;
     78  1.1   tsubai 	const char *name;
     79  1.1   tsubai {
     80  1.1   tsubai 	struct confargs *ca = args;
     81  1.1   tsubai 
     82  1.1   tsubai 	/* Be quiet about empty HB locations. */
     83  1.1   tsubai 	if (name)
     84  1.3   tsubai 		return QUIET;
     85  1.1   tsubai 
     86  1.1   tsubai 	if (ca->ca_addr != -1)
     87  1.1   tsubai 		printf(" addr 0x%x", ca->ca_addr);
     88  1.1   tsubai 
     89  1.3   tsubai 	return UNCONF;
     90  1.4   tsubai }
     91  1.4   tsubai 
     92  1.4   tsubai void *
     93  1.4   tsubai hb_intr_establish(irq, level, func, arg)
     94  1.4   tsubai 	int irq, level;
     95  1.4   tsubai 	int (*func) __P((void *));
     96  1.4   tsubai 	void *arg;
     97  1.4   tsubai {
     98  1.4   tsubai 	struct intrhand *ih = hb_intrhand[irq];
     99  1.4   tsubai 	int i;
    100  1.4   tsubai 
    101  1.4   tsubai 	for (i = NHBINTR; i > 0; i--) {
    102  1.4   tsubai 		if (ih->func == NULL)
    103  1.4   tsubai 			goto found;
    104  1.4   tsubai 		ih++;
    105  1.4   tsubai 	}
    106  1.4   tsubai 	panic("hb_intr_establish: no room");
    107  1.4   tsubai 
    108  1.4   tsubai found:
    109  1.4   tsubai 	ih->func = func;
    110  1.4   tsubai 	ih->arg = arg;
    111  1.4   tsubai 
    112  1.4   tsubai #ifdef HB_DEBUG
    113  1.4   tsubai 	for (irq = 0; irq <= 2; irq++) {
    114  1.4   tsubai 		for (i = 0; i < NHBINTR; i++) {
    115  1.4   tsubai 			printf("%p(%p) ",
    116  1.4   tsubai 			       hb_intrhand[irq][i].func,
    117  1.4   tsubai 			       hb_intrhand[irq][i].arg);
    118  1.4   tsubai 		}
    119  1.4   tsubai 		printf("\n");
    120  1.4   tsubai 	}
    121  1.4   tsubai #endif
    122  1.4   tsubai 
    123  1.4   tsubai 	return ih;
    124  1.4   tsubai }
    125  1.4   tsubai 
    126  1.4   tsubai void
    127  1.4   tsubai hb_intr_dispatch(irq)
    128  1.4   tsubai 	int irq;
    129  1.4   tsubai {
    130  1.4   tsubai 	struct intrhand *ih;
    131  1.4   tsubai 	int i;
    132  1.4   tsubai 
    133  1.4   tsubai 	ih = hb_intrhand[irq];
    134  1.4   tsubai 	for (i = NHBINTR; i > 0; i--) {
    135  1.4   tsubai 		if (ih->func)
    136  1.4   tsubai 			(*ih->func)(ih->arg);
    137  1.4   tsubai 		ih++;
    138  1.4   tsubai 	}
    139  1.1   tsubai }
    140