-pidfile option
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1166 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
fe2cece60e
commit
f7cce89882
@ -202,6 +202,10 @@ Windows.
|
|||||||
@item -full-screen
|
@item -full-screen
|
||||||
Start in full screen.
|
Start in full screen.
|
||||||
|
|
||||||
|
@item -pidfile file
|
||||||
|
Store the QEMU process PID in @var{file}. It is useful if you launch QEMU
|
||||||
|
from a script.
|
||||||
|
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
Network options:
|
Network options:
|
||||||
|
46
vl.c
46
vl.c
@ -1666,6 +1666,46 @@ static int net_fd_init(NetDriverState *nd, int fd)
|
|||||||
|
|
||||||
#endif /* !_WIN32 */
|
#endif /* !_WIN32 */
|
||||||
|
|
||||||
|
/***********************************************************/
|
||||||
|
/* pid file */
|
||||||
|
|
||||||
|
static char *pid_filename;
|
||||||
|
|
||||||
|
/* Remove PID file. Called on normal exit */
|
||||||
|
|
||||||
|
static void remove_pidfile(void)
|
||||||
|
{
|
||||||
|
unlink (pid_filename);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void create_pidfile(const char *filename)
|
||||||
|
{
|
||||||
|
struct stat pidstat;
|
||||||
|
FILE *f;
|
||||||
|
|
||||||
|
/* Try to write our PID to the named file */
|
||||||
|
if (stat(filename, &pidstat) < 0) {
|
||||||
|
if (errno == ENOENT) {
|
||||||
|
if ((f = fopen (filename, "w")) == NULL) {
|
||||||
|
perror("Opening pidfile");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
fprintf(f, "%d\n", getpid());
|
||||||
|
fclose(f);
|
||||||
|
pid_filename = qemu_strdup(filename);
|
||||||
|
if (!pid_filename) {
|
||||||
|
fprintf(stderr, "Could not save PID filename");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
atexit(remove_pidfile);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "%s already exists. Remove it and try again.\n",
|
||||||
|
filename);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/***********************************************************/
|
/***********************************************************/
|
||||||
/* dumb display */
|
/* dumb display */
|
||||||
|
|
||||||
@ -2533,6 +2573,7 @@ void help(void)
|
|||||||
"Debug/Expert options:\n"
|
"Debug/Expert options:\n"
|
||||||
"-monitor dev redirect the monitor to char device 'dev'\n"
|
"-monitor dev redirect the monitor to char device 'dev'\n"
|
||||||
"-serial dev redirect the serial port to char device 'dev'\n"
|
"-serial dev redirect the serial port to char device 'dev'\n"
|
||||||
|
"-pidfile file Write PID to 'file'\n"
|
||||||
"-S freeze CPU at startup (use 'c' to start execution)\n"
|
"-S freeze CPU at startup (use 'c' to start execution)\n"
|
||||||
"-s wait gdb connection to port %d\n"
|
"-s wait gdb connection to port %d\n"
|
||||||
"-p port change gdb connection port\n"
|
"-p port change gdb connection port\n"
|
||||||
@ -2625,6 +2666,7 @@ enum {
|
|||||||
QEMU_OPTION_serial,
|
QEMU_OPTION_serial,
|
||||||
QEMU_OPTION_loadvm,
|
QEMU_OPTION_loadvm,
|
||||||
QEMU_OPTION_full_screen,
|
QEMU_OPTION_full_screen,
|
||||||
|
QEMU_OPTION_pidfile,
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct QEMUOption {
|
typedef struct QEMUOption {
|
||||||
@ -2685,6 +2727,7 @@ const QEMUOption qemu_options[] = {
|
|||||||
{ "serial", 1, QEMU_OPTION_serial },
|
{ "serial", 1, QEMU_OPTION_serial },
|
||||||
{ "loadvm", HAS_ARG, QEMU_OPTION_loadvm },
|
{ "loadvm", HAS_ARG, QEMU_OPTION_loadvm },
|
||||||
{ "full-screen", 0, QEMU_OPTION_full_screen },
|
{ "full-screen", 0, QEMU_OPTION_full_screen },
|
||||||
|
{ "pidfile", HAS_ARG, QEMU_OPTION_pidfile },
|
||||||
|
|
||||||
/* temporary options */
|
/* temporary options */
|
||||||
{ "pci", 0, QEMU_OPTION_pci },
|
{ "pci", 0, QEMU_OPTION_pci },
|
||||||
@ -3110,6 +3153,9 @@ int main(int argc, char **argv)
|
|||||||
case QEMU_OPTION_full_screen:
|
case QEMU_OPTION_full_screen:
|
||||||
full_screen = 1;
|
full_screen = 1;
|
||||||
break;
|
break;
|
||||||
|
case QEMU_OPTION_pidfile:
|
||||||
|
create_pidfile(optarg);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user