diff --git a/libs/sofia-sip/.update b/libs/sofia-sip/.update index e2ccbb5955..d53bbb6f02 100644 --- a/libs/sofia-sip/.update +++ b/libs/sofia-sip/.update @@ -1 +1 @@ -Wed May 21 00:25:55 CEST 2008 +Sat May 24 23:03:50 EDT 2008 diff --git a/libs/sofia-sip/libsofia-sip-ua/tport/tport_tag.c b/libs/sofia-sip/libsofia-sip-ua/tport/tport_tag.c index 723988f945..5bd06959d4 100644 --- a/libs/sofia-sip/libsofia-sip-ua/tport/tport_tag.c +++ b/libs/sofia-sip/libsofia-sip-ua/tport/tport_tag.c @@ -226,7 +226,7 @@ tag_typedef_t tptag_pingpong = UINTTAG_TYPEDEF(pingpong); * If true, respond with PONG to PING. Default value is 0 (false). * * If set, the ping-pong protocol is used on TCP connections. If a ping (at - * least 4 whitespace characters) is received within messages, a pong + * least 4 whitespace characters) is received between messages, a pong * (CR-LF) is sent in response. * * Use with tport_tcreate(), tport_tbind(), tport_set_params(), nua_create(), diff --git a/libs/sofia-sip/libsofia-sip-ua/tport/tport_type_tcp.c b/libs/sofia-sip/libsofia-sip-ua/tport/tport_type_tcp.c index 26ccf4661a..38b06aa617 100644 --- a/libs/sofia-sip/libsofia-sip-ua/tport/tport_type_tcp.c +++ b/libs/sofia-sip/libsofia-sip-ua/tport/tport_type_tcp.c @@ -277,7 +277,8 @@ int tport_recv_stream(tport_t *self) if (n <= 0) return (int)n; - SU_DEBUG_7(("%s(%p): received keepalive\n", __func__, (void *)self)); + SU_DEBUG_7(("%s(%p): received keepalive (total %u)\n", __func__, + (void *)self, self->tp_ping)); N -= n, self->tp_ping += n; @@ -449,7 +450,9 @@ void tport_keepalive_timer(tport_t *self, su_time_t now) __func__, (void *)self, "closing connection", TPN_ARGS(self->tp_name), " because of PONG timeout")); - tport_close(self); + tport_error_report(self, EPIPE, NULL); + if (!self->tp_closed) + tport_close(self); return; } }