mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 12:35:17 +00:00
Move virProcessKill into virprocess.{h,c}
There are a number of process related functions spread across multiple files. Start to consolidate them by creating a virprocess.{c,h} file Signed-off-by: Daniel P. Berrange <berrange@redhat.com> (cherry picked from commit e5e2b65cf86ea49eba76b3c274e3b9d2177485bc)
This commit is contained in:
parent
5292eed6e2
commit
a5cf2ef4a7
@ -87,6 +87,7 @@ UTIL_SOURCES = \
|
||||
util/virnodesuspend.c util/virnodesuspend.h \
|
||||
util/virobject.c util/virobject.h \
|
||||
util/virpidfile.c util/virpidfile.h \
|
||||
util/virprocess.c util/virprocess.h \
|
||||
util/virtypedparam.c util/virtypedparam.h \
|
||||
util/xml.c util/xml.h \
|
||||
util/virterror.c util/virterror_internal.h \
|
||||
|
@ -1708,6 +1708,9 @@ virPidFileDelete;
|
||||
virPidFileDeletePath;
|
||||
|
||||
|
||||
# virprocess.h
|
||||
virProcessKill;
|
||||
|
||||
# virrandom.h
|
||||
virRandom;
|
||||
virRandomBits;
|
||||
|
@ -39,6 +39,7 @@
|
||||
#include "virterror_internal.h"
|
||||
#include "json.h"
|
||||
#include "virfile.h"
|
||||
#include "virprocess.h"
|
||||
#include "virtime.h"
|
||||
#include "virobject.h"
|
||||
|
||||
|
@ -36,6 +36,7 @@
|
||||
#include "memory.h"
|
||||
#include "logging.h"
|
||||
#include "virfile.h"
|
||||
#include "virprocess.h"
|
||||
#include "virobject.h"
|
||||
|
||||
#ifdef WITH_DTRACE_PROBES
|
||||
|
@ -61,6 +61,7 @@
|
||||
#include "locking/domain_lock.h"
|
||||
#include "network/bridge_driver.h"
|
||||
#include "uuid.h"
|
||||
#include "virprocess.h"
|
||||
#include "virtime.h"
|
||||
#include "virnetdevtap.h"
|
||||
#include "bitmap.h"
|
||||
|
@ -63,6 +63,7 @@
|
||||
#include "configmake.h"
|
||||
#include "virnetdevtap.h"
|
||||
#include "virnodesuspend.h"
|
||||
#include "virprocess.h"
|
||||
#include "viruri.h"
|
||||
|
||||
#define VIR_FROM_THIS VIR_FROM_UML
|
||||
|
@ -2289,63 +2289,6 @@ check_and_return:
|
||||
return result;
|
||||
}
|
||||
|
||||
/* send signal to a single process */
|
||||
int virProcessKill(pid_t pid, int sig)
|
||||
{
|
||||
if (pid <= 1) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
|
||||
#ifdef WIN32
|
||||
/* Mingw / Windows don't have many signals (AFAIK) */
|
||||
switch (sig) {
|
||||
case SIGINT:
|
||||
/* This does a Ctrl+C equiv */
|
||||
if (!GenerateConsoleCtrlEvent(CTRL_C_EVENT, pid)) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
break;
|
||||
|
||||
case SIGTERM:
|
||||
/* Since TerminateProcess is closer to SIG_KILL, we do
|
||||
* a Ctrl+Break equiv which is more pleasant like the
|
||||
* good old unix SIGTERM/HUP
|
||||
*/
|
||||
if (!GenerateConsoleCtrlEvent(CTRL_BREAK_EVENT, pid)) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
{
|
||||
HANDLE proc;
|
||||
proc = OpenProcess(PROCESS_TERMINATE, FALSE, pid);
|
||||
if (!proc) {
|
||||
errno = ESRCH; /* Not entirely accurate, but close enough */
|
||||
return -1;
|
||||
}
|
||||
|
||||
/*
|
||||
* TerminateProcess is more or less equiv to SIG_KILL, in that
|
||||
* a process can't trap / block it
|
||||
*/
|
||||
if (sig != 0 && !TerminateProcess(proc, sig)) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
CloseHandle(proc);
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
#else
|
||||
return kill(pid, sig);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifdef HAVE_GETPWUID_R
|
||||
enum {
|
||||
VIR_USER_ENT_DIRECTORY,
|
||||
|
@ -255,8 +255,6 @@ static inline int getgid (void) { return 0; }
|
||||
|
||||
char *virGetHostname(virConnectPtr conn);
|
||||
|
||||
int virProcessKill(pid_t pid, int sig);
|
||||
|
||||
char *virGetUserDirectory(void);
|
||||
char *virGetUserConfigDirectory(void);
|
||||
char *virGetUserCacheDirectory(void);
|
||||
|
84
src/util/virprocess.c
Normal file
84
src/util/virprocess.c
Normal file
@ -0,0 +1,84 @@
|
||||
/*
|
||||
* virprocess.c: interaction with processes
|
||||
*
|
||||
* Copyright (C) 2010-2012 Red Hat, Inc.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library. If not, see
|
||||
* <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#include <config.h>
|
||||
|
||||
#include <signal.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include "virprocess.h"
|
||||
|
||||
/* send signal to a single process */
|
||||
int virProcessKill(pid_t pid, int sig)
|
||||
{
|
||||
if (pid <= 1) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
|
||||
#ifdef WIN32
|
||||
/* Mingw / Windows don't have many signals (AFAIK) */
|
||||
switch (sig) {
|
||||
case SIGINT:
|
||||
/* This does a Ctrl+C equiv */
|
||||
if (!GenerateConsoleCtrlEvent(CTRL_C_EVENT, pid)) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
break;
|
||||
|
||||
case SIGTERM:
|
||||
/* Since TerminateProcess is closer to SIG_KILL, we do
|
||||
* a Ctrl+Break equiv which is more pleasant like the
|
||||
* good old unix SIGTERM/HUP
|
||||
*/
|
||||
if (!GenerateConsoleCtrlEvent(CTRL_BREAK_EVENT, pid)) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
{
|
||||
HANDLE proc;
|
||||
proc = OpenProcess(PROCESS_TERMINATE, FALSE, pid);
|
||||
if (!proc) {
|
||||
errno = ESRCH; /* Not entirely accurate, but close enough */
|
||||
return -1;
|
||||
}
|
||||
|
||||
/*
|
||||
* TerminateProcess is more or less equiv to SIG_KILL, in that
|
||||
* a process can't trap / block it
|
||||
*/
|
||||
if (sig != 0 && !TerminateProcess(proc, sig)) {
|
||||
errno = ESRCH;
|
||||
return -1;
|
||||
}
|
||||
CloseHandle(proc);
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
#else
|
||||
return kill(pid, sig);
|
||||
#endif
|
||||
}
|
31
src/util/virprocess.h
Normal file
31
src/util/virprocess.h
Normal file
@ -0,0 +1,31 @@
|
||||
/*
|
||||
* virprocess.h: interaction with processes
|
||||
*
|
||||
* Copyright (C) 2010-2012 Red Hat, Inc.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library. If not, see
|
||||
* <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __VIR_PROCESS_H__
|
||||
# define __VIR_PROCESS_H__
|
||||
|
||||
# include <sys/types.h>
|
||||
|
||||
# include "internal.h"
|
||||
|
||||
int virProcessKill(pid_t pid, int sig);
|
||||
|
||||
#endif /* __VIR_PROCESS_H__ */
|
Loading…
x
Reference in New Issue
Block a user