[Users] provisional_reply_timer

Christian Schlatter cs at unc.edu
Tue Dec 19 16:40:37 CET 2006


Klaus Darilion wrote:
> Hi Christian!
> 
> Is the behavior identically for all transactions or is there a 
> difference between INVITE and other transactions?

 >> - INVITE transactions: FRT initially equals fr_timer and gets set to
 >> fr_inv_timer after receiving first provisional response

This is only true for INVITE transactions, all other transactions only 
use the fr_timer. This makes sense since INVITE transactions normally 
involve user interaction (ringing).

The code responsible for that is in /modules/tm/t_reply.c, 
reply_received(..) function:

/* update FR/RETR timers on provisional replies */
if (msg_status < 200 && (restart_fr_on_each_reply ||
    ((last_uac_status<msg_status) &&
    ((msg_status >= 180) || (last_uac_status == 0)))
     ) ) { /* provisional now */
                 if (is_invite(t)) {
                         /* invite: change FR to longer FR_INV, do not
                          * attempt to restart retransmission any more
                          */
                         backup_list = set_avp_list(&t->user_avps);
                         if (!fr_inv_avp2timer(&timer)) {
                                 DBG("DEBUG:tm:reply_received: 
FR_INV_TIMER = %d\n", timer);
                                 set_timer(&uac->request.fr_timer,
                                         FR_INV_TIMER_LIST, &timer);
                                 t->flags |= T_NOISY_CTIMER_FLAG;
                         } else {
                                 set_timer(& uac->request.fr_timer, 
FR_INV_TIMER_LIST, 0);
                         }
                         set_avp_list(backup_list);
                 } else {
                         /* non-invite: restart retransmissions (slow 
now) */
                         uac->request.retr_list = RT_T2;
                         set_timer(&uac->request.retr_timer, RT_T2, 0);
                 }
         } /* provisional replies */


- Christian

> 
> regards
> klaus
> 
> Christian Schlatter wrote:
>> Ovidiu Sas wrote:
>>> Hi Klaus,
>>>
>>> You can use the fr_timer from the tm module:
>>> http://openser.org/docs/modules/1.1.x/tm.html#AEN108
>>>
>>> If you don't get any reply from the far end, this timer will fire.
>>
>> I recently had a look at the timer related source code and that is 
>> what I wrote down:
>>
>> - Each SIP transaction has a final response timer (FRT)
>>
>> - SIP transactions fail (failure_route, status 408) when FRT fires
>>
>> - TM module exposes final response timers (FRT) fr_timer and 
>> fr_inv_timer (can be set using AVP)
>>
>> - INVITE transactions: FRT initially equals fr_timer and gets set to 
>> fr_inv_timer after receiving first provisional response
>>
>> - setting fr_timer to a low value (e.g. 3s) allows for fast INVITE 
>> failover
>>
>> So I'm setting fr_timer to a low value for local INVITE transactions. 
>> Local here means sessions between endpoints from our network domain. 
>> Something along the lines:
>>
>> route[0] {
>>     if (method==“INVITE”) {
>>         # set fr_timer to 3 seconds
>>         avp_write("i:3", "$avp(fr_timer)");
>>         # call FAILURE_DEFAULT_RELAY routing block on transaction failure
>>         t_on_failure("FAILURE_DEFAULT_RELAY");
>>         t_relay();
>>         exit;       }
>> }
>> failure_route[FAILURE_DEFAULT_RELAY] {
>>     # status 408 ? transaction timed out
>>     if (t_check_status("408")) {
>>         # try next target
>>         if (ds_next_domain()) {
>>             t_relay();
>>         }
>>     }
>> }
>>
>>
>> - Christian
>>
>>>
>>>
>>> Regards,
>>> Ovidiu Sas
>>>
>>> On 12/18/06, Klaus Darilion <klaus.mailinglists at pernau.at> wrote:
>>>> Hi!
>>>>
>>>> i wonder if there is a timer which controls the timeout for provisional
>>>> replies.
>>>>
>>>> E.g. I want to cancel an INVITE and retry another gateway if the 
>>>> gateway
>>>> does not respond with 100 (or 180) in a certain time.
>>>>
>>>> regards
>>>> klaus
>>>>
>>>> -- 
>>>> Klaus Darilion
>>>> nic.at
>>>>
>>>>
>>>> _______________________________________________
>>>> Users mailing list
>>>> Users at openser.org
>>>> http://openser.org/cgi-bin/mailman/listinfo/users
>>>>
>>>
>>> _______________________________________________
>>> Users mailing list
>>> Users at openser.org
>>> http://openser.org/cgi-bin/mailman/listinfo/users
>>
>>
>> ------------------------------------------------------------------------
>>
>> _______________________________________________
>> Users mailing list
>> Users at openser.org
>> http://openser.org/cgi-bin/mailman/listinfo/users
> 
> 

-------------- next part --------------
A non-text attachment was scrubbed...
Name: smime.p7s
Type: application/x-pkcs7-signature
Size: 1951 bytes
Desc: S/MIME Cryptographic Signature
Url : http://lists.kamailio.org/pipermail/users/attachments/20061219/2153cd34/attachment.bin 


More information about the Users mailing list