diff --git a/channels/chan_sip.c b/channels/chan_sip.c index 45d4541c05..b5d0c87751 100644 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -5653,7 +5653,11 @@ static int sip_indicate(struct ast_channel *ast, int condition, const void *data case AST_T38_REQUEST_NEGOTIATE: /* Request T38 */ if (p->t38.state != T38_ENABLED) { change_t38_state(p, T38_LOCAL_REINVITE); - transmit_reinvite_with_sdp(p, TRUE, FALSE); + if (!p->pendinginvite) { + transmit_reinvite_with_sdp(p, TRUE, FALSE); + } else if (!ast_test_flag(&p->flags[0], SIP_PENDINGBYE)) { + ast_set_flag(&p->flags[0], SIP_NEEDREINVITE); + } } break; case AST_T38_TERMINATED: @@ -15740,7 +15744,7 @@ static void check_pendings(struct sip_pvt *p) } else { ast_debug(2, "Sending pending reinvite on '%s'\n", p->callid); /* Didn't get to reinvite yet, so do it now */ - transmit_reinvite_with_sdp(p, FALSE, FALSE); + transmit_reinvite_with_sdp(p, (p->t38.state == T38_LOCAL_REINVITE ? TRUE : FALSE), FALSE); ast_clear_flag(&p->flags[0], SIP_NEEDREINVITE); } }