diff options
| author | Todd Kjos <tkjos@google.com> | 2024-10-01 23:11:47 +0000 | 
|---|---|---|
| committer | Bjorn Helgaas <bhelgaas@google.com> | 2024-10-02 16:36:35 -0500 | 
| commit | 2985b1844f3f3447f2d938eff1ef6762592065a5 (patch) | |
| tree | 9d96384fd76542bbb4d44a03cce7e613e0c1a10a /rust/helpers/bitops.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/20241001231147.3583649-1-tkjos@google.com
Fixes: d88f521da3ef ("PCI: Allow userspace to query and set device reset mechanism")
Signed-off-by: Todd Kjos <tkjos@google.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Diffstat (limited to 'rust/helpers/bitops.c')
0 files changed, 0 insertions, 0 deletions
