]> git.kernelconcepts.de Git - karo-tx-uboot.git/blobdiff - board/karo/tx6/pmic.c
karo: tx6ul: rework PMIC support and print PMIC name in boot message
[karo-tx-uboot.git] / board / karo / tx6 / pmic.c
index 3e4acda19063b1bd91a17a72f12dd34124f80997..e670b6a7e4071a7e8a35a27e05d028d6e36a8ee8 100644 (file)
@@ -20,6 +20,7 @@
 
 #include "pmic.h"
 
+#ifdef CONFIG_SYS_I2C
 static struct {
        uchar addr;
        pmic_setup_func *init;
@@ -36,28 +37,35 @@ static struct {
 #endif
 };
 
-int tx6_pmic_init(int addr, struct pmic_regs *regs, size_t num_regs)
+int tx6_pmic_init(int i2c_addr, struct pmic_regs *regs, size_t num_regs)
 {
        int ret = -ENODEV;
        int i;
+       const char *pmic = "N/A";
 
        printf("PMIC: ");
 
-       debug("Probing for I2C dev 0x%02x\n", addr);
        for (i = 0; i < ARRAY_SIZE(i2c_addrs); i++) {
-               u8 i2c_addr = i2c_addrs[i].addr;
 
-               if (i2c_addr != addr)
-                       continue;
-
-               debug("Probing for I2C dev 0x%02x\n", i2c_addr);
-               ret = i2c_probe(i2c_addr);
-               if (ret == 0) {
-                       debug("Initializing PMIC at I2C addr 0x%02x\n", i2c_addr);
-                       ret = i2c_addrs[i].init(i2c_addr, regs, num_regs);
+               if (i2c_addrs[i].addr == i2c_addr) {
+                       pmic = i2c_addrs[i].name;
                        break;
                }
        }
-       printf("%s\n", i == ARRAY_SIZE(i2c_addrs) ? "N/A" : i2c_addrs[i].name);
+       printf("%s\n", pmic);
+
+       debug("Probing for I2C dev 0x%02x\n", i2c_addr);
+       ret = i2c_probe(i2c_addr);
+       if (ret == 0) {
+               debug("Initializing PMIC at I2C addr 0x%02x\n", i2c_addr);
+               ret = i2c_addrs[i].init(i2c_addr, regs, num_regs);
+       }
        return ret;
 }
+#else
+int tx6_pmic_init(int i2c_addr, struct pmic_regs *regs, size_t num_regs)
+{
+       printf("PMIC: N/A\n");
+       return 0;
+}
+#endif