From: Anastasia Belova Date: Fri, 11 Nov 2022 12:55:11 +0000 (+0300) Subject: HID: hid-lg4ff: Add check for empty lbuf X-Git-Tag: dma-mapping-2022-12-23~193^2~6 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=d180b6496143cd360c5d5f58ae4b9a8229c1f344;p=users%2Fhch%2Fdma-mapping.git HID: hid-lg4ff: Add check for empty lbuf If an empty buf is received, lbuf is also empty. So lbuf is accessed by index -1. Found by Linux Verification Center (linuxtesting.org) with SVACE. Fixes: f31a2de3fe36 ("HID: hid-lg4ff: Allow switching of Logitech gaming wheels between compatibility modes") Signed-off-by: Anastasia Belova Signed-off-by: Jiri Kosina --- diff --git a/drivers/hid/hid-lg4ff.c b/drivers/hid/hid-lg4ff.c index 5e6a0cef2a06..e3fcf1353fb3 100644 --- a/drivers/hid/hid-lg4ff.c +++ b/drivers/hid/hid-lg4ff.c @@ -872,6 +872,12 @@ static ssize_t lg4ff_alternate_modes_store(struct device *dev, struct device_att return -ENOMEM; i = strlen(lbuf); + + if (i == 0) { + kfree(lbuf); + return -EINVAL; + } + if (lbuf[i-1] == '\n') { if (i == 1) { kfree(lbuf);