From: Heikki Krogerus Date: Wed, 23 Jan 2019 14:44:16 +0000 (+0300) Subject: device property: Fix the length used in PROPERTY_ENTRY_STRING() X-Git-Tag: v4.19.31~77 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=c835b4417c18fc2868a38d4689274e3daed5c32b;p=users%2Fdwmw2%2Flinux.git device property: Fix the length used in PROPERTY_ENTRY_STRING() commit 2b6e492467c78183bb629bb0a100ea3509b615a5 upstream. With string type property entries we need to use sizeof(const char *) instead of the number of characters as the length of the entry. If the string was shorter then sizeof(const char *), attempts to read it would have failed with -EOVERFLOW. The problem has been hidden because all build-in string properties have had a string longer then 8 characters until now. Fixes: a85f42047533 ("device property: helper macros for property entry creation") Cc: 4.5+ # 4.5+ Signed-off-by: Heikki Krogerus Reviewed-by: Andy Shevchenko Signed-off-by: Rafael J. Wysocki Signed-off-by: Greg Kroah-Hartman --- diff --git a/include/linux/property.h b/include/linux/property.h index ac8a1ebc4c1b5..1a12364050d8b 100644 --- a/include/linux/property.h +++ b/include/linux/property.h @@ -258,7 +258,7 @@ struct property_entry { #define PROPERTY_ENTRY_STRING(_name_, _val_) \ (struct property_entry) { \ .name = _name_, \ - .length = sizeof(_val_), \ + .length = sizeof(const char *), \ .type = DEV_PROP_STRING, \ { .value = { .str = _val_ } }, \ }