gpiolib: cdev: zero padding during conversion to gpioline_info_changed
[ Upstream commit cb8f63b8cbf39845244f3ccae43bb7e63bd70543 ]
When userspace requests a GPIO v1 line info changed event,
lineinfo_watch_read() populates and returns the gpioline_info_changed
structure. It contains 5 words of padding at the end which are not
initialized before being returned to userspace.
Zero the structure in gpio_v2_line_info_change_to_v1() before populating
its contents.
Fixes: aad955842d
("gpiolib: cdev: support GPIO_V2_GET_LINEINFO_IOCTL and GPIO_V2_GET_LINEINFO_WATCH_IOCTL")
Signed-off-by: Gabriel Knezek <gabeknez@linux.microsoft.com>
Reviewed-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Sasha Levin

parent
0221a5a4db
commit
b9e6c20d4c
@@ -1865,6 +1865,7 @@ static void gpio_v2_line_info_changed_to_v1(
|
|||||||
struct gpio_v2_line_info_changed *lic_v2,
|
struct gpio_v2_line_info_changed *lic_v2,
|
||||||
struct gpioline_info_changed *lic_v1)
|
struct gpioline_info_changed *lic_v1)
|
||||||
{
|
{
|
||||||
|
memset(lic_v1, 0, sizeof(*lic_v1));
|
||||||
gpio_v2_line_info_to_v1(&lic_v2->info, &lic_v1->info);
|
gpio_v2_line_info_to_v1(&lic_v2->info, &lic_v1->info);
|
||||||
lic_v1->timestamp = lic_v2->timestamp_ns;
|
lic_v1->timestamp = lic_v2->timestamp_ns;
|
||||||
lic_v1->event_type = lic_v2->event_type;
|
lic_v1->event_type = lic_v2->event_type;
|
||||||
|
Reference in New Issue
Block a user