nvmem: core: add nvmem_cell_read_common
[linux-2.6-microblaze.git] / drivers / nvmem / core.c
index ef326f2..b3619f3 100644 (file)
@@ -1088,16 +1088,8 @@ int nvmem_cell_write(struct nvmem_cell *cell, void *buf, size_t len)
 }
 EXPORT_SYMBOL_GPL(nvmem_cell_write);
 
-/**
- * nvmem_cell_read_u16() - Read a cell value as an u16
- *
- * @dev: Device that requests the nvmem cell.
- * @cell_id: Name of nvmem cell to read.
- * @val: pointer to output value.
- *
- * Return: 0 on success or negative errno.
- */
-int nvmem_cell_read_u16(struct device *dev, const char *cell_id, u16 *val)
+static int nvmem_cell_read_common(struct device *dev, const char *cell_id,
+                                 void *val, size_t count)
 {
        struct nvmem_cell *cell;
        void *buf;
@@ -1112,17 +1104,31 @@ int nvmem_cell_read_u16(struct device *dev, const char *cell_id, u16 *val)
                nvmem_cell_put(cell);
                return PTR_ERR(buf);
        }
-       if (len != sizeof(*val)) {
+       if (len != count) {
                kfree(buf);
                nvmem_cell_put(cell);
                return -EINVAL;
        }
-       memcpy(val, buf, sizeof(*val));
+       memcpy(val, buf, count);
        kfree(buf);
        nvmem_cell_put(cell);
 
        return 0;
 }
+
+/**
+ * nvmem_cell_read_u16() - Read a cell value as an u16
+ *
+ * @dev: Device that requests the nvmem cell.
+ * @cell_id: Name of nvmem cell to read.
+ * @val: pointer to output value.
+ *
+ * Return: 0 on success or negative errno.
+ */
+int nvmem_cell_read_u16(struct device *dev, const char *cell_id, u16 *val)
+{
+       return nvmem_cell_read_common(dev, cell_id, val, sizeof(*val));
+}
 EXPORT_SYMBOL_GPL(nvmem_cell_read_u16);
 
 /**
@@ -1136,29 +1142,7 @@ EXPORT_SYMBOL_GPL(nvmem_cell_read_u16);
  */
 int nvmem_cell_read_u32(struct device *dev, const char *cell_id, u32 *val)
 {
-       struct nvmem_cell *cell;
-       void *buf;
-       size_t len;
-
-       cell = nvmem_cell_get(dev, cell_id);
-       if (IS_ERR(cell))
-               return PTR_ERR(cell);
-
-       buf = nvmem_cell_read(cell, &len);
-       if (IS_ERR(buf)) {
-               nvmem_cell_put(cell);
-               return PTR_ERR(buf);
-       }
-       if (len != sizeof(*val)) {
-               kfree(buf);
-               nvmem_cell_put(cell);
-               return -EINVAL;
-       }
-       memcpy(val, buf, sizeof(*val));
-
-       kfree(buf);
-       nvmem_cell_put(cell);
-       return 0;
+       return nvmem_cell_read_common(dev, cell_id, val, sizeof(*val));
 }
 EXPORT_SYMBOL_GPL(nvmem_cell_read_u32);