wtp_init_states.def

来自「mms client」· DEF 代码 · 共 408 行

DEF
408
字号
/* * wtp_init_state.h: Macro calls for implementing wtp initiator state tables * See documentation for guidance how to use and update these. * * Only classes 0 and 1 are implemented. State NULL is called INITIATOR_NULL_ * STATE. 1 in the action field means that action is unconditional. * * Class 0 service is here a stateless invoke message (used for disconnection * or unconfirmed push). * * Basic class 1 transaction, without timers, is following: *               - initiator sends an invoke message to the responder *               - responder acknowledges it, with an pdu with tid verification *                 off (if it is on, we have a tid verification transaction,  *                 see below). * * Retransmission until acknowledgement is implemented using timers and  * retransmission counters. When the initiator sends an invoke it starts a  * timer. When it expires, it resends the packet (either ack or invoke), until * counter reaches the maximum value. Then the transaction is aborted. * * If user acknowledgement is on, timers have different values. * * When the initiator aborts the transaction, it sends an abort pdu. When the * responder does it, the initiator wtp user is indicated. * * Tid verification in the initiator means answering the question posed by the * responder: "Have you an outstanding transaction having this tid". If we do * not have it, we have already, before feeding the event into the state  * machine, sended an abort with reason INVALIDTID. So here we answer to  an * ack pdu with tidve-flag set with an ack pdu with tidok-flag set. See WTP * 5.6, table 2; WTP 8.9; WTP 9.3.4.1. * * By Aarno Syv鋘en for Wapit Ltd.  */INIT_STATE_NAME(INITIATOR_NULL_STATE)INIT_STATE_NAME(INITIATOR_RESULT_WAIT)INIT_STATE_NAME(INITIATOR_RESULT_RESP_WAIT)INIT_STATE_NAME(INITIATOR_WAIT_TIMEOUT)ROW(INITIATOR_NULL_STATE,    TR_Invoke_Req,    event->u.TR_Invoke_Req.tcl == 2,    {     WAPEvent *invoke;/* * A special counter is used for storing value used (1) for tidnew flag when * restarting (See WTP 8.8.3.2) */     init_machine->tidnew = tidnew;          wap_event_destroy(init_machine->invoke);     init_machine->rid = 0;     init_machine->rcr = 0;             if (init_machine->sar != NULL) {         /* SAR - needs to be segmented */         begin_sar_invoke(init_machine, event);     }     else {         /* non SAR */         invoke = wtp_pack_invoke(init_machine, event);         init_machine->invoke = wap_event_duplicate(invoke);         dispatch_to_wdp(invoke);     }     init_machine->rid = 1;/* * Turn the tidnew-flag off if it was on. (This can happen when tid was  * wrapped or when we are restarting, see WTP 8.8.3.2)  */          if (init_machine->tidnew) {         init_machine->tidnew = 0;         tidnew = 0;     }     init_machine->u_ack = event->u.TR_Invoke_Req.up_flag;     init_machine->rcr = 0;     start_initiator_timer_R(init_machine);    },     INITIATOR_RESULT_WAIT)ROW(INITIATOR_NULL_STATE,    TR_Invoke_Req,    event->u.TR_Invoke_Req.tcl == 1,    {     WAPEvent *invoke;/* * A special counter is used for storing value used (1) for tidnew flag when * restarting (See WTP 8.8.3.2) */     init_machine->tidnew = tidnew;          wap_event_destroy(init_machine->invoke);     init_machine->rid = 0;     init_machine->rcr = 0;             invoke = wtp_pack_invoke(init_machine, event);     init_machine->invoke = wap_event_duplicate(invoke);     dispatch_to_wdp(invoke);     init_machine->rid = 1;/* * Turn the tidnew-flag off if it was on. (This can happen when tid was  * wrapped or when we are restarting, see WTP 8.8.3.2)  */          if (init_machine->tidnew) {         init_machine->tidnew = 0;         tidnew = 0;     }     init_machine->u_ack = event->u.TR_Invoke_Req.up_flag;     init_machine->rcr = 0;     start_initiator_timer_R(init_machine);    },     INITIATOR_RESULT_WAIT)/* * No need to turn tidnew flag when sending class 0 message; tid validation is * not invoked in this case. */ROW(INITIATOR_NULL_STATE,    TR_Invoke_Req,    event->u.TR_Invoke_Req.tcl == 0,    {     WAPEvent *invoke;     wap_event_destroy(init_machine->invoke);     invoke = wtp_pack_invoke(init_machine, event);     init_machine->invoke = wap_event_duplicate(invoke);     dispatch_to_wdp(invoke);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_WAIT,    TR_Abort_Req,     1,    {     send_abort(init_machine, USER, event->u.TR_Abort_Req.abort_reason);    },    INITIATOR_NULL_STATE)/* can't figure out this holdon stuff *//* non-SAR */ROW(INITIATOR_RESULT_WAIT,    RcvAck,    init_machine->tcl == 2 && init_machine->sar == NULL,    {        stop_initiator_timer(init_machine->timer);        wsp_event = create_tr_invoke_cnf(init_machine);        dispatch_to_wsp(wsp_event);         },    INITIATOR_RESULT_WAIT)/* SAR */ROW(INITIATOR_RESULT_WAIT,    RcvAck,    init_machine->tcl == 2 && init_machine->sar != NULL,    {        continue_sar_invoke(init_machine, event);         },    INITIATOR_RESULT_WAIT)ROW(INITIATOR_RESULT_WAIT,    RcvAck,    event->u.RcvAck.tid_ok == 0 && init_machine->tcl == 1,    {     stop_initiator_timer(init_machine->timer);     wsp_event = create_tr_invoke_cnf(init_machine);     dispatch_to_wsp(wsp_event);         },    INITIATOR_NULL_STATE)/* * This is a positive answer to a tid verification (negative one being  * already sent by init_machine_find_or_create). */ROW(INITIATOR_RESULT_WAIT,    RcvAck,    event->u.RcvAck.tid_ok == 1 && init_machine->rcr < MAX_RCR,    {     send_ack(init_machine, TID_VERIFICATION, init_machine->rid);     init_machine->tidok_sent = 1;     ++init_machine->rcr;     start_initiator_timer_R(init_machine);    },    INITIATOR_RESULT_WAIT)/* * RCR must not be greater than RCR_MAX. One of corrections from MOT_WTP_CR_01. */ ROW(INITIATOR_RESULT_WAIT,   RcvAck,   event->u.RcvAck.tid_ok,   { },   INITIATOR_RESULT_WAIT)ROW(INITIATOR_RESULT_WAIT,    RcvAbort,    1,    {     wsp_event = create_tr_abort_ind(init_machine, event->u.RcvAbort.abort_reason);     dispatch_to_wsp(wsp_event);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_WAIT,    RcvErrorPDU,    1,    {     send_abort(init_machine, USER, PROTOERR);     wsp_event = create_tr_abort_ind(init_machine, PROTOERR);     dispatch_to_wsp(wsp_event);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_WAIT,    TimerTO_R,    init_machine->rcr < MAX_RCR && !init_machine->tidok_sent,    {      WAPEvent *resend;      ++init_machine->rcr;     start_initiator_timer_R(init_machine);     resend = wap_event_duplicate(init_machine->invoke);     wtp_pack_set_rid(resend, init_machine->rid);     dispatch_to_wdp(resend);    },    INITIATOR_RESULT_WAIT)ROW(INITIATOR_RESULT_WAIT,    TimerTO_R,    init_machine->rcr < MAX_RCR && init_machine->tidok_sent,    {     ++init_machine->rcr;     start_initiator_timer_R(init_machine);     send_ack(init_machine, TID_VERIFICATION, init_machine->tidok_sent);    },    INITIATOR_RESULT_WAIT)ROW(INITIATOR_RESULT_WAIT,    TimerTO_R,    init_machine->rcr == MAX_RCR,     {     wsp_event = create_tr_abort_ind(init_machine, NORESPONSE);     dispatch_to_wsp(wsp_event);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_WAIT,    RcvResult,    1,     {        WAPEvent *e;        /* stop timer */        stop_initiator_timer(init_machine->timer);                /* generate tr-result.ind */        e = wap_event_create(TR_Result_Ind);        e->u.TR_Result_Ind.user_data = event->u.RcvResult.user_data;        /* revisit - MJ don't know if this mapping is corect */        e->u.TR_Result_Ind.handle = event->u.RcvResult.tid;        e->u.TR_Result_Ind.addr_tuple = wap_addr_tuple_duplicate(init_machine->addr_tuple);        dispatch_to_wsp(e);        /* start timer, A */        start_initiator_timer_A(init_machine);        init_machine->aec = 0;    },    INITIATOR_RESULT_RESP_WAIT)ROW(INITIATOR_RESULT_RESP_WAIT,    TR_Result_Res,    1,     {        send_ack(init_machine, ACKNOWLEDGEMENT, 0);        start_initiator_timer_W(init_machine);    },    INITIATOR_WAIT_TIMEOUT)ROW(INITIATOR_RESULT_RESP_WAIT,    RcvAbort,    1,     {        wsp_event = create_tr_abort_ind(init_machine, event->u.RcvAbort.abort_reason);        dispatch_to_wsp(wsp_event);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_RESP_WAIT,    TR_Abort_Req,    1,     {        send_abort(init_machine, USER, event->u.TR_Abort_Req.abort_reason);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_RESP_WAIT,    RcvErrorPDU,    1,     {        send_abort(init_machine, USER, PROTOERR);        wsp_event = create_tr_abort_ind(init_machine, PROTOERR);        dispatch_to_wsp(wsp_event);            },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_RESP_WAIT,    RcvResult,    1,     {        /* Ignore */    },    INITIATOR_RESULT_RESP_WAIT)ROW(INITIATOR_RESULT_RESP_WAIT,    TimerTO_A,    init_machine->aec < AEC_MAX,    {        ++init_machine->aec;        start_initiator_timer_A(init_machine);    },    INITIATOR_RESULT_RESP_WAIT)ROW(INITIATOR_RESULT_RESP_WAIT,    TimerTO_A,    init_machine->aec == AEC_MAX,    {        send_abort(init_machine, USER, NORESPONSE);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_RESULT_RESP_WAIT,    TimerTO_A,    init_machine->u_ack == 0,    {        send_ack(init_machine, ACKNOWLEDGEMENT, 0);        start_initiator_timer_W(init_machine);    },    INITIATOR_WAIT_TIMEOUT)ROW(INITIATOR_WAIT_TIMEOUT,    RcvResult,    init_machine->rid == 0,    {        /* ignore */    },    INITIATOR_WAIT_TIMEOUT)ROW(INITIATOR_WAIT_TIMEOUT,    RcvResult,    init_machine->rid == 1,    {        send_ack(init_machine, ACKNOWLEDGEMENT, 0);    },    INITIATOR_WAIT_TIMEOUT)ROW(INITIATOR_WAIT_TIMEOUT,    RcvAbort,    1,    {        wsp_event = create_tr_abort_ind(init_machine, event->u.RcvAbort.abort_reason);        dispatch_to_wsp(wsp_event);    },    INITIATOR_NULL_STATE)ROW(INITIATOR_WAIT_TIMEOUT,    RcvErrorPDU,    1,    {        send_abort(init_machine, USER, PROTOERR);        wsp_event = create_tr_abort_ind(init_machine, PROTOERR);        dispatch_to_wsp(wsp_event);            },    INITIATOR_NULL_STATE)ROW(INITIATOR_WAIT_TIMEOUT,    TimerTO_W,    1,    {        /* clear transaction */    },    INITIATOR_NULL_STATE)ROW(INITIATOR_WAIT_TIMEOUT,    TR_Abort_Req,    1,    {        send_abort(init_machine, USER, event->u.TR_Abort_Req.abort_reason);    },    INITIATOR_NULL_STATE)#undef ROW#undef INIT_STATE_NAME

⌨️ 快捷键说明

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