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