mirror of
https://github.com/openvswitch/ovs
synced 2025-10-19 14:37:21 +00:00
The following code does not add any users yet. The visioned workflow that this piece of code should work with is: * Create a windows service through a startup script with a tool like 'sc' ex: sc create ovsdb-server binpath= "C:\openvswitch\usr\sbin\ovsdb-server.exe -vconsole:off -vsyslog:off -vfile:info --remote=ptcp:6632:127.0.0.1 --log-file --service-monitor --service" * Start the service from the startup script. ex: sc start ovsdb-server * Terminate the service during shutdown process. ex: sc stop ovsdb-server * Abrupt termination will restart the service. Signed-off-by: Gurucharan Shetty <gshetty@nicira.com> Acked-by: Ben Pfaff <blp@nicira.com>
111 lines
4.3 KiB
C
111 lines
4.3 KiB
C
/*
|
|
* Copyright (c) 2008, 2009, 2010, 2011, 2012 Nicira, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at:
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef DAEMON_H
|
|
#define DAEMON_H 1
|
|
|
|
#include <limits.h>
|
|
#include <stdbool.h>
|
|
#include <sys/types.h>
|
|
|
|
/* This file provides an interface for utilities to run in the background
|
|
* as daemons on POSIX platforms like Linux or as services on Windows platform.
|
|
* Some of the functionalities defined in this file are only applicable to
|
|
* POSIX platforms and some are applicable only on Windows. As such, the
|
|
* function definitions unique to each platform are separated out with
|
|
* ifdef macros. More descriptive comments on individual functions are provided
|
|
* in daemon.c (for Linux) and daemon-windows.c (for Windows).
|
|
|
|
* The DAEMON_OPTION_ENUMS, DAEMON_LONG_OPTIONS and DAEMON_OPTION_HANDLERS
|
|
* macros are useful for parsing command-line options in individual utilities.
|
|
* For e.g., the command-line option "--detach" is recognized on Linux
|
|
* and results in calling the set_detach() function. The same option is not
|
|
* recognized on Windows platform.
|
|
*/
|
|
|
|
#ifndef _WIN32
|
|
#define DAEMON_OPTION_ENUMS \
|
|
OPT_DETACH, \
|
|
OPT_NO_CHDIR, \
|
|
OPT_OVERWRITE_PIDFILE, \
|
|
OPT_PIDFILE, \
|
|
OPT_MONITOR
|
|
|
|
#define DAEMON_LONG_OPTIONS \
|
|
{"detach", no_argument, NULL, OPT_DETACH}, \
|
|
{"no-chdir", no_argument, NULL, OPT_NO_CHDIR}, \
|
|
{"pidfile", optional_argument, NULL, OPT_PIDFILE}, \
|
|
{"overwrite-pidfile", no_argument, NULL, OPT_OVERWRITE_PIDFILE}, \
|
|
{"monitor", no_argument, NULL, OPT_MONITOR}
|
|
|
|
#define DAEMON_OPTION_HANDLERS \
|
|
case OPT_DETACH: \
|
|
set_detach(); \
|
|
break; \
|
|
\
|
|
case OPT_NO_CHDIR: \
|
|
set_no_chdir(); \
|
|
break; \
|
|
\
|
|
case OPT_PIDFILE: \
|
|
set_pidfile(optarg); \
|
|
break; \
|
|
\
|
|
case OPT_OVERWRITE_PIDFILE: \
|
|
ignore_existing_pidfile(); \
|
|
break; \
|
|
\
|
|
case OPT_MONITOR: \
|
|
daemon_set_monitor(); \
|
|
break;
|
|
|
|
void set_detach(void);
|
|
void daemon_set_monitor(void);
|
|
void set_pidfile(const char *name);
|
|
void set_no_chdir(void);
|
|
void ignore_existing_pidfile(void);
|
|
pid_t read_pidfile(const char *name);
|
|
#else
|
|
#define DAEMON_OPTION_ENUMS \
|
|
OPT_SERVICE, \
|
|
OPT_SERVICE_MONITOR
|
|
|
|
#define DAEMON_LONG_OPTIONS \
|
|
{"service", no_argument, NULL, OPT_SERVICE}, \
|
|
{"service-monitor", no_argument, NULL, OPT_SERVICE_MONITOR}
|
|
|
|
#define DAEMON_OPTION_HANDLERS \
|
|
case OPT_SERVICE: \
|
|
break; \
|
|
\
|
|
case OPT_SERVICE_MONITOR: \
|
|
break;
|
|
|
|
void control_handler(DWORD request);
|
|
#endif /* _WIN32 */
|
|
|
|
bool get_detach(void);
|
|
void daemon_save_fd(int fd);
|
|
void daemonize(void);
|
|
void daemonize_start(void);
|
|
void daemonize_complete(void);
|
|
void daemon_usage(void);
|
|
void service_start(int *argcp, char **argvp[]);
|
|
void service_stop(void);
|
|
bool should_service_stop(void);
|
|
|
|
#endif /* daemon.h */
|