mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-13 14:40:22 +00:00
mixer: Fix a bogus free() call in the main loop
After a strsep() call, p might not point at the original allocation anymore. Reported by: CHERI Reviewed by: christos MFC after: 1 week Differential Revision: https://reviews.freebsd.org/D47266
This commit is contained in:
parent
9b2f2fbfcb
commit
c22be0b181
@ -147,7 +147,9 @@ main(int argc, char *argv[])
|
||||
|
||||
parse:
|
||||
while (argc > 0) {
|
||||
if ((p = strdup(*argv)) == NULL)
|
||||
char *orig;
|
||||
|
||||
if ((orig = p = strdup(*argv)) == NULL)
|
||||
err(1, "strdup(%s)", *argv);
|
||||
|
||||
/* Check if we're using the shorthand syntax for volume setting. */
|
||||
@ -200,7 +202,7 @@ main(int argc, char *argv[])
|
||||
/* Input: `dev.control=val`. */
|
||||
cp->mod(cp->parent_dev, valstr);
|
||||
next:
|
||||
free(p);
|
||||
free(orig);
|
||||
argc--;
|
||||
argv++;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user