@@ -81,6 +81,20 @@ int sysinfo_sandbox_get_str(struct udevice *dev, int id, size_t size, char *val)
return -ENOENT;
}
+int sysinfo_sandbox_get_str_list(struct udevice *dev, int id, unsigned idx,
+ size_t size, char *val)
+{
+ if (id != STR_VACATIONSPOT)
+ return -ENOENT;
+
+ if (idx >= ARRAY_SIZE(vacation_spots))
+ return -ERANGE;
+
+ strncpy(val, vacation_spots[idx], size);
+ val[size - 1] = '\0';
+ return strlen(vacation_spots[idx]);
+}
+
static const struct udevice_id sysinfo_sandbox_ids[] = {
{ .compatible = "sandbox,sysinfo-sandbox" },
{ /* sentinel */ }
@@ -91,6 +105,7 @@ static const struct sysinfo_ops sysinfo_sandbox_ops = {
.get_bool = sysinfo_sandbox_get_bool,
.get_int = sysinfo_sandbox_get_int,
.get_str = sysinfo_sandbox_get_str,
+ .get_str_list = sysinfo_sandbox_get_str_list,
};
int sysinfo_sandbox_probe(struct udevice *dev)
@@ -92,6 +92,21 @@ int sysinfo_get_str(struct udevice *dev, int id, size_t size, char *val)
return ops->get_str(dev, id, size, val);
}
+int sysinfo_get_str_list(struct udevice *dev, int id, unsigned idx, size_t size,
+ char *val)
+{
+ struct sysinfo_priv *priv = dev_get_uclass_priv(dev);
+ struct sysinfo_ops *ops = sysinfo_get_ops(dev);
+
+ if (!priv->detected)
+ return -EPERM;
+
+ if (!ops->get_str_list)
+ return -ENOSYS;
+
+ return ops->get_str_list(dev, id, idx, size, val);
+}
+
UCLASS_DRIVER(sysinfo) = {
.id = UCLASS_SYSINFO,
.name = "sysinfo",
@@ -106,6 +106,25 @@ struct sysinfo_ops {
int (*get_str)(struct udevice *dev, int id, size_t size, char *val);
+ /**
+ * get_str_list() - Read a specific string data value from a string list
+ * that describes hardware setup.
+ * @dev: The sysinfo instance to gather the data.
+ * @id: A unique identifier for the string list to read from.
+ * @idx: The index of the string in the string list.
+ * @size: The size of the buffer to receive the string data.
+ * If the buffer is not large enough to contain the whole
+ * string, the string must be trimmed to fit in the
+ * buffer including the terminating NULL-byte.
+ * @val: Pointer to a buffer that receives the value read.
+ *
+ * Return: Actual length of the string excluding the terminating
+ * NULL-byte if OK, -ENOENT if list with ID @id does not exist,
+ * -ERANGE if @idx is invalid or -ve on error.
+ */
+ int (*get_str_list)(struct udevice *dev, int id, unsigned idx,
+ size_t size, char *val);
+
/**
* get_fit_loadable - Get the name of an image to load from FIT
* This function can be used to provide the image names based on runtime
@@ -180,6 +199,25 @@ int sysinfo_get_int(struct udevice *dev, int id, int *val);
*/
int sysinfo_get_str(struct udevice *dev, int id, size_t size, char *val);
+/**
+ * sysinfo_get_str_list() - Read a specific string data value from a string list
+ * that describes hardware setup.
+ * @dev: The sysinfo instance to gather the data.
+ * @id: A unique identifier for the string list to read from.
+ * @idx: The index of the string in the string list.
+ * @size: The size of the buffer to receive the string data. If the buffer
+ * is not large enough to contain the whole string, the string will
+ * be trimmed to fit in the buffer including the terminating
+ * NULL-byte.
+ * @val: Pointer to a buffer that receives the value read.
+ *
+ * Return: Actual length of the string excluding the terminating NULL-byte if
+ * OK, -ENOENT if list with ID @id does not exist, -ERANGE if @idx is
+ * invalid, -EPERM if called before sysinfo_detect(), else -ve on error.
+ */
+int sysinfo_get_str_list(struct udevice *dev, int id, unsigned idx, size_t size,
+ char *val);
+
/**
* sysinfo_get() - Return the sysinfo device for the sysinfo in question.
* @devp: Pointer to structure to receive the sysinfo device.
@@ -235,6 +273,12 @@ static inline int sysinfo_get_str(struct udevice *dev, int id, size_t size,
return -ENOSYS;
}
+static inline int sysinfo_get_str_list(struct udevice *dev, int id,
+ unsigned idx, size_t size, char *val)
+{
+ return -ENOSYS;
+}
+
static inline int sysinfo_get(struct udevice **devp)
{
return -ENOSYS;
@@ -58,6 +58,19 @@ static int dm_test_sysinfo(struct unit_test_state *uts)
str));
ut_asserteq_str(str, "Yuggoth");
+ ut_asserteq(6, sysinfo_get_str_list(sysinfo, STR_VACATIONSPOT, 0,
+ sizeof(str), str));
+ ut_asserteq_str(str, "R'lyeh");
+
+ ut_asserteq(17, sysinfo_get_str_list(sysinfo, STR_VACATIONSPOT, 5, 6,
+ str));
+ ut_asserteq_str(str, "The N");
+
+ ut_asserteq(-ENOENT, sysinfo_get_str_list(sysinfo, INT_TEST1, 0,
+ sizeof(str), str));
+ ut_asserteq(-ERANGE, sysinfo_get_str_list(sysinfo, STR_VACATIONSPOT, 10,
+ sizeof(str), str));
+
return 0;
}