Move set_proc_name() to OS specific files.
Move handling to change process name to POSIX specific files plus add a better error message to cover the case where the feature isn't supported. Signed-off-by: Jes Sorensen <Jes.Sorensen@redhat.com> Acked-by: Juan Quintela <quintela@redhat.com> Acked-by: Richard Henderson <rth@redhat.com> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
9156d76331
commit
ce798cf2a2
24
os-posix.c
24
os-posix.c
@ -37,6 +37,10 @@
|
|||||||
#include "net/slirp.h"
|
#include "net/slirp.h"
|
||||||
#include "qemu-options.h"
|
#include "qemu-options.h"
|
||||||
|
|
||||||
|
#ifdef CONFIG_LINUX
|
||||||
|
#include <sys/prctl.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
static struct passwd *user_pwd;
|
static struct passwd *user_pwd;
|
||||||
static const char *chroot_dir;
|
static const char *chroot_dir;
|
||||||
static int daemonize;
|
static int daemonize;
|
||||||
@ -139,6 +143,26 @@ char *os_find_datadir(const char *argv0)
|
|||||||
#undef SHARE_SUFFIX
|
#undef SHARE_SUFFIX
|
||||||
#undef BUILD_SUFFIX
|
#undef BUILD_SUFFIX
|
||||||
|
|
||||||
|
void os_set_proc_name(const char *s)
|
||||||
|
{
|
||||||
|
#if defined(PR_SET_NAME)
|
||||||
|
char name[16];
|
||||||
|
if (!s)
|
||||||
|
return;
|
||||||
|
name[sizeof(name) - 1] = 0;
|
||||||
|
strncpy(name, s, sizeof(name));
|
||||||
|
/* Could rewrite argv[0] too, but that's a bit more complicated.
|
||||||
|
This simple way is enough for `top'. */
|
||||||
|
if (prctl(PR_SET_NAME, name)) {
|
||||||
|
perror("unable to change process name");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
fprintf(stderr, "Change of process name not supported by your OS\n");
|
||||||
|
exit(1);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Parse OS specific command line options.
|
* Parse OS specific command line options.
|
||||||
* return 0 if option handled, -1 otherwise
|
* return 0 if option handled, -1 otherwise
|
||||||
|
@ -31,6 +31,7 @@ static inline void os_host_main_loop_wait(int *timeout)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void os_set_line_buffering(void);
|
void os_set_line_buffering(void);
|
||||||
|
void os_set_proc_name(const char *s);
|
||||||
void os_setup_signal_handling(void);
|
void os_setup_signal_handling(void);
|
||||||
void os_daemonize(void);
|
void os_daemonize(void);
|
||||||
void os_setup_post(void);
|
void os_setup_post(void);
|
||||||
|
@ -47,5 +47,6 @@ static inline void os_daemonize(void) {}
|
|||||||
static inline void os_setup_post(void) {}
|
static inline void os_setup_post(void) {}
|
||||||
/* Win32 doesn't support line-buffering and requires size >= 2 */
|
/* Win32 doesn't support line-buffering and requires size >= 2 */
|
||||||
static inline void os_set_line_buffering(void) {}
|
static inline void os_set_line_buffering(void) {}
|
||||||
|
static inline void os_set_proc_name(const char *dummy) {}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
19
vl.c
19
vl.c
@ -59,7 +59,6 @@
|
|||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
#include <pty.h>
|
#include <pty.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#include <sys/prctl.h>
|
|
||||||
|
|
||||||
#include <linux/ppdev.h>
|
#include <linux/ppdev.h>
|
||||||
#include <linux/parport.h>
|
#include <linux/parport.h>
|
||||||
@ -283,22 +282,6 @@ static int default_driver_check(QemuOpts *opts, void *opaque)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/***********************************************************/
|
|
||||||
|
|
||||||
static void set_proc_name(const char *s)
|
|
||||||
{
|
|
||||||
#if defined(__linux__) && defined(PR_SET_NAME)
|
|
||||||
char name[16];
|
|
||||||
if (!s)
|
|
||||||
return;
|
|
||||||
name[sizeof(name) - 1] = 0;
|
|
||||||
strncpy(name, s, sizeof(name));
|
|
||||||
/* Could rewrite argv[0] too, but that's a bit more complicated.
|
|
||||||
This simple way is enough for `top'. */
|
|
||||||
prctl(PR_SET_NAME, name);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/***********************************************************/
|
/***********************************************************/
|
||||||
/* real time host monotonic timer */
|
/* real time host monotonic timer */
|
||||||
|
|
||||||
@ -2988,7 +2971,7 @@ int main(int argc, char **argv, char **envp)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
p += 8;
|
p += 8;
|
||||||
set_proc_name(p);
|
os_set_proc_name(p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user