diff options
author | Todd Kjos <[email protected]> | 2024-10-01 23:11:47 +0000 |
---|---|---|
committer | Bjorn Helgaas <[email protected]> | 2024-10-02 16:36:35 -0500 |
commit | 2985b1844f3f3447f2d938eff1ef6762592065a5 (patch) | |
tree | 9d96384fd76542bbb4d44a03cce7e613e0c1a10a /drivers/pci/controller/dwc/pcie-qcom-ep.c | |
parent | 43ee11adcb940204948ac0ca3a05d6178f0e8b08 (diff) |
PCI: Fix reset_method_store() memory leak
In reset_method_store(), a string is allocated via kstrndup() and assigned
to the local "options". options is then used in with strsep() to find
spaces:
while ((name = strsep(&options, " ")) != NULL) {
If there are no remaining spaces, then options is set to NULL by strsep(),
so the subsequent kfree(options) doesn't free the memory allocated via
kstrndup().
Fix by using a separate tmp_options to iterate with strsep() so options is
preserved.
Link: https://lore.kernel.org/r/[email protected]
Fixes: d88f521da3ef ("PCI: Allow userspace to query and set device reset mechanism")
Signed-off-by: Todd Kjos <[email protected]>
Signed-off-by: Bjorn Helgaas <[email protected]>
Diffstat (limited to 'drivers/pci/controller/dwc/pcie-qcom-ep.c')
0 files changed, 0 insertions, 0 deletions