diff options
author | Gustavo A. R. Silva <gustavo@embeddedor.com> | 2019-08-29 14:17:21 -0400 |
---|---|---|
committer | Bjorn Andersson <bjorn.andersson@linaro.org> | 2019-08-29 14:24:31 -0400 |
commit | 61c65f47f30a1f32e0a84fe8335cd0360a028b48 (patch) | |
tree | 715f16c8e086ee65f5298c9f6d8c6b63f8405c78 /drivers/rpmsg | |
parent | de4064af76537f13d74a814a962f4524e81436ac (diff) |
rpmsg: glink: Use struct_size() helper
One of the more common cases of allocation size calculations is finding
the size of a structure that has a zero-sized array at the end, along
with memory for some number of elements for that array. For example:
struct {
...
struct intent_pair intents[];
} __packed * msg;
Make use of the struct_size() helper instead of an open-coded version
in order to avoid any potential type mistakes.
So, replace the following form:
sizeof(*msg) + sizeof(struct intent_pair) * count
with:
struct_size(msg, intents, count)
This code was detected with the help of Coccinelle.
Signed-off-by: Gustavo A. R. Silva <gustavo@embeddedor.com>
Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Diffstat (limited to 'drivers/rpmsg')
-rw-r--r-- | drivers/rpmsg/qcom_glink_native.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/rpmsg/qcom_glink_native.c b/drivers/rpmsg/qcom_glink_native.c index f46c787733e8..621f1afd4d6b 100644 --- a/drivers/rpmsg/qcom_glink_native.c +++ b/drivers/rpmsg/qcom_glink_native.c | |||
@@ -892,7 +892,7 @@ static void qcom_glink_handle_intent(struct qcom_glink *glink, | |||
892 | struct intent_pair intents[]; | 892 | struct intent_pair intents[]; |
893 | } __packed * msg; | 893 | } __packed * msg; |
894 | 894 | ||
895 | const size_t msglen = sizeof(*msg) + sizeof(struct intent_pair) * count; | 895 | const size_t msglen = struct_size(msg, intents, count); |
896 | int ret; | 896 | int ret; |
897 | int i; | 897 | int i; |
898 | unsigned long flags; | 898 | unsigned long flags; |