firmware: arm_scmi: use strlcpy to ensure NULL-terminated strings
authorSudeep Holla <sudeep.holla@arm.com>
Fri, 7 Sep 2018 16:03:25 +0000 (17:03 +0100)
committerSudeep Holla <sudeep.holla@arm.com>
Mon, 10 Sep 2018 09:08:44 +0000 (10:08 +0100)
Replace all the memcpy() for copying name strings from the firmware with
strlcpy() to make sure we are bounded by the source buffer size and we
also always have NULL-terminated strings.

This is needed to avoid out of bounds accesses if the firmware returns
a non-terminated string.

Reported-by: Olof Johansson <olof@lixom.net>
Acked-by: Olof Johansson <olof@lixom.net>
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
drivers/firmware/arm_scmi/base.c
drivers/firmware/arm_scmi/clock.c
drivers/firmware/arm_scmi/perf.c
drivers/firmware/arm_scmi/power.c
drivers/firmware/arm_scmi/sensors.c

index 9dff33ea6416f66879ea4de32e8dba6a22e37c01..204390297f4bd4e249a6f3987e992ff1eb2b7d56 100644 (file)
@@ -208,7 +208,7 @@ static int scmi_base_discover_agent_get(const struct scmi_handle *handle,
 
        ret = scmi_do_xfer(handle, t);
        if (!ret)
-               memcpy(name, t->rx.buf, SCMI_MAX_STR_SIZE);
+               strlcpy(name, t->rx.buf, SCMI_MAX_STR_SIZE);
 
        scmi_xfer_put(handle, t);
 
index e4119eb34986cb5219b648d1b900a23c8686329b..30fc04e284312e9f19c165994dad1170966304b8 100644 (file)
@@ -111,7 +111,7 @@ static int scmi_clock_attributes_get(const struct scmi_handle *handle,
 
        ret = scmi_do_xfer(handle, t);
        if (!ret)
-               memcpy(clk->name, attr->name, SCMI_MAX_STR_SIZE);
+               strlcpy(clk->name, attr->name, SCMI_MAX_STR_SIZE);
        else
                clk->name[0] = '\0';
 
index 64342944d9175c54918100c36f0b43a20e6acae3..87c99d296ecd3331218b41b65b19d487b039e62e 100644 (file)
@@ -174,7 +174,7 @@ scmi_perf_domain_attributes_get(const struct scmi_handle *handle, u32 domain,
                        dom_info->mult_factor =
                                        (dom_info->sustained_freq_khz * 1000) /
                                        dom_info->sustained_perf_level;
-               memcpy(dom_info->name, attr->name, SCMI_MAX_STR_SIZE);
+               strlcpy(dom_info->name, attr->name, SCMI_MAX_STR_SIZE);
        }
 
        scmi_xfer_put(handle, t);
index cfa033b05aed5e568b2510e2a7dace5162d13327..62f3401a1f01e90d9ddceabbe462416471d67614 100644 (file)
@@ -106,7 +106,7 @@ scmi_power_domain_attributes_get(const struct scmi_handle *handle, u32 domain,
                dom_info->state_set_notify = SUPPORTS_STATE_SET_NOTIFY(flags);
                dom_info->state_set_async = SUPPORTS_STATE_SET_ASYNC(flags);
                dom_info->state_set_sync = SUPPORTS_STATE_SET_SYNC(flags);
-               memcpy(dom_info->name, attr->name, SCMI_MAX_STR_SIZE);
+               strlcpy(dom_info->name, attr->name, SCMI_MAX_STR_SIZE);
        }
 
        scmi_xfer_put(handle, t);
index 27f2092b9882aef307763e214eb74c69f4db2af5..b53d5cc9c9f6c57ebae04f6a43e42fb814fc27d9 100644 (file)
@@ -140,7 +140,7 @@ static int scmi_sensor_description_get(const struct scmi_handle *handle,
                        s = &si->sensors[desc_index + cnt];
                        s->id = le32_to_cpu(buf->desc[cnt].id);
                        s->type = SENSOR_TYPE(attrh);
-                       memcpy(s->name, buf->desc[cnt].name, SCMI_MAX_STR_SIZE);
+                       strlcpy(s->name, buf->desc[cnt].name, SCMI_MAX_STR_SIZE);
                }
 
                desc_index += num_returned;