start_stop_daemon: NOMMU fixes, round 2 by Alex Landau <landau_alex@yahoo.com>
dhcpc: fixed "ifupdown + udhcpc_without_pidpile_creation" bug
This commit is contained in:
parent
fc77eb54e7
commit
1caca34aa6
@ -14,6 +14,8 @@
|
|||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
#include <sys/resource.h>
|
#include <sys/resource.h>
|
||||||
|
|
||||||
|
/* Override ENABLE_FEATURE_PIDFILE */
|
||||||
|
#define WANT_PIDFILE 1
|
||||||
#include "libbb.h"
|
#include "libbb.h"
|
||||||
|
|
||||||
static int signal_nr = 15;
|
static int signal_nr = 15;
|
||||||
@ -46,7 +48,7 @@ static int pid_is_exec(pid_t pid, const char *name)
|
|||||||
n = strcmp(execbuf, name);
|
n = strcmp(execbuf, name);
|
||||||
if (ENABLE_FEATURE_CLEAN_UP)
|
if (ENABLE_FEATURE_CLEAN_UP)
|
||||||
free(execbuf);
|
free(execbuf);
|
||||||
return ~n; /* nonzero (true) if execbuf == name */
|
return !n; /* nonzero (true) if execbuf == name */
|
||||||
}
|
}
|
||||||
|
|
||||||
static int pid_is_user(int pid, int uid)
|
static int pid_is_user(int pid, int uid)
|
||||||
@ -301,10 +303,14 @@ int start_stop_daemon_main(int argc, char **argv)
|
|||||||
pid_t pid = vfork();
|
pid_t pid = vfork();
|
||||||
if (pid < 0) /* error */
|
if (pid < 0) /* error */
|
||||||
bb_perror_msg_and_die("vfork");
|
bb_perror_msg_and_die("vfork");
|
||||||
if (pid == 0) /* parent */
|
if (pid != 0) {
|
||||||
return 0;
|
/* parent */
|
||||||
|
/* why _exit? the child may have changed the stack,
|
||||||
|
* so "return 0" may do bad things */
|
||||||
|
_exit(0);
|
||||||
}
|
}
|
||||||
/* child */
|
/* child */
|
||||||
|
setsid(); /* detach from controlling tty */
|
||||||
/* Redirect stdio to /dev/null, close extra FDs.
|
/* Redirect stdio to /dev/null, close extra FDs.
|
||||||
* We do not actually daemonize because of DAEMON_ONLY_SANITIZE */
|
* We do not actually daemonize because of DAEMON_ONLY_SANITIZE */
|
||||||
bb_daemonize_or_rexec(
|
bb_daemonize_or_rexec(
|
||||||
@ -316,11 +322,7 @@ int start_stop_daemon_main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
if (opt & OPT_MAKEPID) {
|
if (opt & OPT_MAKEPID) {
|
||||||
/* user wants _us_ to make the pidfile */
|
/* user wants _us_ to make the pidfile */
|
||||||
FILE *pidf = xfopen(pidfile, "w");
|
write_pidfile(pidfile);
|
||||||
|
|
||||||
pid_t pidt = getpid();
|
|
||||||
fprintf(pidf, "%d\n", pidt);
|
|
||||||
fclose(pidf);
|
|
||||||
}
|
}
|
||||||
if (opt & OPT_c) {
|
if (opt & OPT_c) {
|
||||||
struct bb_uidgid_t ugid;
|
struct bb_uidgid_t ugid;
|
||||||
|
@ -619,8 +619,9 @@ llist_t *llist_rev(llist_t *list);
|
|||||||
* llist_t *llist_add_to(llist_t *old_head, void *data)
|
* llist_t *llist_add_to(llist_t *old_head, void *data)
|
||||||
* etc does not result in smaller code... */
|
* etc does not result in smaller code... */
|
||||||
|
|
||||||
|
/* start_stop_daemon and (udhcpc with ifupdown) are special - they want to
|
||||||
#if ENABLE_FEATURE_PIDFILE
|
* create pidfiles regardless of FEATURE_PIDFILE. */
|
||||||
|
#if ENABLE_FEATURE_PIDFILE || defined(WANT_PIDFILE)
|
||||||
int write_pidfile(const char *path);
|
int write_pidfile(const char *path);
|
||||||
#define remove_pidfile(f) ((void)unlink(f))
|
#define remove_pidfile(f) ((void)unlink(f))
|
||||||
#else
|
#else
|
||||||
|
@ -6,9 +6,11 @@
|
|||||||
*
|
*
|
||||||
* Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
|
* Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Override ENABLE_FEATURE_PIDFILE */
|
||||||
|
#define WANT_PIDFILE 1
|
||||||
#include "libbb.h"
|
#include "libbb.h"
|
||||||
|
|
||||||
#if ENABLE_FEATURE_PIDFILE
|
|
||||||
int write_pidfile(const char *path)
|
int write_pidfile(const char *path)
|
||||||
{
|
{
|
||||||
int pid_fd;
|
int pid_fd;
|
||||||
@ -26,4 +28,3 @@ int write_pidfile(const char *path)
|
|||||||
close(pid_fd);
|
close(pid_fd);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
@ -536,8 +536,8 @@ static int manual_up_down(struct interface_defn_t *ifd, execfn *exec)
|
|||||||
static int bootp_up(struct interface_defn_t *ifd, execfn *exec)
|
static int bootp_up(struct interface_defn_t *ifd, execfn *exec)
|
||||||
{
|
{
|
||||||
return execute("bootpc[[ --bootfile %bootfile%]] --dev %iface%"
|
return execute("bootpc[[ --bootfile %bootfile%]] --dev %iface%"
|
||||||
"[[ --server %server%]][[ --hwaddr %hwaddr%]] "
|
"[[ --server %server%]][[ --hwaddr %hwaddr%]]"
|
||||||
"--returniffail --serverbcast", ifd, exec);
|
" --returniffail --serverbcast", ifd, exec);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ppp_up(struct interface_defn_t *ifd, execfn *exec)
|
static int ppp_up(struct interface_defn_t *ifd, execfn *exec)
|
||||||
|
@ -11,6 +11,8 @@
|
|||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
#include <syslog.h>
|
#include <syslog.h>
|
||||||
|
|
||||||
|
/* Override ENABLE_FEATURE_PIDFILE - ifupdown needs our pidfile to always exist */
|
||||||
|
#define WANT_PIDFILE 1
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "dhcpd.h"
|
#include "dhcpd.h"
|
||||||
#include "dhcpc.h"
|
#include "dhcpc.h"
|
||||||
|
Loading…
Reference in New Issue
Block a user