semihosting: clean up handling of expanded argv

Another cleanup patch tripped over the fact we weren't being careful
in our casting. Fix the casts, allow for a non-const and switch from
g_realloc to g_renew.

The whole semihosting argument handling could do with some tests
though.

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20220315121251.2280317-8-alex.bennee@linaro.org>
This commit is contained in:
Alex Bennée 2022-03-15 11:46:12 +00:00
parent c6afd2bdfd
commit 78beee809d

View File

@ -51,7 +51,7 @@ typedef struct SemihostingConfig {
bool enabled; bool enabled;
SemihostingTarget target; SemihostingTarget target;
Chardev *chardev; Chardev *chardev;
const char **argv; char **argv;
int argc; int argc;
const char *cmdline; /* concatenated argv */ const char *cmdline; /* concatenated argv */
} SemihostingConfig; } SemihostingConfig;
@ -98,8 +98,8 @@ static int add_semihosting_arg(void *opaque,
if (strcmp(name, "arg") == 0) { if (strcmp(name, "arg") == 0) {
s->argc++; s->argc++;
/* one extra element as g_strjoinv() expects NULL-terminated array */ /* one extra element as g_strjoinv() expects NULL-terminated array */
s->argv = g_realloc(s->argv, (s->argc + 1) * sizeof(void *)); s->argv = g_renew(char *, s->argv, s->argc + 1);
s->argv[s->argc - 1] = val; s->argv[s->argc - 1] = g_strdup(val);
s->argv[s->argc] = NULL; s->argv[s->argc] = NULL;
} }
return 0; return 0;