[asterisk-bugs] [Asterisk 0009492]: [patch] Asterisk sends wrong CSEQ in CANCEL if using INFO dtmf
noreply at bugs.digium.com
noreply at bugs.digium.com
Wed Nov 28 15:36:48 CST 2007
A NOTE has been added to this issue.
======================================================================
http://bugs.digium.com/view.php?id=9492
======================================================================
Reported By: kryptolus
Assigned To:
======================================================================
Project: Asterisk
Issue ID: 9492
Category: Channels/chan_sip/Interoperability
Reproducibility: always
Severity: major
Priority: normal
Status: ready for testing
Asterisk Version: 1.2.17
SVN Branch (only for SVN checkouts, not tarball releases): N/A
SVN Revision (number only!):
Disclaimer on File?: No
Request Review:
======================================================================
Date Submitted: 04-06-2007 09:40 CDT
Last Modified: 11-28-2007 15:36 CST
======================================================================
Summary: [patch] Asterisk sends wrong CSEQ in CANCEL if using
INFO dtmf
Description:
SIP RFC states that a CANCEL to an INVITE must have the same CSEQ as the
INVITE. When asterisk sends INFO packets, it increments the ocseq counter.
When it sends the CANCEL, the cseq is not that of the INVITE but of the
last INFO.
(Please don't ask me for logs... they're not going to say anything more
than what I just said above. )
This is a big problem as the other party thinks the call is still going
(it rejects the improper CANCEL).
======================================================================
Relationships ID Summary
----------------------------------------------------------------------
related to 0005215 [patch] Provisional responses to INVITE...
has duplicate 0009408 error response on INFO kills call
======================================================================
----------------------------------------------------------------------
andrewgray - 11-28-07 15:36
----------------------------------------------------------------------
This is for version 1.4.5, but for 1.4.14 I put in the follow patch on line
15505 of chan_sip.c, then remade asterisk:
if ((p->icseq && (p->icseq > seqno)) && !(!ast_test_flag(&p->flags[0],
SIP_OUTGOING) && (req->method == SIP_ACK) &&
p->pendinginvite &&
(p->pendinginvite == seqno))) {
if (option_debug)
ast_log(LOG_DEBUG, "Ignoring too old SIP packet packet %d
(expecting >= %d)\n", seqno, p->icseq);
if (req->method != SIP_ACK)
transmit_response(p, "503 Server error", req); /* We must respond
according to RFC 3261 sec 12.2 */
return -1;
} else if (p->icseq && p->icseq == seqno && req->method != SIP_ACK &&
(p->method != SIP_CANCEL || ast_test_flag(&p->flags[0],
SIP_ALREADYGONE))) {
Issue History
Date Modified Username Field Change
======================================================================
11-28-07 15:36 andrewgray Note Added: 0074517
======================================================================
More information about the asterisk-bugs
mailing list