mirror of
https://github.com/torvalds/linux.git
synced 2026-05-30 10:04:04 +02:00
scsi: elx: efct: Fix memory leak in efct_hw_parse_filter()
strsep() modifies the address of the pointer passed to it so that it no
longer points to the original address. This means kfree() gets the wrong
pointer.
Fix this by passing unmodified pointer returned from kstrdup() to
kfree().
Found by Linux Verification Center (linuxtesting.org) with Svace.
Fixes: 4df84e8466 ("scsi: elx: efct: Driver initialization routines")
Signed-off-by: Vitaliy Shevtsov <v.shevtsov@mt-integration.ru>
Link: https://lore.kernel.org/r/20250612163616.24298-1-v.shevtsov@mt-integration.ru
Reviewed-by: Daniel Wagner <dwagner@suse.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
d8ab68bdb2
commit
2a8a5a5dd0
|
|
@ -1120,7 +1120,7 @@ int
|
|||
efct_hw_parse_filter(struct efct_hw *hw, void *value)
|
||||
{
|
||||
int rc = 0;
|
||||
char *p = NULL;
|
||||
char *p = NULL, *pp = NULL;
|
||||
char *token;
|
||||
u32 idx = 0;
|
||||
|
||||
|
|
@ -1132,6 +1132,7 @@ efct_hw_parse_filter(struct efct_hw *hw, void *value)
|
|||
efc_log_err(hw->os, "p is NULL\n");
|
||||
return -ENOMEM;
|
||||
}
|
||||
pp = p;
|
||||
|
||||
idx = 0;
|
||||
while ((token = strsep(&p, ",")) && *token) {
|
||||
|
|
@ -1144,7 +1145,7 @@ efct_hw_parse_filter(struct efct_hw *hw, void *value)
|
|||
if (idx == ARRAY_SIZE(hw->config.filter_def))
|
||||
break;
|
||||
}
|
||||
kfree(p);
|
||||
kfree(pp);
|
||||
|
||||
return rc;
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user