]> git.sur5r.net Git - u-boot/blobdiff - drivers/i2c/i2c-uniphier.c
Merge git://git.denx.de/u-boot-mpc85xx
[u-boot] / drivers / i2c / i2c-uniphier.c
index 666272dd0d7aefe97b495612bb8c829ae3e03c73..73575e98951a3fe0a102e539798dbda972f6520c 100644 (file)
@@ -1,6 +1,6 @@
 /*
- * Copyright (C) 2014 Panasonic Corporation
- * Copyright (C) 2015 Socionext Inc.
+ * Copyright (C) 2014      Panasonic Corporation
+ * Copyright (C) 2015-2016 Socionext Inc.
  *   Author: Masahiro Yamada <yamada.masahiro@socionext.com>
  *
  * SPDX-License-Identifier:    GPL-2.0+
@@ -8,15 +8,13 @@
 
 #include <common.h>
 #include <linux/types.h>
-#include <asm/io.h>
-#include <asm/errno.h>
+#include <linux/io.h>
+#include <linux/sizes.h>
+#include <linux/errno.h>
 #include <dm/device.h>
-#include <dm/root.h>
 #include <i2c.h>
 #include <fdtdec.h>
 
-DECLARE_GLOBAL_DATA_PTR;
-
 struct uniphier_i2c_regs {
        u32 dtrm;                       /* data transmission */
 #define I2C_DTRM_STA   (1 << 10)
@@ -49,13 +47,13 @@ struct uniphier_i2c_dev {
 static int uniphier_i2c_probe(struct udevice *dev)
 {
        fdt_addr_t addr;
-       fdt_size_t size;
        struct uniphier_i2c_dev *priv = dev_get_priv(dev);
 
-       addr = fdtdec_get_addr_size(gd->fdt_blob, dev->of_offset, "reg", &size);
-
-       priv->regs = map_sysmem(addr, size);
+       addr = dev_get_addr(dev);
+       if (addr == FDT_ADDR_T_NONE)
+               return -EINVAL;
 
+       priv->regs = devm_ioremap(dev, addr, SZ_64);
        if (!priv->regs)
                return -ENOMEM;
 
@@ -67,15 +65,6 @@ static int uniphier_i2c_probe(struct udevice *dev)
        return 0;
 }
 
-static int uniphier_i2c_remove(struct udevice *dev)
-{
-       struct uniphier_i2c_dev *priv = dev_get_priv(dev);
-
-       unmap_sysmem(priv->regs);
-
-       return 0;
-}
-
 static int send_and_recv_byte(struct uniphier_i2c_dev *dev, u32 dtrm)
 {
        writel(dtrm, &dev->regs->dtrm);
@@ -222,7 +211,6 @@ U_BOOT_DRIVER(uniphier_i2c) = {
        .id = UCLASS_I2C,
        .of_match = uniphier_i2c_of_match,
        .probe = uniphier_i2c_probe,
-       .remove = uniphier_i2c_remove,
        .priv_auto_alloc_size = sizeof(struct uniphier_i2c_dev),
        .ops = &uniphier_i2c_ops,
 };