Merge "res_pjsip_session.c: Extract sip_session_defer_termination_stop_timer()."
This commit is contained in:
commit
f99322ab21
|
@ -1693,6 +1693,23 @@ int ast_sip_session_defer_termination(struct ast_sip_session *session)
|
|||
return res;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \internal
|
||||
* \brief Stop the defer termination timer if it is still running.
|
||||
* \since 13.5.0
|
||||
*
|
||||
* \param session Which session to stop the timer.
|
||||
*
|
||||
* \return Nothing
|
||||
*/
|
||||
static void sip_session_defer_termination_stop_timer(struct ast_sip_session *session)
|
||||
{
|
||||
if (pj_timer_heap_cancel(pjsip_endpt_get_timer_heap(ast_sip_get_pjsip_endpoint()),
|
||||
&session->scheduled_termination)) {
|
||||
ao2_ref(session, -1);
|
||||
}
|
||||
}
|
||||
|
||||
void ast_sip_session_defer_termination_cancel(struct ast_sip_session *session)
|
||||
{
|
||||
if (!session->defer_terminate) {
|
||||
|
@ -1707,10 +1724,7 @@ void ast_sip_session_defer_termination_cancel(struct ast_sip_session *session)
|
|||
}
|
||||
|
||||
/* Stop the termination timer if it is still running. */
|
||||
if (pj_timer_heap_cancel(pjsip_endpt_get_timer_heap(ast_sip_get_pjsip_endpoint()),
|
||||
&session->scheduled_termination)) {
|
||||
ao2_ref(session, -1);
|
||||
}
|
||||
sip_session_defer_termination_stop_timer(session);
|
||||
}
|
||||
|
||||
struct ast_sip_session *ast_sip_dialog_get_session(pjsip_dialog *dlg)
|
||||
|
@ -2257,9 +2271,7 @@ static void session_end(struct ast_sip_session *session)
|
|||
struct ast_sip_session_supplement *iter;
|
||||
|
||||
/* Stop the scheduled termination */
|
||||
if (pj_timer_heap_cancel(pjsip_endpt_get_timer_heap(ast_sip_get_pjsip_endpoint()), &session->scheduled_termination)) {
|
||||
ao2_ref(session, -1);
|
||||
}
|
||||
sip_session_defer_termination_stop_timer(session);
|
||||
|
||||
/* Session is dead. Notify the supplements. */
|
||||
AST_LIST_TRAVERSE(&session->supplements, iter, next) {
|
||||
|
|
Loading…
Reference in New Issue