From 5c6a275d22890d00126f51fb7cbff1aa01948aca Mon Sep 17 00:00:00 2001 From: Theo de Raadt Date: Sun, 1 Jan 2006 20:52:29 +0000 Subject: switch from macppc-specific maciic(4) driver to the generic iic(4), after teaching it to use a function pointer to get back to the OFW scan.. this will also help the sparc64 later; ok kettenis --- sys/arch/macppc/conf/GENERIC | 28 +++++++++++++------------- sys/arch/macppc/conf/files.macppc | 13 +++++------- sys/arch/macppc/dev/ki2c.c | 9 ++++++--- sys/arch/macppc/dev/maci2c.c | 42 ++++++--------------------------------- sys/arch/macppc/dev/maci2cvar.h | 7 ++----- sys/arch/macppc/dev/pi2c.c | 9 ++++++--- sys/arch/macppc/dev/smu.c | 11 ++++++---- 7 files changed, 46 insertions(+), 73 deletions(-) (limited to 'sys/arch') diff --git a/sys/arch/macppc/conf/GENERIC b/sys/arch/macppc/conf/GENERIC index 270841bc68c..d5896e05ab3 100644 --- a/sys/arch/macppc/conf/GENERIC +++ b/sys/arch/macppc/conf/GENERIC @@ -1,4 +1,4 @@ -# $OpenBSD: GENERIC,v 1.119 2005/12/23 04:01:11 brad Exp $g +# $OpenBSD: GENERIC,v 1.120 2006/01/01 20:52:23 deraadt Exp $g # # For further information on compiling OpenBSD kernels, see the config(8) # man page. @@ -250,22 +250,22 @@ radio* at udsbr? # USB radio ugen* at uhub? # USB Generic driver # I2C bus support -maciic* at ki2c? -maciic* at pi2c? -maciic* at smu? +iic* at ki2c? +iic* at pi2c? +iic* at smu? # I2C devices -lmtemp* at maciic? -lmenv* at maciic? -maxtmp* at maciic? -adc* at maciic? -tsl* at maciic? -admtmp* at maciic? -pcagpio* at maciic? +lmtemp* at iic? +lmenv* at iic? +maxtmp* at iic? +adc* at iic? +tsl* at iic? +admtmp* at iic? +pcagpio* at iic? gpio* at pcagpio? -maxds* at maciic? -fcu* at maciic? -adt* at maciic? +maxds* at iic? +fcu* at iic? +adt* at iic? # CardBus bus support cardbus* at cardslot? diff --git a/sys/arch/macppc/conf/files.macppc b/sys/arch/macppc/conf/files.macppc index b4d7fda95d1..b8a2ce0eba0 100644 --- a/sys/arch/macppc/conf/files.macppc +++ b/sys/arch/macppc/conf/files.macppc @@ -1,4 +1,4 @@ -# $OpenBSD: files.macppc,v 1.43 2005/12/21 18:50:51 miod Exp $ +# $OpenBSD: files.macppc,v 1.44 2006/01/01 20:52:23 deraadt Exp $ # # macppc-specific configuration info @@ -77,7 +77,7 @@ device ht {} : pcibus attach ht at mainbus file arch/macppc/pci/ht.c ht -device smu {} : i2cbus +device smu: i2cbus attach smu at mainbus file arch/macppc/dev/smu.c smu file dev/clock_subr.c smu @@ -185,13 +185,13 @@ attach mediabay at macobio file arch/macppc/dev/mediabay.c mediabay # Keywest I2C -device ki2c {} +device ki2c: i2cbus attach ki2c at macobio attach ki2c at memc with ki2c_memc file arch/macppc/dev/ki2c.c ki2c # PMU I2C -device pi2c {} +device pi2c: i2cbus attach pi2c at adb file arch/macppc/dev/pi2c.c pi2c @@ -271,10 +271,7 @@ include "dev/usb/files.usb" # Machine-independent I2C drivers # include "dev/i2c/files.i2c" - -device maciic {} : i2c -attach maciic at ki2c, pi2c, smu -file arch/macppc/dev/maci2c.c maciic +file arch/macppc/dev/maci2c.c i2cbus # # Machine-independent GPIO drivers diff --git a/sys/arch/macppc/dev/ki2c.c b/sys/arch/macppc/dev/ki2c.c index a8a7e118b55..f42eac8cf15 100644 --- a/sys/arch/macppc/dev/ki2c.c +++ b/sys/arch/macppc/dev/ki2c.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ki2c.c,v 1.11 2005/12/13 19:21:45 kettenis Exp $ */ +/* $OpenBSD: ki2c.c,v 1.12 2006/01/01 20:52:25 deraadt Exp $ */ /* $NetBSD: ki2c.c,v 1.1 2003/12/27 02:19:34 grant Exp $ */ /*- @@ -140,7 +140,7 @@ ki2c_attach(struct device *parent, struct device *self, void *aux) void ki2c_attach_bus(struct ki2c_softc *sc, struct ki2c_bus *bus, int node) { - struct maci2cbus_attach_args iba; + struct i2cbus_attach_args iba; u_int32_t reg; if (OF_getprop(node, "reg", ®, sizeof reg) != sizeof reg) @@ -153,8 +153,11 @@ ki2c_attach_bus(struct ki2c_softc *sc, struct ki2c_bus *bus, int node) bus->i2c_tag.ic_exec = ki2c_i2c_exec; bus->reg = reg; - iba.iba_node = node; + bzero(&iba, sizeof iba); + iba.iba_name = "iic"; iba.iba_tag = &bus->i2c_tag; + iba.iba_bus_scan = maciic_scan; + iba.iba_bus_scan_arg = &node; config_found(&sc->sc_dev, &iba, NULL); } diff --git a/sys/arch/macppc/dev/maci2c.c b/sys/arch/macppc/dev/maci2c.c index b3978bd87a8..d94ef65175b 100644 --- a/sys/arch/macppc/dev/maci2c.c +++ b/sys/arch/macppc/dev/maci2c.c @@ -1,4 +1,4 @@ -/* $OpenBSD: maci2c.c,v 1.4 2005/12/27 17:18:18 deraadt Exp $ */ +/* $OpenBSD: maci2c.c,v 1.5 2006/01/01 20:52:25 deraadt Exp $ */ /* * Copyright (c) 2005 Mark Kettenis @@ -25,36 +25,19 @@ #include -int maciic_match(struct device *, void *, void *); -void maciic_attach(struct device *, struct device *, void *); int maciic_print(void *, const char *); -struct cfattach maciic_ca = { - sizeof (struct device), maciic_match, maciic_attach -}; - -struct cfdriver maciic_cd = { - NULL, "maciic", DV_DULL -}; - -int -maciic_match(struct device *parent, void *cf, void *aux) -{ - return (1); -} - void -maciic_attach(struct device *parent, struct device *self, void *aux) +maciic_scan(struct device *self, struct i2cbus_attach_args *iba, void *aux) { - struct maci2cbus_attach_args *iba = aux; + int iba_node = *(int *)aux; + extern int iic_print(void *, const char *); struct i2c_attach_args ia; char name[32]; u_int32_t reg; int node; - printf("\n"); - - for (node = OF_child(iba->iba_node); node; node = OF_peer(node)) { + for (node = OF_child(iba_node); node; node = OF_peer(node)) { if (OF_getprop(node, "reg", ®, sizeof reg) != sizeof reg && OF_getprop(node, "i2c-address", ®, sizeof reg) != sizeof reg) continue; @@ -70,19 +53,6 @@ maciic_attach(struct device *parent, struct device *self, void *aux) sizeof name) && name[0]) ia.ia_name = name; if (ia.ia_name) - config_found(self, &ia, maciic_print); + config_found(self, &ia, iic_print); } } - -int -maciic_print(void *aux, const char *pnp) -{ - struct i2c_attach_args *ia = aux; - - if (pnp != NULL) { - printf("\"%s\" at %s", ia->ia_name, pnp); - } - printf(" addr 0x%x", ia->ia_addr); - - return (UNCONF); -} diff --git a/sys/arch/macppc/dev/maci2cvar.h b/sys/arch/macppc/dev/maci2cvar.h index 7dc43716b20..4575b37fa1b 100644 --- a/sys/arch/macppc/dev/maci2cvar.h +++ b/sys/arch/macppc/dev/maci2cvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: maci2cvar.h,v 1.2 2005/11/15 16:23:34 deraadt Exp $ */ +/* $OpenBSD: maci2cvar.h,v 1.3 2006/01/01 20:52:25 deraadt Exp $ */ /* * Copyright (c) 2005 Mark Kettenis @@ -18,7 +18,4 @@ #include -struct maci2cbus_attach_args { - i2c_tag_t iba_tag; - int iba_node; -}; +void maciic_scan(struct device *sc, struct i2cbus_attach_args *iba, void *aux); diff --git a/sys/arch/macppc/dev/pi2c.c b/sys/arch/macppc/dev/pi2c.c index 7c5c0bf85a4..ff2fa05e895 100644 --- a/sys/arch/macppc/dev/pi2c.c +++ b/sys/arch/macppc/dev/pi2c.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pi2c.c,v 1.4 2005/11/28 23:56:51 deraadt Exp $ */ +/* $OpenBSD: pi2c.c,v 1.5 2006/01/01 20:52:25 deraadt Exp $ */ /* * Copyright (c) 2005 Mark Kettenis @@ -63,7 +63,7 @@ pi2c_attach(struct device *parent, struct device *self, void *aux) { struct pi2c_softc *sc = (struct pi2c_softc *)self; struct confargs *ca = aux; - struct maci2cbus_attach_args iba; + struct i2cbus_attach_args iba; printf("\n"); @@ -74,8 +74,11 @@ pi2c_attach(struct device *parent, struct device *self, void *aux) sc->sc_i2c_tag.ic_release_bus = pi2c_i2c_release_bus; sc->sc_i2c_tag.ic_exec = pi2c_i2c_exec; - iba.iba_node = ca->ca_node; + bzero(&iba, sizeof iba); + iba.iba_name = "iic"; iba.iba_tag = &sc->sc_i2c_tag; + iba.iba_bus_scan = maciic_scan; + iba.iba_bus_scan_arg = &ca->ca_node; config_found(&sc->sc_dev, &iba, NULL); } diff --git a/sys/arch/macppc/dev/smu.c b/sys/arch/macppc/dev/smu.c index d9a0219ccd9..70e7edc67d9 100644 --- a/sys/arch/macppc/dev/smu.c +++ b/sys/arch/macppc/dev/smu.c @@ -1,4 +1,4 @@ -/* $OpenBSD: smu.c,v 1.9 2005/12/09 22:55:10 kettenis Exp $ */ +/* $OpenBSD: smu.c,v 1.10 2006/01/01 20:52:25 deraadt Exp $ */ /* * Copyright (c) 2005 Mark Kettenis @@ -175,7 +175,7 @@ smu_attach(struct device *parent, struct device *self, void *aux) { struct smu_softc *sc = (struct smu_softc *)self; struct confargs *ca = aux; - struct maci2cbus_attach_args iba; + struct i2cbus_attach_args iba; struct smu_fan *fan; struct smu_sensor *sensor; int nseg, node; @@ -347,10 +347,13 @@ smu_attach(struct device *parent, struct device *self, void *aux) sc->sc_i2c_tag.ic_exec = smu_i2c_exec; node = OF_getnodebyname(ca->ca_node, "smu-i2c-control"); + node = OF_child(node); - /* XXX */ - iba.iba_node = OF_child(node); + bzero(&iba, sizeof iba); + iba.iba_name = "iic"; iba.iba_tag = &sc->sc_i2c_tag; + iba.iba_bus_scan = maciic_scan; + iba.iba_bus_scan_arg = &node; config_found(&sc->sc_dev, &iba, NULL); } -- cgit v1.2.3