diff options
author | Alexey Dobriyan <adobriyan@gmail.com> | 2005-08-26 01:49:14 +0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-08-26 16:30:30 -0700 |
commit | 1f57ff89fee47a317e9e8ca63bf0f139802cc116 (patch) | |
tree | 0db3419ab73cabed542a18cd5c7da50b03df896c /drivers/hwmon/smsc47m1.c | |
parent | d634cc15e8f33332038dc9c078beae79f9382ada (diff) | |
download | op-kernel-dev-1f57ff89fee47a317e9e8ca63bf0f139802cc116.zip op-kernel-dev-1f57ff89fee47a317e9e8ca63bf0f139802cc116.tar.gz |
[PATCH] drivers/hwmon/*: kfree() correct pointers
The adm9240 driver, in adm9240_detect(), allocates a structure. The
error path attempts to kfree() ->client field of it (second one),
resulting in an oops (or slab corruption) if the hardware is not present.
->client field in adm1026, adm1031, smsc47b397 and smsc47m1 is the first in
${HWMON}_data structure, but fix them too.
Signed-off-by: Jonathan Corbet <corbet@lwn.net
Signed-off-by: Alexey Dobriyan <adobriyan@gmail.com>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/hwmon/smsc47m1.c')
-rw-r--r-- | drivers/hwmon/smsc47m1.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/hwmon/smsc47m1.c b/drivers/hwmon/smsc47m1.c index 897117a..7166ad0 100644 --- a/drivers/hwmon/smsc47m1.c +++ b/drivers/hwmon/smsc47m1.c @@ -495,7 +495,7 @@ static int smsc47m1_detect(struct i2c_adapter *adapter, int address, int kind) return 0; error_free: - kfree(new_client); + kfree(data); error_release: release_region(address, SMSC_EXTENT); return err; |