亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? dfork.c

?? 用來編寫 unix 環(huán)境下的守護(hù)程序的工具庫
?? C
字號(hào):
/* $Id: dfork.c 127 2007-07-10 16:53:50Z lennart $ *//* * This file is part of libdaemon. * * libdaemon 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. * * libdaemon 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 libdaemon; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA */#ifdef HAVE_CONFIG_H#include <config.h>#endif#include <sys/types.h>#include <unistd.h>#include <errno.h>#include <string.h>#include <fcntl.h>#include <sys/stat.h>#include <stdio.h>#include <stdlib.h>#include <sys/wait.h>#include <assert.h>#include <sys/ioctl.h>#include <signal.h>#include <sys/time.h>#include <sys/resource.h>#include <dirent.h>#include "dfork.h"#include "dnonblock.h"#include "dlog.h"static int _daemon_retval_pipe[2] = { -1, -1 };static int _null_open(int f, int fd) {    int fd2;    if ((fd2 = open("/dev/null", f)) < 0)        return -1;        if (fd2 == fd)        return fd;    if (dup2(fd2, fd) < 0)        return -1;    close(fd2);    return fd;}static ssize_t atomic_read(int fd, void *d, size_t l) {    ssize_t t = 0;        while (l > 0) {        ssize_t r;                if ((r = read(fd, d, l)) <= 0) {            if (r < 0)                return t > 0 ? t : -1;            else                return t;        }        t += r;        d = (char*) d + r;        l -= r;    }    return t;}static ssize_t atomic_write(int fd, const void *d, size_t l) {    ssize_t t = 0;        while (l > 0) {        ssize_t r;                if ((r = write(fd, d, l)) <= 0) {            if (r < 0)                return t > 0 ? t : -1;            else                return t;        }        t += r;        d = (const char*) d + r;        l -= r;    }    return t;}static int move_fd_up(int *fd) {    assert(fd);        while (*fd <= 2) {        if ((*fd = dup(*fd)) < 0) {            daemon_log(LOG_ERR, "dup(): %s", strerror(errno));            return -1;        }    }    return 0;}static void sigchld(int s) {}pid_t daemon_fork(void) {    pid_t pid;    int pipe_fds[2] = {-1, -1};    struct sigaction sa_old, sa_new;    sigset_t ss_old, ss_new;    memset(&sa_new, 0, sizeof(sa_new));    sa_new.sa_handler = sigchld;    sa_new.sa_flags = SA_RESTART;        if (sigaction(SIGCHLD, &sa_new, &sa_old) < 0) {        daemon_log(LOG_ERR, "sigaction() failed: %s", strerror(errno));        return (pid_t) -1;    }    sigemptyset(&ss_new);    sigaddset(&ss_new, SIGCHLD);        if (sigprocmask(SIG_UNBLOCK, &ss_new, &ss_old) < 0) {        daemon_log(LOG_ERR, "sigprocmask() failed: %s", strerror(errno));        sigaction(SIGCHLD, &sa_old, NULL);        return (pid_t) -1;    }        if (pipe(pipe_fds) < 0) {        daemon_log(LOG_ERR, "pipe() failed: %s", strerror(errno));        sigaction(SIGCHLD, &sa_old, NULL);        sigprocmask(SIG_SETMASK, &ss_old, NULL);        return (pid_t) -1;    }    if ((pid = fork()) < 0) { /* First fork */        daemon_log(LOG_ERR, "First fork() failed: %s", strerror(errno));        close(pipe_fds[0]);        close(pipe_fds[1]);        sigaction(SIGCHLD, &sa_old, NULL);        sigprocmask(SIG_SETMASK, &ss_old, NULL);        return (pid_t) -1;    } else if (pid == 0) {        pid_t dpid;                /* First child */        sigaction(SIGCHLD, &sa_old, NULL);        sigprocmask(SIG_SETMASK, &ss_old, NULL);        close(pipe_fds[0]);        /* Move file descriptors up*/        if (move_fd_up(&pipe_fds[1]) < 0)            goto fail;        if (_daemon_retval_pipe[0] >= 0 && move_fd_up(&_daemon_retval_pipe[0]) < 0)            goto fail;        if (_daemon_retval_pipe[1] >= 0 && move_fd_up(&_daemon_retval_pipe[1]) < 0)            goto fail;                    if (_null_open(O_RDONLY, 0) < 0) {            daemon_log(LOG_ERR, "Failed to open /dev/null for STDIN: %s", strerror(errno));            goto fail;        }                if (_null_open(O_WRONLY, 1) < 0) {            daemon_log(LOG_ERR, "Failed to open /dev/null for STDOUT: %s", strerror(errno));            goto fail;        }                if (_null_open(O_WRONLY, 2) < 0) {            daemon_log(LOG_ERR, "Failed to open /dev/null for STDERR: %s", strerror(errno));            goto fail;        }        setsid();        umask(0777);        chdir("/");        if ((pid = fork()) < 0) { /* Second fork */            daemon_log(LOG_ERR, "Second fork() failed: %s", strerror(errno));            goto fail;        } else if (pid == 0) {            int tty_fd;            /* Second child */                        if (daemon_log_use & DAEMON_LOG_AUTO)                daemon_log_use = DAEMON_LOG_SYSLOG;                    signal(SIGTTOU, SIG_IGN);            signal(SIGTTIN, SIG_IGN);            signal(SIGTSTP, SIG_IGN);                        setsid();            setpgid(0,0);#ifdef TIOCNOTTY            if ((tty_fd = open("/dev/tty", O_RDWR)) >= 0) {                ioctl(tty_fd, TIOCNOTTY, NULL);                close(tty_fd);            }#endif            dpid = getpid();            if (atomic_write(pipe_fds[1], &dpid, sizeof(dpid)) != sizeof(dpid))                goto fail;            close(pipe_fds[1]);            return 0;        } else {            /* Second father */            close(pipe_fds[1]);            _exit(0);        }                fail:        dpid = (pid_t) -1;        if (atomic_write(pipe_fds[1], &dpid, sizeof(dpid)) != sizeof(dpid))            daemon_log(LOG_ERR, "Failed to write error PID.");        close(pipe_fds[1]);        _exit(0);    } else {        /* First father */        pid_t dpid;        close(pipe_fds[1]);        waitpid(pid, NULL, WUNTRACED);                sigprocmask(SIG_SETMASK, &ss_old, NULL);        sigaction(SIGCHLD, &sa_old, NULL);        if (atomic_read(pipe_fds[0], &dpid, sizeof(dpid)) != sizeof(dpid)) {            daemon_log(LOG_ERR, "Failed to read daemon PID.");            dpid = (pid_t) -1;        }        close(pipe_fds[0]);        return dpid;    }}int daemon_retval_init(void) {    if (pipe(_daemon_retval_pipe) < 0)        return -1;    return 0;}void daemon_retval_done(void) {    if (_daemon_retval_pipe[0] >= 0)        close(_daemon_retval_pipe[0]);        if (_daemon_retval_pipe[1] >= 0)        close(_daemon_retval_pipe[1]);    _daemon_retval_pipe[0] = _daemon_retval_pipe[1] = -1;}int daemon_retval_send(int i) {    ssize_t r;    if (_daemon_retval_pipe[1] < 0) {        errno = EINVAL;        return -1;    }    r = atomic_write(_daemon_retval_pipe[1], &i, sizeof(i));    daemon_retval_done();    if (r != sizeof(i)) {        if (r < 0)            daemon_log(LOG_ERR, "write() failed while writing return value to pipe: %s", strerror(errno));        else {            daemon_log(LOG_ERR, "write() too short while writing return value from pipe");            errno = EINVAL;        }                return -1;    }    return 0;}int daemon_retval_wait(int timeout) {    ssize_t r;    int i;    if (timeout > 0) {        struct timeval tv;        int s;        fd_set fds;        tv.tv_sec = timeout;        tv.tv_usec = 0;                FD_ZERO(&fds);        FD_SET(_daemon_retval_pipe[0], &fds);        if ((s = select(FD_SETSIZE, &fds, 0, 0, &tv)) != 1) {                        if (s < 0)                daemon_log(LOG_ERR, "select() failed while waiting for return value: %s", strerror(errno));            else {                errno = ETIMEDOUT;                daemon_log(LOG_ERR, "Timeout reached while wating for return value");            }                    return -1;        }    }    if ((r = atomic_read(_daemon_retval_pipe[0], &i, sizeof(i))) != sizeof(i)) {        if (r < 0)            daemon_log(LOG_ERR, "read() failed while reading return value from pipe: %s", strerror(errno));        else if (r == 0) {            daemon_log(LOG_ERR, "read() failed with EOF while reading return value from pipe.");            errno = EINVAL;        } else if (r > 0) {            daemon_log(LOG_ERR, "read() too short while reading return value from pipe.");            errno = EINVAL;        }                return -1;    }    daemon_retval_done();        return i;}int daemon_close_all(int except_fd, ...) {    va_list original_ap, ap;    int n = 0, i, r;    int *p;    va_start(original_ap, except_fd);    va_copy(ap, original_ap);    if (except_fd >= 0)        for (n = 1; va_arg(ap, int) >= 0; n++)            ;    va_end(ap);    if (!(p = malloc(sizeof(int) * (n+1)))) {        va_end(original_ap);        return -1;    }    i = 0;    if (except_fd >= 0) {        p[i++] = except_fd;                while ((p[i++] = va_arg(original_ap, int)) >= 0)            ;    }    p[i] = -1;        r = daemon_close_allv(p);    free(p);        return r;}/** Same as daemon_close_all but takes an array of fds, terminated by -1 */int daemon_close_allv(const int except_fds[]) {    struct rlimit rl;    int fd;    #ifdef __linux__    DIR *d;    if ((d = opendir("/proc/self/fd"))) {        struct dirent *de;        while ((de = readdir(d))) {            long l;            char *e = NULL;            int i, fd;            if (de->d_name[0] == '.')                continue;                        errno = 0;            l = strtol(de->d_name, &e, 10);            if (errno != 0 || !e || *e) {                closedir(d);                errno = EINVAL;                return -1;            }            fd = (int) l;            if ((long) fd != l) {                closedir(d);                errno = EINVAL;                return -1;            }            if (fd <= 3)                continue;                        if (fd == dirfd(d))                continue;            if (fd == _daemon_retval_pipe[1])                continue;            for (i = 0; except_fds[i] >= 0; i++)                if (except_fds[i] == fd)                    continue;            if (close(fd) < 0) {                closedir(d);                return -1;            }        }                closedir(d);        return 0;    }    #endif    if (getrlimit(RLIMIT_NOFILE, &rl) < 0)        return -1;    for (fd = 0; fd < (int) rl.rlim_max; fd++) {        int i;        if (fd <= 3)            continue;                if (fd == _daemon_retval_pipe[1])            continue;                for (i = 0; except_fds[i] >= 0; i++)             if (except_fds[i] == fd)                continue;        if (close(fd) < 0 && errno != EBADF)            return -1;    }    return 0;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日日摸夜夜添夜夜添国产精品| 日韩美女天天操| 九九视频精品免费| 亚洲国产中文字幕在线视频综合| ...xxx性欧美| 中日韩免费视频中文字幕| 久久婷婷成人综合色| 精品久久久久一区| 欧美成人一区二区三区片免费| 日韩色视频在线观看| 日韩欧美一区二区在线视频| 欧美二区三区的天堂| 欧美一区二区在线看| 日韩三级av在线播放| 日韩精品中午字幕| 欧美电影免费观看完整版| 精品国产91乱码一区二区三区| 欧美不卡一区二区三区四区| 欧美不卡一区二区三区四区| 久久这里只精品最新地址| 国产欧美一区在线| 日韩毛片精品高清免费| 亚洲午夜私人影院| 人人爽香蕉精品| 国产精品一卡二卡| 暴力调教一区二区三区| 色哟哟国产精品免费观看| 欧美精品在线视频| 亚洲精品在线三区| 亚洲丝袜精品丝袜在线| 亚洲国产精品久久人人爱蜜臀| 日本vs亚洲vs韩国一区三区二区 | 国产精品18久久久久久久久 | 美女在线观看视频一区二区| 另类调教123区 | 欧美色男人天堂| 日韩欧美国产一区二区三区| 国产精品无遮挡| 天堂久久一区二区三区| 成人在线一区二区三区| 欧美四级电影在线观看| 久久影院午夜论| 亚洲精品va在线观看| 麻豆精品一区二区av白丝在线| 国产一二精品视频| 色综合夜色一区| 亚洲精品在线观| 亚洲h动漫在线| 国产一区二区中文字幕| 色婷婷香蕉在线一区二区| 日韩三级在线观看| 国产精品国产自产拍高清av| 天堂蜜桃91精品| 91视频一区二区三区| 精品国产91久久久久久久妲己 | 国产精品一二三四| 欧美日韩在线直播| 亚洲一区二区在线播放相泽| 国产呦萝稀缺另类资源| 这里只有精品视频在线观看| 中文字幕一区二区三区在线不卡 | 日本一区二区三区在线观看| 亚洲国产综合色| 色综合一个色综合亚洲| 中文字幕欧美国产| 国内外精品视频| 日韩欧美一卡二卡| 日韩精品亚洲一区| 欧美性做爰猛烈叫床潮| 国产精品午夜电影| 成人av午夜电影| 国产欧美精品一区二区三区四区| 久热成人在线视频| 制服丝袜在线91| 日本va欧美va瓶| 欧美日韩一区二区三区四区| 一区二区三区四区在线免费观看| av一区二区三区四区| 国产精品免费久久| 国产高清不卡一区二区| 国产免费久久精品| 国产高清不卡一区| 国产精品国产精品国产专区不片| 国产在线精品视频| 国产欧美一区二区精品久导航| 久久激情综合网| 久久久99免费| 懂色av一区二区在线播放| 国产精品美女久久久久久久 | 欧美日韩一区视频| 日韩国产欧美在线播放| 69av一区二区三区| 美女mm1313爽爽久久久蜜臀| 欧美mv日韩mv国产网站| 国产一二三精品| 一区精品在线播放| 91国产免费看| 青青国产91久久久久久| 日韩精品一区二区三区视频在线观看 | 在线视频国内一区二区| 一区二区三区成人在线视频| 欧美精品丝袜中出| 久久国产三级精品| 亚洲欧美综合另类在线卡通| 欧美在线观看视频一区二区 | 精品视频一区二区不卡| 免费精品视频在线| 久久精品亚洲精品国产欧美 | 国产亚洲欧美一区在线观看| 丰满少妇在线播放bd日韩电影| 中文字幕av在线一区二区三区| av一本久道久久综合久久鬼色| 亚洲国产综合91精品麻豆| 欧美一级黄色片| 91无套直看片红桃| 日韩高清一区二区| 国产精品久久久久久妇女6080| 欧美久久一二区| 成人一区二区三区在线观看| 亚洲成人动漫在线免费观看| 国产午夜精品一区二区| 精品1区2区3区| 成人午夜在线播放| 蜜桃久久av一区| 亚洲图片激情小说| 久久嫩草精品久久久精品| 色狠狠一区二区三区香蕉| 国产在线一区观看| 亚洲国产日韩av| 国产精品久久久久久久第一福利| 欧美日韩国产欧美日美国产精品| 粉嫩一区二区三区在线看| 天天影视涩香欲综合网| 一区二区三区在线视频观看| 国产日韩欧美电影| 精品美女在线播放| 91精品国产乱码| 日本韩国欧美一区二区三区| 成人免费精品视频| 狠狠色狠狠色综合日日91app| 视频一区免费在线观看| 亚洲精品乱码久久久久久久久 | 99久久国产综合精品色伊| 另类综合日韩欧美亚洲| 五月综合激情网| 一区二区免费视频| 亚洲美女屁股眼交3| 中文av一区特黄| 国产女同性恋一区二区| 精品嫩草影院久久| 精品国产1区二区| 欧美成人免费网站| 欧美xxxxx牲另类人与| 欧美日韩精品欧美日韩精品一综合| www.成人网.com| eeuss鲁片一区二区三区| 高清视频一区二区| eeuss国产一区二区三区| 欧美伊人久久久久久午夜久久久久| 国产91精品免费| 国产高清精品久久久久| 成人综合婷婷国产精品久久免费| 国产成人精品免费网站| 国产一区二区伦理| www.欧美亚洲| 99久久国产免费看| 在线一区二区视频| 欧美丝袜丝nylons| 欧美一区二区三区日韩| 日韩一级欧美一级| 久久九九久精品国产免费直播| 国产精品天天摸av网| 亚洲欧洲精品一区二区三区| 一个色综合av| 日本女人一区二区三区| 国产一区999| av一区二区三区四区| 欧美视频在线一区| 日韩一区二区三区四区五区六区| 久久久久久一二三区| 国产精品国产自产拍高清av| 一区二区在线看| 蜜臀精品久久久久久蜜臀| 精品亚洲欧美一区| 91影院在线观看| 欧美精品精品一区| 日本一区二区三区dvd视频在线| 亚洲视频小说图片| 午夜亚洲福利老司机| 国产成人精品www牛牛影视| 成人国产亚洲欧美成人综合网| 欧美性感一类影片在线播放| 91精品国产一区二区三区蜜臀| 久久久久国产精品麻豆| 亚洲欧美另类久久久精品2019 | 国产日产欧美精品一区二区三区| 国产精品看片你懂得| 视频一区在线视频| 丁香天五香天堂综合| 欧美日韩国产美|