summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64/dev
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/sparc64/dev')
-rw-r--r--sys/arch/sparc64/dev/zs.c69
1 files changed, 58 insertions, 11 deletions
diff --git a/sys/arch/sparc64/dev/zs.c b/sys/arch/sparc64/dev/zs.c
index 5c3f822fc68..a5fc66e45d2 100644
--- a/sys/arch/sparc64/dev/zs.c
+++ b/sys/arch/sparc64/dev/zs.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: zs.c,v 1.13 2003/06/24 21:54:39 henric Exp $ */
+/* $OpenBSD: zs.c,v 1.14 2004/09/23 18:00:58 jason Exp $ */
/* $NetBSD: zs.c,v 1.29 2001/05/30 15:24:24 lukem Exp $ */
/*-
@@ -68,6 +68,7 @@
#include <dev/cons.h>
#include <sparc64/dev/z8530reg.h>
+#include <sparc64/dev/fhcvar.h>
#include <ddb/db_output.h>
#include <sparc64/dev/cons.h>
@@ -157,22 +158,23 @@ struct consdev zs_consdev = {
****************************************************************/
/* Definition of the driver for autoconfig. */
-static int zs_match_mainbus(struct device *, void *, void *);
-static void zs_attach_mainbus(struct device *, struct device *, void *);
+static int zs_match_sbus(struct device *, void *, void *);
+static void zs_attach_sbus(struct device *, struct device *, void *);
+
+static int zs_match_fhc(struct device *, void *, void *);
+static void zs_attach_fhc(struct device *, struct device *, void *);
static void zs_attach(struct zsc_softc *, struct zsdevice *, int);
static int zs_print(void *, const char *name);
-/* Do we really need this ? */
-struct cfattach zs_ca = {
- sizeof(struct zsc_softc), zs_match_mainbus, zs_attach_mainbus
+struct cfattach zs_sbus_ca = {
+ sizeof(struct zsc_softc), zs_match_sbus, zs_attach_sbus
};
-struct cfattach zs_mainbus_ca = {
- sizeof(struct zsc_softc), zs_match_mainbus, zs_attach_mainbus
+struct cfattach zs_fhc_ca = {
+ sizeof(struct zsc_softc), zs_match_fhc, zs_attach_fhc
};
-extern struct cfdriver zs_cd;
extern int stdinnode;
extern int fbnode;
@@ -194,7 +196,7 @@ void zs_disable(struct zs_chanstate *);
* Is the zs chip present?
*/
static int
-zs_match_mainbus(parent, vcf, aux)
+zs_match_sbus(parent, vcf, aux)
struct device *parent;
void *vcf;
void *aux;
@@ -208,8 +210,22 @@ zs_match_mainbus(parent, vcf, aux)
return (1);
}
+static int
+zs_match_fhc(parent, vcf, aux)
+ struct device *parent;
+ void *vcf;
+ void *aux;
+{
+ struct cfdata *cf = vcf;
+ struct fhc_attach_args *fa = aux;
+
+ if (strcmp(cf->cf_driver->cd_name, fa->fa_name) != 0)
+ return (0);
+ return (1);
+}
+
static void
-zs_attach_mainbus(parent, self, aux)
+zs_attach_sbus(parent, self, aux)
struct device *parent;
struct device *self;
void *aux;
@@ -263,6 +279,37 @@ zs_attach_mainbus(parent, self, aux)
zs_attach(zsc, zsaddr[zs_unit], sa->sa_pri);
}
+static void
+zs_attach_fhc(parent, self, aux)
+ struct device *parent;
+ struct device *self;
+ void *aux;
+{
+ struct zsc_softc *zsc = (void *) self;
+ struct fhc_attach_args *fa = aux;
+ int zs_unit = zsc->zsc_dev.dv_unit;
+
+ bus_space_handle_t kvaddr;
+
+ if (fhc_bus_map(fa->fa_bustag, fa->fa_reg[0].fbr_slot,
+ fa->fa_reg[0].fbr_offset, fa->fa_reg[0].fbr_size,
+ BUS_SPACE_MAP_LINEAR, &kvaddr) != 0) {
+ printf("%s @ fhc: cannot map registers\n", self->dv_xname);
+ return;
+ }
+ zsaddr[zs_unit] =
+ (struct zsdevice *) bus_space_vaddr(fa->fa_bustag, kvaddr);
+
+ zsc->zsc_bustag = fa->fa_bustag;
+ zsc->zsc_dmatag = NULL;
+ zsc->zsc_promunit = getpropint(fa->fa_node, "slave", -2);
+ zsc->zsc_node = fa->fa_node;
+ printf("\n");
+#if 0
+ zs_attach(zsc, zsaddr[zs_unit], sa->sa_pri);
+#endif
+}
+
/*
* Attach a found zs.
*