Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/i2c FDT-ize X-Powers AXP805/806 PMIC driver.
details:   https://anonhg.NetBSD.org/src/rev/1510f0336ba6
branches:  trunk
changeset: 361544:1510f0336ba6
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Thu May 03 01:15:49 2018 +0000
description:
FDT-ize X-Powers AXP805/806 PMIC driver.
diffstat:
 sys/dev/i2c/axp806.c  |  362 +++++++++++++++++++++++++------------------------
 sys/dev/i2c/axp806.h  |   41 -----
 sys/dev/i2c/files.i2c |   10 +-
 3 files changed, 189 insertions(+), 224 deletions(-)
diffs (truncated from 545 to 300 lines):
diff -r cb811f5d8be0 -r 1510f0336ba6 sys/dev/i2c/axp806.c
--- a/sys/dev/i2c/axp806.c      Thu May 03 01:14:54 2018 +0000
+++ b/sys/dev/i2c/axp806.c      Thu May 03 01:15:49 2018 +0000
@@ -1,7 +1,7 @@
-/* $NetBSD: axp806.c,v 1.1 2014/12/07 00:33:26 jmcneill Exp $ */
+/* $NetBSD: axp806.c,v 1.2 2018/05/03 01:15:49 jmcneill Exp $ */
 
 /*-
- * Copyright (c) 2014 Jared D. McNeill <jmcneill%invisible.ca@localhost>
+ * Copyright (c) 2014-2018 Jared McNeill <jmcneill%invisible.ca@localhost>
  * All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without
@@ -26,10 +26,8 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 
-#define AXP_DEBUG
-
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: axp806.c,v 1.1 2014/12/07 00:33:26 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: axp806.c,v 1.2 2018/05/03 01:15:49 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -40,7 +38,8 @@
 #include <sys/kmem.h>
 
 #include <dev/i2c/i2cvar.h>
-#include <dev/i2c/axp806.h>
+
+#include <dev/fdt/fdtvar.h>
 
 #define AXP_STARTUP_SOURCE_REG 0x00
 #define AXP_IC_TYPE_REG                0x03
@@ -117,35 +116,35 @@
          .c_voltage_reg = AXP_##vreg##_REG, .c_voltage_mask = (vmask) }
 
 static const struct axp806_ctrl axp806_ctrls[] = {
-       AXP_CTRL2("DCDCA", 600, 1520, 10, 51, 20, 21,
+       AXP_CTRL2("dcdca", 600, 1520, 10, 51, 20, 21,
                OUT_CTRL1, __BIT(0), DCDCA_CTRL, __BITS(6,0)),
-       AXP_CTRL("DCDCB", 1000, 2550, 50,
+       AXP_CTRL("dcdcb", 1000, 2550, 50,
                OUT_CTRL1, __BIT(1), DCDCB_CTRL, __BITS(4,0)),
-       AXP_CTRL2("DCDCC", 600, 1520, 10, 51, 20, 21,
+       AXP_CTRL2("dcdcc", 600, 1520, 10, 51, 20, 21,
                OUT_CTRL1, __BIT(2), DCDCC_CTRL, __BITS(6,0)),
-       AXP_CTRL2("DCDCD", 600, 3300, 20, 46, 100, 18,
+       AXP_CTRL2("dcdcd", 600, 3300, 20, 46, 100, 18,
                OUT_CTRL1, __BIT(3), DCDCD_CTRL, __BITS(5,0)),
-       AXP_CTRL("DCDCE", 1100, 3400, 100,
+       AXP_CTRL("dcdce", 1100, 3400, 100,
                OUT_CTRL1, __BIT(4), DCDCE_CTRL, __BITS(4,0)),
-       AXP_CTRL("ALDO1", 700, 3300, 100,
+       AXP_CTRL("aldo1", 700, 3300, 100,
                OUT_CTRL1, __BIT(5), ALDO1_CTRL, __BITS(4,0)),
-       AXP_CTRL("ALDO2", 700, 3400, 100,
+       AXP_CTRL("aldo2", 700, 3400, 100,
                OUT_CTRL1, __BIT(6), ALDO2_CTRL, __BITS(4,0)),
-       AXP_CTRL("ALDO3", 700, 3300, 100,
+       AXP_CTRL("aldo3", 700, 3300, 100,
                OUT_CTRL1, __BIT(7), ALDO3_CTRL, __BITS(4,0)),
-       AXP_CTRL("BLDO1", 700, 1900, 100,
+       AXP_CTRL("bldo1", 700, 1900, 100,
                OUT_CTRL2, __BIT(0), BLDO1_CTRL, __BITS(3,0)),
-       AXP_CTRL("BLDO2", 700, 1900, 100,
+       AXP_CTRL("bldo2", 700, 1900, 100,
                OUT_CTRL2, __BIT(1), BLDO2_CTRL, __BITS(3,0)),
-       AXP_CTRL("BLDO3", 700, 1900, 100,
+       AXP_CTRL("bldo3", 700, 1900, 100,
                OUT_CTRL2, __BIT(2), BLDO3_CTRL, __BITS(3,0)),
-       AXP_CTRL("BLDO4", 700, 1900, 100,
+       AXP_CTRL("bldo4", 700, 1900, 100,
                OUT_CTRL2, __BIT(3), BLDO4_CTRL, __BITS(3,0)),
-       AXP_CTRL("CLDO1", 700, 3300, 100, 
+       AXP_CTRL("cldo1", 700, 3300, 100, 
                OUT_CTRL2, __BIT(4), CLDO1_CTRL, __BITS(4,0)),
-       AXP_CTRL2("CLDO2", 700, 4200, 100, 28, 200, 4,
+       AXP_CTRL2("cldo2", 700, 4200, 100, 28, 200, 4,
                OUT_CTRL2, __BIT(5), CLDO2_CTRL, __BITS(4,0)),
-       AXP_CTRL("CLDO3", 700, 3300, 100, 
+       AXP_CTRL("cldo3", 700, 3300, 100, 
                OUT_CTRL2, __BIT(6), CLDO3_CTRL, __BITS(4,0)),
 };
 
@@ -153,117 +152,47 @@
        device_t        sc_dev;
        i2c_tag_t       sc_i2c;
        i2c_addr_t      sc_addr;
+       int             sc_phandle;
+};
 
-       u_int           sc_nctrl;
-       struct axp806_ctrl *sc_ctrl;
+struct axp806reg_softc {
+       device_t        sc_dev;
+       i2c_tag_t       sc_i2c;
+       i2c_addr_t      sc_addr;
+       const struct axp806_ctrl *sc_ctrl;
 };
 
-static int     axp806_match(device_t, cfdata_t, void *);
-static void    axp806_attach(device_t, device_t, void *);
+struct axp806reg_attach_args {
+       const struct axp806_ctrl *reg_ctrl;
+       int             reg_phandle;
+       i2c_tag_t       reg_i2c;
+       i2c_addr_t      reg_addr;
+};
 
-static int     axp806_read(struct axp806_softc *, uint8_t, uint8_t *);
-static int     axp806_write(struct axp806_softc *, uint8_t, uint8_t);
-
-static void    axp806_print(struct axp806_ctrl *c);
-
-CFATTACH_DECL_NEW(axp806pm, sizeof(struct axp806_softc),
-    axp806_match, axp806_attach, NULL, NULL);
+static const char *compatible[] = {
+       "x-powers,axp805",
+       "x-powers,axp806",
+       NULL
+};
 
 static int
-axp806_match(device_t parent, cfdata_t match, void *aux)
-{
-       return 1;
-}
-
-static void
-axp806_attach(device_t parent, device_t self, void *aux)
+axp806_read(i2c_tag_t tag, i2c_addr_t addr, uint8_t reg, uint8_t *val)
 {
-       struct axp806_softc *sc = device_private(self);
-       struct i2c_attach_args *ia = aux;
-       u_int n;
-
-       sc->sc_dev = self;
-       sc->sc_i2c = ia->ia_tag;
-       sc->sc_addr = ia->ia_addr;
-
-       aprint_naive("\n");
-       aprint_normal("\n");
-
-       sc->sc_nctrl = __arraycount(axp806_ctrls);
-       sc->sc_ctrl = kmem_alloc(sizeof(axp806_ctrls), KM_SLEEP);
-       memcpy(sc->sc_ctrl, axp806_ctrls, sizeof(axp806_ctrls));
-       for (n = 0; n < sc->sc_nctrl; n++) {
-               sc->sc_ctrl[n].c_dev = self;
-       }
-
-#ifdef AXP_DEBUG
-       for (n = 0; n < sc->sc_nctrl; n++) {
-               axp806_print(&sc->sc_ctrl[n]);
-       }
-#endif
-}
-
-static int
-axp806_read(struct axp806_softc *sc, uint8_t reg, uint8_t *val)
-{
-       return iic_smbus_read_byte(sc->sc_i2c, sc->sc_addr, reg, val,
+       return iic_smbus_read_byte(tag, addr, reg, val,
            cold ? I2C_F_POLL : 0);
 }
 
 static int
-axp806_write(struct axp806_softc *sc, uint8_t reg, uint8_t val)
+axp806_write(i2c_tag_t tag, i2c_addr_t addr, uint8_t reg, uint8_t val)
 {
-       return iic_smbus_write_byte(sc->sc_i2c, sc->sc_addr, reg, val,
+       return iic_smbus_write_byte(tag, addr, reg, val,
            cold ? I2C_F_POLL : 0);
 }
 
-static void
-axp806_print(struct axp806_ctrl *c)
+static int
+axp806_set_voltage(i2c_tag_t tag, i2c_addr_t addr, const struct axp806_ctrl *c, u_int min, u_int max)
 {
-       struct axp806_softc *sc = device_private(c->c_dev);
-       u_int voltage;
-       bool enabled;
-
-       device_printf(sc->sc_dev, "%s:", c->c_name);
-       if (c->c_voltage_reg) {
-               if (axp806_get_voltage(c, &voltage)) {
-                       printf(" [??? V]");
-               } else {
-                       printf(" [%d.%03dV]", voltage / 1000,
-                           voltage % 1000);
-               }
-       }
-       if (c->c_enable_reg) {
-               if (axp806_is_enabled(c, &enabled)) {
-                       printf(" [unknown state]");
-               } else {
-                       printf(" [%s]", enabled ? "ON" : "OFF");
-               }
-       }
-       printf("\n");
-}
-
-struct axp806_ctrl *
-axp806_lookup(device_t dev, const char *name)
-{
-       struct axp806_softc *sc = device_private(dev);
-       struct axp806_ctrl *c;
-       u_int n;
-
-       for (n = 0; n < sc->sc_nctrl; n++) {
-               c = &sc->sc_ctrl[n];
-               if (strcmp(c->c_name, name) == 0) {
-                       return c;
-               }
-       }
-
-       return NULL;
-}
-
-int
-axp806_set_voltage(struct axp806_ctrl *c, u_int min, u_int max)
-{
-       struct axp806_softc *sc = device_private(c->c_dev);
+       const int flags = (cold ? I2C_F_POLL : 0);
        u_int vol, reg_val;
        int nstep, error;
        uint8_t val;
@@ -290,35 +219,30 @@
        if (vol > max)
                return EINVAL;
 
-       iic_acquire_bus(sc->sc_i2c, 0);
-       if ((error = axp806_read(sc, c->c_voltage_reg, &val)) != 0)
-               goto done;
-       val &= ~c->c_voltage_mask;
-       val |= __SHIFTIN(reg_val, c->c_voltage_mask);
-       error = axp806_write(sc, c->c_voltage_reg, val);
+       iic_acquire_bus(tag, flags);
+       if ((error = axp806_read(tag, addr, c->c_voltage_reg, &val)) == 0) {
+               val &= ~c->c_voltage_mask;
+               val |= __SHIFTIN(reg_val, c->c_voltage_mask);
+               error = axp806_write(tag, addr, c->c_voltage_reg, val);
+       }
+       iic_release_bus(tag, flags);
 
-done:
-       iic_release_bus(sc->sc_i2c, 0);
-#ifdef AXP_DEBUG
-       if (error == 0)
-               axp806_print(c);
-#endif
        return error;
 }
 
-int
-axp806_get_voltage(struct axp806_ctrl *c, u_int *pvol)
+static int
+axp806_get_voltage(i2c_tag_t tag, i2c_addr_t addr, const struct axp806_ctrl *c, u_int *pvol)
 {
-       struct axp806_softc *sc = device_private(c->c_dev);
+       const int flags = (cold ? I2C_F_POLL : 0);
        int reg_val, error;
        uint8_t val;
 
        if (!c->c_voltage_mask)
                return EINVAL;
 
-       iic_acquire_bus(sc->sc_i2c, 0);
-       error = axp806_read(sc, c->c_voltage_reg, &val);
-       iic_release_bus(sc->sc_i2c, 0);
+       iic_acquire_bus(tag, flags);
+       error = axp806_read(tag, addr, c->c_voltage_reg, &val);
+       iic_release_bus(tag, flags);
        if (error)
                return error;
 
@@ -333,72 +257,152 @@
        return 0;
 }
 
-int
-axp806_is_enabled(struct axp806_ctrl *c, bool *penabled)
+static int
+axp806_match(device_t parent, cfdata_t match, void *aux)
 {
-       struct axp806_softc *sc = device_private(c->c_dev);
-       uint8_t val;
-       int error;
+       struct i2c_attach_args *ia = aux;
+
+       if (ia->ia_name != NULL)
+               return iic_compat_match(ia, compatible);
+
+       return 1;
+}
+
+static void
+axp806_attach(device_t parent, device_t self, void *aux)
Home |
Main Index |
Thread Index |
Old Index