[asterisk-bugs] [Asterisk 0011737]: Cancel sending not conform to SIP RFC 3261

noreply at bugs.digium.com noreply at bugs.digium.com
Fri Jan 11 05:24:12 CST 2008


A NOTE has been added to this issue. 
====================================================================== 
http://bugs.digium.com/view.php?id=11737 
====================================================================== 
Reported By:                gasparz
Assigned To:                
====================================================================== 
Project:                    Asterisk
Issue ID:                   11737
Category:                   Channels/chan_sip/General
Reproducibility:            always
Severity:                   minor
Priority:                   normal
Status:                     new
Asterisk Version:           1.4.13 
SVN Branch (only for SVN checkouts, not tarball releases): N/A  
SVN Revision (number only!):  
Disclaimer on File?:        N/A 
Request Review:              
====================================================================== 
Date Submitted:             01-11-2008 03:58 CST
Last Modified:              01-11-2008 05:24 CST
====================================================================== 
Summary:                    Cancel sending not conform to SIP RFC 3261
Description: 
See the following call flow.

Src ip is asterisk
Date              Src IP Dst IP Packet type 
2008-01-10 10:57:24 ip1 ip2 INVITE sip:number at ip2 SIP/2.0. 
2008-01-10 10:57:24 ip2 ip1 SIP/2.0 100 Trying. 
2008-01-10 10:57:26 ip2 ip1 SIP/2.0 180 Ringing. 
2008-01-10 10:57:49 ip2 ip1 SIP/2.0 180 Ringing. 
2008-01-10 10:57:49 ip1 ip2 CANCEL sip:number at ip2 SIP/2.0. 
2008-01-10 10:57:49 ip2 ip1 SIP/2.0 200 OK. (CSeq: 102 INVITE.!!!!)
2008-01-10 10:57:49 ip1 ip2 ACK sip:number1 at ip2; SIP/2.0 
2008-01-10 10:57:49 ip1 ip2 BYE sip:number1 at ip2; SIP/2.0 
2008-01-10 10:57:49 ip2 ip1 SIP/2.0 481 Call/Transaction Does Not Exist.
(CSeq: 102 CANCEL.!!!)
2008-01-10 10:57:49 ip2 ip1 SIP/2.0 200 OK. (CSeq: 103 BYE.)
2008-01-10 10:57:50 ip1 ip2 CANCEL sip:number at ip2 SIP/2.0. 
2008-01-10 10:57:50 ip2 ip1 SIP/2.0 200 OK. (CSeq: 102 CANCEL.)
2008-01-10 10:57:51 ip1 ip2 CANCEL sip:number at ip2 SIP/2.0. 
2008-01-10 10:57:51 ip2 ip1 SIP/2.0 200 OK. CSeq: 102 CANCEL.
2008-01-10 10:57:53 ip1 ip2 CANCEL sip:number at ip2 SIP/2.0. 
2008-01-10 10:57:53 ip2 ip1 SIP/2.0 200 OK. CSeq: 102 CANCEL.
2008-01-10 10:57:57 ip1 ip2 CANCEL sip:number at ip2 SIP/2.0. 
2008-01-10 10:57:57 ip2 ip1 SIP/2.0 200 OK. CSeq: 102 CANCEL.
2008-01-10 10:58:01 ip1 ip2 CANCEL sip:number at ip2 SIP/2.0. 
2008-01-10 10:58:01 ip2 ip1 SIP/2.0 200 OK. CSeq: 102 CANCEL.
2008-01-10 10:58:05 ip1 ip2 CANCEL sip:number at ip2 SIP/2.0. 
2008-01-10 10:58:05 ip2 ip1 SIP/2.0 200 OK. CSeq: 102 CANCEL.

so we want to cancel after we received the 180 ringing from ip2. But while
we send the first cancel (sending this cancel is correct) the ip2 accepts
the call (200 ok). Now we have a strange situation. Asterisk confirms the
200 ok for the invite with an ACK, then imidiatly sends a BYE request. The
ip2 accepts the bye with a 200 ok, great.

Now the strange things:
ip2 sends 481 Call/Transaction Does Not Exist. for the cancel request. I
don't know how good is this message, but this is not the issue.

After the ip2 sends the 200 ok for the bye we resend the cancel. I
understand asterisk sees no 200 ok for the cancel and it resends it after
exactly 1 second, a normal packet retransmision, BUT it shouldn't. In this
case the 200 ok that accepts the invite, or at least the 200 ok for the bye
should block the sending, retransmision of the cancel packet.

Because: (sip RFC 3261)
page 42:
"Once the CANCEL is constructed, the client SHOULD check whether it has
received any response (provisional
or final) for the request being cancelled (herein referred to as the
“original request”).
If no provisional response has been received, the CANCEL request MUST NOT
be sent; rather, the client
MUST wait for the arrival of a provisional response before sending the
request. If the original request has
generated a final response, the CANCEL SHOULD NOT be sent, as it is an
effective no-op, since CANCEL
has no effect on requests that have already generated a final response."

But anyway after the second cancel we receive a 200 ok message
acknowlegeing the cancel so the cancel retransmition should be stoped at
least at this point.

But no the rettransmission continues another 5 times (I think until it
reaches max_retrans for the packet).

====================================================================== 

---------------------------------------------------------------------- 
 flefoll - 01-11-08 05:24  
---------------------------------------------------------------------- 
As far as CANCEL repetition is concerned, this is one more consequence of
code in chan_sip.c sip_handle_request() (better renamed handle_incoming()
in SVN trunk) that voluntarily ignores responses where CSeq is not the
highest sent CSeq. In your case, Asterisk has sent a BYE after the CANCEL,
thus it will ignore all responses except for the BYE. Consequence :
retransmission mechanism keeps running for "unanswered :-(" CANCEL
request.

A number of patches have been proposed by different people, probably none
of them ideal, probably most of them preferable to current situation
(imho).
http://bugs.digium.com/view.php?id=11231
http://bugs.digium.com/view.php?id=10946
http://bugs.digium.com/view.php?id=10915
http://bugs.digium.com/view.php?id=10052
http://bugs.digium.com/view.php?id=9567 

Issue History 
Date Modified   Username       Field                    Change               
====================================================================== 
01-11-08 05:24  flefoll        Note Added: 0076704                          
======================================================================




More information about the asterisk-bugs mailing list