]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
regmap: Add regmap_init_mem_range()
authorPratyush Yadav <p.yadav@ti.com>
Thu, 24 Sep 2020 04:34:14 +0000 (10:04 +0530)
committerTom Rini <trini@konsulko.com>
Wed, 30 Sep 2020 15:55:22 +0000 (11:55 -0400)
Right now, the base of a regmap can only be obtained from the device
tree. This makes it impossible for devices which calculate the base at
runtime to use a regmap. An example of such a device is the Cadence
Sierra PHY.

Allow creating a regmap with one range whose start and size can be
specified by the driver based on calculations at runtime.

Signed-off-by: Pratyush Yadav <p.yadav@ti.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
drivers/core/regmap.c
include/regmap.h

index 173ae808909a81fb09d62e012080825755cb6c5d..a9087df32b9b405a6502137932ac32145e2687a8 100644 (file)
@@ -164,6 +164,33 @@ err:
        return ret;
 }
 
+int regmap_init_mem_range(ofnode node, ulong r_start, ulong r_size,
+                         struct regmap **mapp)
+{
+       struct regmap *map;
+       struct regmap_range *range;
+
+       map = regmap_alloc(1);
+       if (!map)
+               return -ENOMEM;
+
+       range = &map->ranges[0];
+       range->start = r_start;
+       range->size = r_size;
+
+       if (ofnode_read_bool(node, "little-endian"))
+               map->endianness = REGMAP_LITTLE_ENDIAN;
+       else if (ofnode_read_bool(node, "big-endian"))
+               map->endianness = REGMAP_BIG_ENDIAN;
+       else if (ofnode_read_bool(node, "native-endian"))
+               map->endianness = REGMAP_NATIVE_ENDIAN;
+       else /* Default: native endianness */
+               map->endianness = REGMAP_NATIVE_ENDIAN;
+
+       *mapp = map;
+       return 0;
+}
+
 int regmap_init_mem(ofnode node, struct regmap **mapp)
 {
        struct regmap_range *range;
index e6c59dfbcedc6b74824e88b8122ded01d755cdc5..7c8ad04759937900c4d0c01a7869e6b96048422a 100644 (file)
@@ -350,6 +350,25 @@ int regmap_init_mem_platdata(struct udevice *dev, fdt_val_t *reg, int count,
 
 int regmap_init_mem_index(ofnode node, struct regmap **mapp, int index);
 
+/**
+ * regmap_init_mem_range() - Set up a new memory region for ofnode with the
+ *                          specified range.
+ *
+ * @node:      The ofnode for the map.
+ * @r_start:   Start of the range.
+ * @r_size:    Size of the range.
+ * @mapp:      Returns allocated map.
+ *
+ * Return: 0 in success, -errno otherwise
+ *
+ * This creates a regmap with one range where instead of extracting the range
+ * from 'node', it is created based on the parameters specified. This is
+ * useful when a driver needs to calculate the base of the regmap at runtime,
+ * and can't specify it in device tree.
+ */
+int regmap_init_mem_range(ofnode node, ulong r_start, ulong r_size,
+                         struct regmap **mapp);
+
 /**
  * devm_regmap_init() - Initialise register map (device managed)
  *