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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ppplib.c

?? vxworks下的實現網絡TCPIP協議的原代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
intr(sig)    int sig;{    MAINDEBUG((LOG_INFO, "Interrupt received: terminating link"));    adjtimeout();			/* Adjust timeouts */    die(ppp_unit, 1);			/* Close connection */}/* * alrm - Catch SIGALRM signal. * * Indicates a timeout. */static voidalrm(sig)    int sig;{    struct itimerspec itv;    struct callout *freep, *list, *last;        MAINDEBUG((LOG_DEBUG, "Alarm"));        if (ppp_if[ppp_unit]->callout == NULL)        return;    /*     * Get the first scheduled timeout and any that were scheduled     * for the same time as a list, and remove them all from callout     * list.     */    list = last = ppp_if[ppp_unit]->callout;    while (last->c_next != NULL && last->c_next->c_time == 0)        last = last->c_next;    ppp_if[ppp_unit]->callout = last->c_next;    last->c_next = NULL;    /*     * Set a new itimer if there are more timeouts scheduled.     */    if (ppp_if[ppp_unit]->callout) {        itv.it_interval.tv_sec = itv.it_interval.tv_nsec = 0;        itv.it_value.tv_nsec = 0;        itv.it_value.tv_sec = ppp_if[ppp_unit]->callout->c_time;        MAINDEBUG((LOG_DEBUG, "Setting itimer for %d seconds in alrm.",                   itv.it_value.tv_sec));        if (timer_settime(ppp_if[ppp_unit]->timer_id, CLOCK_REALTIME, &itv, NULL) < 0) {            syslog(LOG_ERR, "setitimer(ITIMER_REAL): error");            die(ppp_unit, 1);        }        if (time(&ppp_if[ppp_unit]->schedtime) == ERROR) {            syslog(LOG_ERR, "gettimeofday: error");            die(ppp_unit, 1);        }    }    /*     * Now call all the timeout routines scheduled for this time.     */    while (list) {        (*list->c_func)(list->c_arg);        freep = list;        list = list->c_next;        (void) free((char *) freep);    }  }  /* * io - Catch SIGIO signal. * * Indicates that incoming data is available. */static voidio(){    int len, i;    u_char *p;    u_short protocol;    MAINDEBUG((LOG_DEBUG, "IO signal received"));    adjtimeout();         /* Adjust timeouts */    /* Yup, this is for real */    for (;;) {                    /* Read all available packets */        p = ppp_if[ppp_unit]->inpacket_buf;/* point to beggining of packet buffer */        len = read_packet(ppp_if[ppp_unit]->inpacket_buf);        if (len < 0)            break;        if (ppp_if[ppp_unit]->debug /*&& (debugflags & DBG_INPACKET)*/)            log_packet(p, len, "rcvd ");        if (len < DLLHEADERLEN) {            MAINDEBUG((LOG_DEBUG, "io(): Received short packet."));            break;        }        p += 2;                             /* Skip address and control */        GETSHORT(protocol, p);        len -= DLLHEADERLEN;        /*         * Toss all non-LCP packets unless LCP is OPEN.         */        if (protocol != LCP && ppp_if[ppp_unit]->lcp_fsm.state != OPENED) {            MAINDEBUG((LOG_DEBUG, "io(): Received non-LCP packet and LCP not open."));            break;        }        /*         * Upcall the proper protocol input routine.         */        for (i = 0; i < sizeof (prottbl) / sizeof (struct protent); i++)            if (prottbl[i].protocol == protocol) {                (*prottbl[i].input)(ppp_unit, p, len);                break;            }        if (i == sizeof (prottbl) / sizeof (struct protent)) {	    ppp_if[ppp_unit]->unknownProto++;            syslog(LOG_WARNING, "input: Unknown protocol (%x) received!",		   protocol);            lcp_sprotrej(ppp_unit, p - DLLHEADERLEN,		         len + DLLHEADERLEN);        }    }}/* * demuxprotrej - Demultiplex a Protocol-Reject. */voiddemuxprotrej    (    int unit,    u_short protocol    ){    int i;        /*     * Upcall the proper Protocol-Reject routine.     */    for (i = 0; i < sizeof (prottbl) / sizeof (struct protent); i++)        if (prottbl[i].protocol == protocol) {            (*prottbl[i].protrej)(unit);            return;        }    syslog(LOG_WARNING,	   "demuxprotrej: Unrecognized Protocol-Reject for protocol %d!",	   protocol);}/* * incdebug - Catch SIGUSR1 signal. * * Increment debug flag. *//*ARGSUSED*/static voidincdebug(sig)    int sig;{    syslog(LOG_INFO, "Debug turned ON, Level %d", ppp_if[ppp_unit]->debug);    ppp_if[ppp_unit]->debug++;}/* * nodebug - Catch SIGUSR2 signal. * * Turn off debugging. *//*ARGSUSED*/static voidnodebug(sig)    int sig;{    ppp_if[ppp_unit]->debug = 0;}#ifdef	notyet/* * device_script - run a program to connect or disconnect the * serial device. */intdevice_script(program, in, out)    char *program;    int in, out;{    int pid;    int status;    sigset_t mask;    sigemptyset(&mask);    sigaddset(&mask, SIGINT);    sigaddset(&mask, SIGHUP);    sigprocmask(SIG_BLOCK, &mask, &mask);    pid = fork();    if (pid < 0) {        syslog(LOG_ERR, "fork: %m");        die(1);    }    if (pid == 0) {        setreuid(getuid(), getuid());        setregid(getgid(), getgid());        sigprocmask(SIG_SETMASK, &mask, NULL);        dup2(in, 0);        dup2(out, 1);        execl("/bin/sh", "sh", "-c", program, (char *)0);        syslog(LOG_ERR, "could not exec /bin/sh: %m");        _exit(99);        /* NOTREACHED */    }    while (waitpid(pid, &status, 0) < 0) {        if (errno == EINTR)            continue;        syslog(LOG_ERR, "waiting for (dis)connection process: %m");        die(1);    }    sigprocmask(SIG_SETMASK, &mask, NULL);    return (status == 0 ? 0 : -1);}/* * run-program - execute a program with given arguments, * but don't wait for it. * If the program can't be executed, logs an error unless * must_exist is 0 and the program file doesn't exist. */intrun_program(prog, args, must_exist)    char *prog;    char **args;    int must_exist;{    int pid;    pid = fork();    if (pid == -1) {        syslog(LOG_ERR, "can't fork to run %s: %m", prog);        return -1;    }    if (pid == 0) {        execv(prog, args);        if (must_exist || errno != ENOENT)            syslog(LOG_WARNING, "can't execute %s: %m", prog);        _exit(-1);    }    MAINDEBUG((LOG_DEBUG, "Script %s started; pid = %d", prog, pid));    ++n_children;    return 0;}#endif	/* notyet *//* * log_packet - format a packet and log it. */char line[256];                 /* line to be logged accumulated here */char *linep;voidlog_packet(p, len, prefix)    u_char *p;    int len;    char *prefix;{    strcpy(line, prefix);    linep = line + strlen(line);    format_packet(p, len, pr_log, NULL);    if (linep != line)        syslog(LOG_DEBUG, "%s", line);}/* * format_packet - make a readable representation of a packet, * calling `printer(arg, format, ...)' to output it. */voidformat_packet(p, len, printer, arg)    u_char *p;    int len;    void (*printer) __ARGS((void *, char *, ...));    void *arg;{    int i, n;    u_short proto;    u_char x;    if (len >= DLLHEADERLEN && p[0] == ALLSTATIONS && p[1] == UI) {        p += 2;        GETSHORT(proto, p);        len -= DLLHEADERLEN;        for (i = 0; i < N_PROTO; ++i)            if (proto == prottbl[i].protocol)                break;        if (i < N_PROTO) {            printer(arg, "[%s", prottbl[i].name);            n = (*prottbl[i].printpkt)(p, len, printer, arg);            printer(arg, "]");            p += n;            len -= n;        } else {            printer(arg, "[proto=0x%x]", proto);        }    }    for (; len > 0; --len) {        GETCHAR(x, p);        printer(arg, " %.2x", x);    }}#ifdef __STDC__#include <stdarg.h>voidpr_log(void *arg, char *fmt, ...){    int n;    va_list pvar;    char buf[256];    va_start(pvar, fmt);    vsprintf(buf, fmt, pvar);    va_end(pvar);    n = strlen(buf);    if (linep + n + 1 > line + sizeof(line)) {        syslog(LOG_DEBUG, "%s", line);        linep = line;    }    strcpy(linep, buf);    linep += n;}#else /* __STDC__ */#include <varargs.h>voidpr_log(arg, fmt, va_alist)void *arg;char *fmt;va_dcl{    int n;    va_list pvar;    char buf[256];    va_start(pvar);    vsprintf(buf, fmt, pvar);    va_end(pvar);    n = strlen(buf);    if (linep + n + 1 > line + sizeof(line)) {        syslog(LOG_DEBUG, "%s", line);        linep = line;    }    strcpy(linep, buf);    linep += n;}#endif/* * print_string - print a readable representation of a string using * printer. */voidprint_string(p, len, printer, arg)    char *p;    int len;    void (*printer) __ARGS((void *, char *, ...));    void *arg;{    int c;    printer(arg, "\"");    for (; len > 0; --len) {        c = *p++;        if (' ' <= c && c <= '~')            printer(arg, "%c", c);        else            printer(arg, "\\%.3o", c);    }    printer(arg, "\"");}/* * novm - log an error message saying we ran out of memory, and die. */voidnovm(msg)    char *msg;{    syslog(LOG_ERR, "Memory exhausted allocating %s", msg);    die(ppp_unit, 1);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品1区2区| 久久se这里有精品| 精品欧美黑人一区二区三区| av一本久道久久综合久久鬼色| 亚洲综合视频网| 国产日韩欧美一区二区三区综合| 欧美日韩国产一级片| 国产成人av自拍| 免费成人你懂的| 一级精品视频在线观看宜春院| 国产日韩欧美制服另类| 日韩精品一区二区三区四区| 欧美日韩一级视频| 97超碰欧美中文字幕| 国产成人精品一区二| 国内一区二区视频| 免费成人深夜小野草| 天天操天天干天天综合网| 国产精品久久久久9999吃药| 床上的激情91.| 精品一区二区免费在线观看| 亚洲成人自拍一区| 亚洲色图清纯唯美| 中文字幕av免费专区久久| 久久中文字幕电影| 日韩午夜小视频| 欧美一级在线观看| 91精品国产综合久久福利| 日本道在线观看一区二区| av电影在线观看不卡| 成人激情校园春色| 成熟亚洲日本毛茸茸凸凹| 国产麻豆精品一区二区| 韩国一区二区三区| 韩国精品在线观看| 久久91精品久久久久久秒播| 天天综合色天天综合色h| 亚洲国产va精品久久久不卡综合| 一区二区三区欧美日| 亚洲欧美区自拍先锋| 亚洲另类在线一区| 亚洲一二三四在线| 亚洲午夜久久久| 日韩电影在线一区| 久久狠狠亚洲综合| 国产在线国偷精品产拍免费yy| 国产一区二区91| 风间由美一区二区三区在线观看 | 久久aⅴ国产欧美74aaa| 久久精品国产99| 韩国毛片一区二区三区| 国产一区二区在线免费观看| 国产高清精品在线| 成人av在线资源| 在线观看日韩精品| 欧美精品亚洲二区| 精品福利一二区| 日本一区二区动态图| |精品福利一区二区三区| 亚洲一二三四在线| 久久机这里只有精品| 成人爽a毛片一区二区免费| 99麻豆久久久国产精品免费优播| 色香蕉久久蜜桃| 欧美久久久久久久久中文字幕| 欧美成人伊人久久综合网| 久久久久一区二区三区四区| 国产精品久久福利| 一片黄亚洲嫩模| 精品一区二区三区免费播放| 成人小视频在线| 欧美日韩在线观看一区二区| 精品日韩欧美在线| 亚洲精品第1页| 久久精品国内一区二区三区| 岛国一区二区三区| 欧美视频你懂的| 亚洲美女视频在线观看| 日韩精品免费专区| 丁香婷婷综合色啪| 欧美日韩视频专区在线播放| 国产午夜精品理论片a级大结局| 亚洲精品国产成人久久av盗摄| 美女尤物国产一区| 91网站最新网址| 日韩免费观看高清完整版| 亚洲欧洲一区二区在线播放| 青青草精品视频| 91在线观看美女| 欧美成人vps| 亚洲午夜久久久久久久久电影院| 国产另类ts人妖一区二区| 欧美视频中文字幕| 欧美国产激情二区三区| 爽爽淫人综合网网站| 成人黄色大片在线观看| 日韩一级二级三级精品视频| 亚洲欧美日韩在线不卡| 激情欧美日韩一区二区| 欧美喷水一区二区| 亚洲人精品午夜| 国产一区二区在线观看免费| 欧美三级在线看| 亚洲色图一区二区| 国产不卡免费视频| 精品国内二区三区| 视频在线在亚洲| 色综合中文字幕| 国产午夜精品一区二区三区视频 | 99热精品一区二区| 久久久久99精品一区| 日韩高清电影一区| 91福利在线导航| 中文字幕永久在线不卡| 国产成人免费视频精品含羞草妖精| 91精品国产综合久久福利软件 | 日韩视频在线永久播放| 香蕉av福利精品导航| 色狠狠色狠狠综合| 亚洲欧洲在线观看av| 国产91精品精华液一区二区三区| 日韩精品一区国产麻豆| 日本欧美加勒比视频| 精品视频一区二区不卡| 亚洲精品成人悠悠色影视| www.色综合.com| 国产精品无圣光一区二区| 国产成人av一区二区三区在线| 精品精品国产高清a毛片牛牛 | 色婷婷av一区二区三区大白胸| 国产亚洲短视频| 国产精品一品视频| 久久色视频免费观看| 国产一区二区三区免费在线观看| 精品久久久久99| 久久99国产乱子伦精品免费| 日韩欧美在线综合网| 蜜臀久久99精品久久久久宅男| 在线不卡a资源高清| 五月天丁香久久| 欧美日本免费一区二区三区| 亚洲五月六月丁香激情| 欧美日产在线观看| 日韩和欧美一区二区| 国产精品美女一区二区| 国产成人综合在线| 国产精品国产馆在线真实露脸| 成人免费视频一区| **网站欧美大片在线观看| 色偷偷一区二区三区| 性做久久久久久| 日韩午夜av一区| 国产大片一区二区| 国产精品久久国产精麻豆99网站| 色综合天天天天做夜夜夜夜做| 一个色妞综合视频在线观看| 91精品在线免费观看| 久久精品国产澳门| 国产精品美日韩| 欧美影视一区在线| 久久精品99久久久| 国产精品少妇自拍| 欧美偷拍一区二区| 男女激情视频一区| 国产精品久久一卡二卡| 91成人网在线| 久久精品噜噜噜成人av农村| 中文子幕无线码一区tr| 欧美中文字幕一区| 久久99久久99| 亚洲天堂中文字幕| 91精品国产免费| 懂色av一区二区三区蜜臀| 一区二区三区不卡视频在线观看 | 国产精品一级在线| 一区二区三区蜜桃网| 日韩免费福利电影在线观看| 不卡av免费在线观看| 天天av天天翘天天综合网| 久久人人爽爽爽人久久久| 91看片淫黄大片一级在线观看| 日日欢夜夜爽一区| 国产精品拍天天在线| 欧美精品高清视频| youjizz国产精品| 久久激情综合网| 亚洲线精品一区二区三区| 久久嫩草精品久久久精品一| 欧美做爰猛烈大尺度电影无法无天| 麻豆91在线看| 亚洲午夜免费视频| 中文字幕精品一区 | **性色生活片久久毛片| 日韩欧美中文字幕精品| 在线亚洲一区二区| 成人天堂资源www在线| 久久97超碰国产精品超碰| 亚洲一区二区三区免费视频| 欧美经典一区二区三区| 日韩一级二级三级|