Hi On Mon, Jan 16, 2023 at 5:35 AM John Berberian, Jr <jeb.st...@gmail.com> wrote: > > * Use cmd instead of /bin/sh on Windows. > > * Try to auto-detect cmd.exe's path, but default to a hard-coded path. > > Note that this will require that gspawn-win[32|64]-helper.exe and > gspawn-win[32|64]-helper-console.exe are included in the Windows binary > distributions (cc: Stefan Weil). > > Signed-off-by: "John Berberian, Jr" <jeb.st...@gmail.com> > --- > Whoops, forgot a header. Here's a revised patch. > > migration/exec.c | 24 ++++++++++++++++++++++++ > 1 file changed, 24 insertions(+) > > diff --git a/migration/exec.c b/migration/exec.c > index 375d2e1b54..38604d73a6 100644 > --- a/migration/exec.c > +++ b/migration/exec.c > @@ -23,12 +23,31 @@ > #include "migration.h" > #include "io/channel-command.h" > #include "trace.h" > +#include "qemu/cutils.h" > > +#ifdef WIN32 > +const char *exec_get_cmd_path(void); > +const char *exec_get_cmd_path(void) > +{ > + g_autofree char *detected_path = g_new(char, MAX_PATH); > + if (GetSystemDirectoryA(detected_path, MAX_PATH) == 0) { > + warn_report("Could not detect cmd.exe path, using default."); > + return "C:\\Windows\\System32\\cmd.exe"; > + } > + pstrcat(detected_path, MAX_PATH, "\\cmd.exe"); > + return g_steal_pointer(&detected_path); > +} > +#endif > > void exec_start_outgoing_migration(MigrationState *s, const char *command, > Error **errp) > { > QIOChannel *ioc; > + > +#ifdef WIN32 > + const char *argv[] = { exec_get_cmd_path(), "/c", command, NULL }; > +#else > const char *argv[] = { "/bin/sh", "-c", command, NULL }; > +#endif
It may be a better idea to use g_shell_parse_argv() instead. > > trace_migration_exec_outgoing(command); > ioc = QIO_CHANNEL(qio_channel_command_new_spawn(argv, > @@ -55,7 +74,12 @@ static gboolean exec_accept_incoming_migration(QIOChannel > *ioc, > void exec_start_incoming_migration(const char *command, Error **errp) > { > QIOChannel *ioc; > + > +#ifdef WIN32 > + const char *argv[] = { exec_get_cmd_path(), "/c", command, NULL }; > +#else > const char *argv[] = { "/bin/sh", "-c", command, NULL }; > +#endif > > trace_migration_exec_incoming(command); > ioc = QIO_CHANNEL(qio_channel_command_new_spawn(argv, > -- > 2.39.0 > > -- Marc-André Lureau