⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fsm.c

📁 VXWORKS源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
	break;    case STOPPED:	/* Negotiation started by our peer */	fsm_sconfreq(f, 0);		/* Send initial Configure-Request */	f->state = REQSENT;	break;    }    /*     * Pass the requested configuration options     * to protocol-specific code for checking.     */    if (f->callbacks->reqci){		/* Check CI */	reject_if_disagree = (f->nakloops >= f->maxnakloops);	code = (*f->callbacks->reqci)(f, inp, &len, reject_if_disagree);    } else if (len)	code = CONFREJ;			/* Reject all CI */    else        code = CONFACK;    /* send the Ack, Nak or Rej to the peer */    fsm_sdata(f, code, id, inp, len);    if (code == CONFACK) {	if (f->state == ACKRCVD) {	    PPP_UNTIMEOUT(fsm_timeout, (caddr_t) f);	/* Cancel timeout */	    f->state = OPENED;	    if (f->callbacks->up)		(*f->callbacks->up)(f);	/* Inform upper layers */	} else	    f->state = ACKSENT;	f->nakloops = 0;    } else {	/* we sent CONFACK or CONFREJ */	if (f->state != ACKRCVD)	    f->state = REQSENT;	if( code == CONFNAK )	    ++f->nakloops;    }}/* * fsm_rconfack - Receive Configure-Ack. */static voidfsm_rconfack(f, id, inp, len)    fsm *f;    u_char id;    u_char *inp;    int len;{    FSMDEBUG((LOG_INFO, "fsm_rconfack(%s): Rcvd id %d.",              PROTO_NAME(f), id));    if (id != f->reqid)		/* Expected id? */	return;			/* Nope, toss... */    if( !(f->callbacks->ackci? (*f->callbacks->ackci)(f, inp, len): (len == 0)) ){	/* Ack is bad - ignore it */	FSMDEBUG((LOG_INFO, "%s: received bad Ack (length %d)",                  PROTO_NAME(f), len));	return;    }    f->reqid = -1;    switch (f->state) {    case CLOSED:    case STOPPED:	fsm_sdata(f, TERMACK, id, NULL, 0);	break;    case REQSENT:	f->state = ACKRCVD;	f->retransmits = f->maxconfreqtransmits;	break;    case ACKRCVD:	/* Huh? an extra Ack? oh well... */	fsm_sconfreq(f, 0);	f->state = REQSENT;	break;    case ACKSENT:	PPP_UNTIMEOUT(fsm_timeout, (caddr_t) f);	/* Cancel timeout */	f->state = OPENED;	f->retransmits = f->maxconfreqtransmits;	if (f->callbacks->up)	    (*f->callbacks->up)(f);	/* Inform upper layers */	break;    case OPENED:	/* Go down and restart negotiation */	if (f->callbacks->down)	    (*f->callbacks->down)(f);	/* Inform upper layers */	fsm_sconfreq(f, 0);		/* Send initial Configure-Request */	f->state = REQSENT;	break;    }}/* * fsm_rconfnakrej - Receive Configure-Nak or Configure-Reject. */static voidfsm_rconfnakrej(f, code, id, inp, len)    fsm *f;    int code, id;    u_char *inp;    int len;{    int (*proc)();    FSMDEBUG((LOG_INFO, "fsm_rconfnakrej(%s): Rcvd id %d.",              PROTO_NAME(f), id));    if (id != f->reqid)		/* Expected id? */	return;			/* Nope, toss... */    proc = (code == CONFNAK)? f->callbacks->nakci: f->callbacks->rejci;    if( !proc || !proc(f, inp, len) ){	/* Nak/reject is bad - ignore it */	FSMDEBUG((LOG_INFO, "%s: received bad %s (length %d)",		  PROTO_NAME(f), (code==CONFNAK? "Nak": "reject"), len));	return;    }    f->reqid = -1;    switch (f->state) {    case CLOSED:    case STOPPED:	fsm_sdata(f, TERMACK, id, NULL, 0);	break;    case REQSENT:    case ACKSENT:	/* They didn't agree to what we wanted - try another request */	PPP_UNTIMEOUT(fsm_timeout, (caddr_t) f);	/* Cancel timeout */	fsm_sconfreq(f, 0);		/* Send Configure-Request */	break;    case ACKRCVD:	/* Got a Nak/reject when we had already had an Ack?? oh well... */	fsm_sconfreq(f, 0);	f->state = REQSENT;	break;    case OPENED:	/* Go down and restart negotiation */	if (f->callbacks->down)	    (*f->callbacks->down)(f);	/* Inform upper layers */	fsm_sconfreq(f, 0);		/* Send initial Configure-Request */	f->state = REQSENT;	break;    }}/* * fsm_rtermreq - Receive Terminate-Req. */static voidfsm_rtermreq(f, id)    fsm *f;    int id;{    FSMDEBUG((LOG_INFO, "fsm_rtermreq(%s): Rcvd id %d.",              PROTO_NAME(f), id));    switch (f->state) {    case ACKRCVD:    case ACKSENT:	f->state = REQSENT;		/* Start over but keep trying */	break;    case OPENED:	syslog(LOG_INFO, "%s terminated at peer's request", PROTO_NAME(f));	if (f->callbacks->down)	    (*f->callbacks->down)(f);	/* Inform upper layers */	f->retransmits = 0;	f->state = STOPPING;	PPP_TIMEOUT(fsm_timeout, (caddr_t) f, f->timeouttime);	break;    }    fsm_sdata(f, TERMACK, id, NULL, 0);}/* * fsm_rtermack - Receive Terminate-Ack. */static voidfsm_rtermack(f)    fsm *f;{    FSMDEBUG((LOG_INFO, "fsm_rtermack(%s).", PROTO_NAME(f)));    switch (f->state) {    case CLOSING:	f->state = CLOSED;	if( f->callbacks->finished )	    (*f->callbacks->finished)(f);	break;    case STOPPING:	f->state = STOPPED;	if( f->callbacks->finished )	    (*f->callbacks->finished)(f);	break;    case ACKRCVD:	f->state = REQSENT;	break;    case OPENED:	if (f->callbacks->down)	    (*f->callbacks->down)(f);	/* Inform upper layers */	fsm_sconfreq(f, 0);	break;    }}/* * fsm_rcoderej - Receive an Code-Reject. */static voidfsm_rcoderej(f, inp, len)    fsm *f;    u_char *inp;    int len;{    u_char code, id;    FSMDEBUG((LOG_INFO, "fsm_rcoderej(%s).", PROTO_NAME(f)));    if (len < HEADERLEN) {	FSMDEBUG((LOG_INFO, "fsm_rcoderej: Rcvd short Code-Reject packet!"));	return;    }    GETCHAR(code, inp);    GETCHAR(id, inp);    syslog(LOG_WARNING, "%s: Rcvd Code-Reject for code %d, id %d",           PROTO_NAME(f), code, id);    if( f->state == ACKRCVD )	f->state = REQSENT;}/* * fsm_protreject - Peer doesn't speak this protocol. * * Treat this as a catastrophic error (RXJ-). */voidfsm_protreject(f)    fsm *f;{    switch( f->state ){    case CLOSING:	PPP_UNTIMEOUT(fsm_timeout, (caddr_t) f);	/* Cancel timeout */	/* fall through */    case CLOSED:	f->state = CLOSED;	if( f->callbacks->finished )	    (*f->callbacks->finished)(f);	break;    case STOPPING:    case REQSENT:    case ACKRCVD:    case ACKSENT:	PPP_UNTIMEOUT(fsm_timeout, (caddr_t) f);	/* Cancel timeout */	/* fall through */    case STOPPED:	f->state = STOPPED;	if( f->callbacks->finished )	    (*f->callbacks->finished)(f);	break;    case OPENED:	if( f->callbacks->down )	    (*f->callbacks->down)(f);	/* Init restart counter, send Terminate-Request */	f->retransmits = f->maxtermtransmits;	fsm_sdata(f, TERMREQ, f->reqid = ++f->id, NULL, 0);	PPP_TIMEOUT(fsm_timeout, (caddr_t) f, f->timeouttime);	--f->retransmits;	f->state = STOPPING;	break;    default:	FSMDEBUG((LOG_INFO, "%s: Protocol-reject event in state %d!",		  PROTO_NAME(f), f->state));    }}extern struct ppp_softc *ppp_softc[ ];/* * fsm_sconfreq - Send a Configure-Request. */static voidfsm_sconfreq(f, retransmit)    fsm *f;    int retransmit;{    u_char *outp;    int cilen;    register struct ppp_softc *sc = ppp_softc[f->unit];    if( f->state != REQSENT && f->state != ACKRCVD && f->state != ACKSENT ){	/* Not currently negotiating - reset options */	if( f->callbacks->resetci )	    (*f->callbacks->resetci)(f);	f->nakloops = 0;    }    if( !retransmit ){	/* New request - reset retransmission counter, use new ID */	f->retransmits = f->maxconfreqtransmits;	f->reqid = ++f->id;    }    /* Write the string "CLIENT" to the remote peer */    if (((ppp_if[ppp_unit]->lcp_wantoptions.passive) == 1) || 	 (ppp_if[ppp_unit]->lcp_wantoptions.silent == 1))	{	char buf[7];	strncpy(buf,"CLIENT",strlen("CLIENT"));	output(f->unit, buf, strlen("CLIENT"));	taskDelay(sysClkRateGet());	}    /*     * Make up the request packet     */    outp = ppp_if[f->unit]->outpacket_buf + DLLHEADERLEN + HEADERLEN;    if( f->callbacks->cilen && f->callbacks->addci ){	cilen = (*f->callbacks->cilen)(f);	if( cilen > ppp_if[f->unit]->peer_mru - HEADERLEN )	    cilen = ppp_if[f->unit]->peer_mru - HEADERLEN;	if (f->callbacks->addci)	    (*f->callbacks->addci)(f, outp, &cilen);    } else	cilen = 0;    /* send the request to our peer */    fsm_sdata(f, CONFREQ, f->reqid, outp, cilen);    /* start the retransmit timer */    --f->retransmits;    PPP_TIMEOUT(fsm_timeout, (caddr_t) f, f->timeouttime);    FSMDEBUG((LOG_INFO, "%s: sending Configure-Request, id %d",	      PROTO_NAME(f), f->reqid));}/* * fsm_sdata - Send some data. * * Used for all packets sent to our peer by this module. */voidfsm_sdata(f, code, id, data, datalen)    fsm *f;    u_char code, id;    u_char *data;    int datalen;{    u_char *outp;    int outlen;    /* Adjust length to be smaller than MTU */    outp = ppp_if[f->unit]->outpacket_buf;    if (datalen > ppp_if[f->unit]->peer_mru - HEADERLEN)	datalen = ppp_if[f->unit]->peer_mru - HEADERLEN;    if (datalen && data != outp + DLLHEADERLEN + HEADERLEN)	BCOPY((char *)data, (char *)(outp + DLLHEADERLEN + HEADERLEN), datalen);    outlen = datalen + HEADERLEN;    MAKEHEADER(outp, f->protocol);    PUTCHAR(code, outp);    PUTCHAR(id, outp);    PUTSHORT(outlen, outp);    output(f->unit, ppp_if[f->unit]->outpacket_buf, outlen + DLLHEADERLEN);    FSMDEBUG((LOG_INFO, "fsm_sdata(%s): Sent code %d, id %d.",	      PROTO_NAME(f), code, id));}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -