Skip to content

Commit

Permalink
usb: misc: ljca: Fix double free in error handling path
Browse files Browse the repository at this point in the history
When auxiliary_device_add() returns error and then calls
auxiliary_device_uninit(), callback function ljca_auxdev_release
calls kfree(auxdev->dev.platform_data) to free the parameter data
of the function ljca_new_client_device. The callers of
ljca_new_client_device shouldn't call kfree() again
in the error handling path to free the platform data.

Fix this by cleaning up the redundant kfree() in all callers and
adding kfree() the passed in platform_data on errors which happen
before auxiliary_device_init() succeeds .

Fixes: acd6199 ("usb: Add support for Intel LJCA device")
Cc: stable <[email protected]>
Signed-off-by: Yongzhi Liu <[email protected]>
Reviewed-by: Hans de Goede <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Greg Kroah-Hartman <[email protected]>
  • Loading branch information
Yongzhi Liu authored and gregkh committed Mar 26, 2024
1 parent f5e9bda commit 7c96319
Showing 1 changed file with 9 additions and 13 deletions.
22 changes: 9 additions & 13 deletions drivers/usb/misc/usb-ljca.c
Original file line number Diff line number Diff line change
Expand Up @@ -518,8 +518,10 @@ static int ljca_new_client_device(struct ljca_adapter *adap, u8 type, u8 id,
int ret;

client = kzalloc(sizeof *client, GFP_KERNEL);
if (!client)
if (!client) {
kfree(data);
return -ENOMEM;
}

client->type = type;
client->id = id;
Expand All @@ -535,8 +537,10 @@ static int ljca_new_client_device(struct ljca_adapter *adap, u8 type, u8 id,
auxdev->dev.release = ljca_auxdev_release;

ret = auxiliary_device_init(auxdev);
if (ret)
if (ret) {
kfree(data);
goto err_free;
}

ljca_auxdev_acpi_bind(adap, auxdev, adr, id);

Expand Down Expand Up @@ -590,12 +594,8 @@ static int ljca_enumerate_gpio(struct ljca_adapter *adap)
valid_pin[i] = get_unaligned_le32(&desc->bank_desc[i].valid_pins);
bitmap_from_arr32(gpio_info->valid_pin_map, valid_pin, gpio_num);

ret = ljca_new_client_device(adap, LJCA_CLIENT_GPIO, 0, "ljca-gpio",
return ljca_new_client_device(adap, LJCA_CLIENT_GPIO, 0, "ljca-gpio",
gpio_info, LJCA_GPIO_ACPI_ADR);
if (ret)
kfree(gpio_info);

return ret;
}

static int ljca_enumerate_i2c(struct ljca_adapter *adap)
Expand Down Expand Up @@ -629,10 +629,8 @@ static int ljca_enumerate_i2c(struct ljca_adapter *adap)
ret = ljca_new_client_device(adap, LJCA_CLIENT_I2C, i,
"ljca-i2c", i2c_info,
LJCA_I2C1_ACPI_ADR + i);
if (ret) {
kfree(i2c_info);
if (ret)
return ret;
}
}

return 0;
Expand Down Expand Up @@ -669,10 +667,8 @@ static int ljca_enumerate_spi(struct ljca_adapter *adap)
ret = ljca_new_client_device(adap, LJCA_CLIENT_SPI, i,
"ljca-spi", spi_info,
LJCA_SPI1_ACPI_ADR + i);
if (ret) {
kfree(spi_info);
if (ret)
return ret;
}
}

return 0;
Expand Down

0 comments on commit 7c96319

Please sign in to comment.