diff options
author | Rob Herring <robh@kernel.org> | 2017-01-16 14:28:39 -0600 |
---|---|---|
committer | Rob Herring <robh@kernel.org> | 2017-03-22 09:01:11 -0500 |
commit | bcf54d5385abaea9c8026aae6f4eeb348671a52d (patch) | |
tree | f3ddf2d76f83693039f76426e8ed030a7d4b3258 /drivers/of/device.c | |
parent | b7e252fcddfa573bb1ee275b53bba6cef85671d4 (diff) | |
download | linux-bcf54d5385abaea9c8026aae6f4eeb348671a52d.tar.gz linux-bcf54d5385abaea9c8026aae6f4eeb348671a52d.tar.bz2 linux-bcf54d5385abaea9c8026aae6f4eeb348671a52d.zip |
of: fix of_device_get_modalias returned length when truncating buffers
If the length of the modalias is greater than the buffer size, then the
modalias is truncated. However the untruncated length is returned which
will cause an error. Fix this to return the truncated length. If an error
in the case was desired, then then we should just return -ENOMEM.
The reality is no device will ever have 4KB of compatible strings to hit
this case.
Signed-off-by: Rob Herring <robh@kernel.org>
Cc: Frank Rowand <frowand.list@gmail.com>
Diffstat (limited to 'drivers/of/device.c')
-rw-r--r-- | drivers/of/device.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/of/device.c b/drivers/of/device.c index b1e6bebda3f3..210432a3c4ec 100644 --- a/drivers/of/device.c +++ b/drivers/of/device.c @@ -223,7 +223,7 @@ ssize_t of_device_get_modalias(struct device *dev, char *str, ssize_t len) str[i] = '_'; } - return tsize; + return repend; } EXPORT_SYMBOL_GPL(of_device_get_modalias); |