From a41eab6bedf670f9f34f069b82a85c3a49c5e1bd Mon Sep 17 00:00:00 2001 From: Daniel-Constantin Mierla Date: Wed, 7 Jan 2015 22:01:27 +0100 Subject: [PATCH] dialog: proper handling of dlg_set_timeout() for not confirmed dialogs --- modules/dialog/dlg_hash.c | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/modules/dialog/dlg_hash.c b/modules/dialog/dlg_hash.c index 0d8fdcaa86c..134626a5d1b 100644 --- a/modules/dialog/dlg_hash.c +++ b/modules/dialog/dlg_hash.c @@ -1076,12 +1076,14 @@ int dlg_set_toroute(struct dlg_cell *dlg, str *route) int update_dlg_timeout(dlg_cell_t *dlg, int timeout) { - if(update_dlg_timer(&dlg->tl, timeout) < 0) { - LM_ERR("failed to update dialog lifetime\n"); - dlg_release(dlg); - return -1; - } - + if(dlg->state!=DLG_STATE_UNCONFIRMED + && dlg->state!=DLG_STATE_EARLY) { + if(update_dlg_timer(&dlg->tl, timeout) < 0) { + LM_ERR("failed to update dialog lifetime\n"); + dlg_release(dlg); + return -1; + } + } dlg->lifetime = timeout; dlg->dflags |= DLG_FLAG_CHANGED;