From: Benjamin Tissoires Date: Tue, 4 Dec 2012 15:27:54 +0000 (+0100) Subject: HID: i2c-hid: also call i2c_hid_free_buffers in i2c_hid_remove X-Git-Tag: firefly_0821_release~3680^2~1471^2^3~9 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=134ebfd86b9353a3d98f9f4e93b4e79824a4b49a;p=firefly-linux-kernel-4.4.55.git HID: i2c-hid: also call i2c_hid_free_buffers in i2c_hid_remove In the case where the hid driver in charge of handling the hid part of the device (hid-generic for instance) fails at probe, neither i2c_hid_start nor i2c_hid_stop are called. Thus, the buffers allocated in i2c_hid_probe are never freed. Signed-off-by: Benjamin Tissoires Signed-off-by: Jiri Kosina --- diff --git a/drivers/hid/i2c-hid/i2c-hid.c b/drivers/hid/i2c-hid/i2c-hid.c index 035a0cdd129e..aab3357626c7 100644 --- a/drivers/hid/i2c-hid/i2c-hid.c +++ b/drivers/hid/i2c-hid/i2c-hid.c @@ -908,6 +908,9 @@ static int __devexit i2c_hid_remove(struct i2c_client *client) free_irq(client->irq, ihid); + if (ihid->bufsize) + i2c_hid_free_buffers(ihid); + kfree(ihid); return 0;