mirror of
https://github.com/sheumann/hush.git
synced 2024-12-22 14:30:31 +00:00
ash: fix command -- crash
busybox sh -c 'command --' segfaults because parse_command_args returns a pointer to a null pointer. Based on commit 18071c7 from git://git.kernel.org/pub/scm/utils/dash/dash.git by Gerrit Pape. Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
383b885ff7
commit
e2f32c02b1
@ -8878,14 +8878,15 @@ parse_command_args(char **argv, const char **path)
|
||||
for (;;) {
|
||||
cp = *++argv;
|
||||
if (!cp)
|
||||
return 0;
|
||||
return NULL;
|
||||
if (*cp++ != '-')
|
||||
break;
|
||||
c = *cp++;
|
||||
if (!c)
|
||||
break;
|
||||
if (c == '-' && !*cp) {
|
||||
argv++;
|
||||
if (!*++argv)
|
||||
return NULL;
|
||||
break;
|
||||
}
|
||||
do {
|
||||
@ -8895,7 +8896,7 @@ parse_command_args(char **argv, const char **path)
|
||||
break;
|
||||
default:
|
||||
/* run 'typecmd' for other options */
|
||||
return 0;
|
||||
return NULL;
|
||||
}
|
||||
c = *cp++;
|
||||
} while (c);
|
||||
|
Loading…
Reference in New Issue
Block a user