|
|
|
@ -11529,17 +11529,31 @@ immediatedial:
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ((iaxs[fr->callno]->transferring == TRANSFER_BEGIN) ||
|
|
|
|
|
(iaxs[fr->callno]->transferring == TRANSFER_MBEGIN)) {
|
|
|
|
|
if (iaxs[fr->callno]->transferring == TRANSFER_MBEGIN)
|
|
|
|
|
if (iaxs[fr->callno]->transferring == TRANSFER_BEGIN) {
|
|
|
|
|
iaxs[fr->callno]->transferring = TRANSFER_MREADY;
|
|
|
|
|
else
|
|
|
|
|
} else if (iaxs[fr->callno]->transferring == TRANSFER_MBEGIN) {
|
|
|
|
|
iaxs[fr->callno]->transferring = TRANSFER_READY;
|
|
|
|
|
ast_verb(3, "Channel '%s' ready to transfer\n", iaxs[fr->callno]->owner ? ast_channel_name(iaxs[fr->callno]->owner) : "<Unknown>");
|
|
|
|
|
} else {
|
|
|
|
|
if (iaxs[fr->callno]->bridgecallno) {
|
|
|
|
|
if ((iaxs[iaxs[fr->callno]->bridgecallno]->transferring == TRANSFER_READY) ||
|
|
|
|
|
(iaxs[iaxs[fr->callno]->bridgecallno]->transferring == TRANSFER_MREADY)) {
|
|
|
|
|
/* They're both ready, now release them. */
|
|
|
|
|
ast_mutex_unlock(&iaxsl[iaxs[fr->callno]->bridgecallno]);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
ast_verb(3, "Channel '%s' ready to transfer\n", iaxs[fr->callno]->owner ? ast_channel_name(iaxs[fr->callno]->owner) : "<Unknown>");
|
|
|
|
|
|
|
|
|
|
if (!iaxs[fr->callno]->bridgecallno) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!(iaxs[iaxs[fr->callno]->bridgecallno]->transferring == TRANSFER_READY) &&
|
|
|
|
|
!(iaxs[iaxs[fr->callno]->bridgecallno]->transferring == TRANSFER_MREADY)) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Both sides are ready */
|
|
|
|
|
|
|
|
|
|
/* XXX what isn't checked here is that both sides match transfer types. */
|
|
|
|
|
|
|
|
|
|
if (iaxs[fr->callno]->transferring == TRANSFER_MREADY) {
|
|
|
|
|
ast_verb(3, "Attempting media bridge of %s and %s\n", iaxs[fr->callno]->owner ? ast_channel_name(iaxs[fr->callno]->owner) : "<Unknown>",
|
|
|
|
|
iaxs[iaxs[fr->callno]->bridgecallno]->owner ? ast_channel_name(iaxs[iaxs[fr->callno]->bridgecallno]->owner) : "<Unknown>");
|
|
|
|
@ -11573,13 +11587,7 @@ immediatedial:
|
|
|
|
|
send_command(iaxs[fr->callno], AST_FRAME_IAX, IAX_COMMAND_TXREL, 0, ied0.buf, ied0.pos, -1);
|
|
|
|
|
send_command(iaxs[iaxs[fr->callno]->bridgecallno], AST_FRAME_IAX, IAX_COMMAND_TXREL, 0, ied1.buf, ied1.pos, -1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (iaxs[fr->callno]->bridgecallno) {
|
|
|
|
|
ast_mutex_unlock(&iaxsl[iaxs[fr->callno]->bridgecallno]);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case IAX_COMMAND_TXREQ:
|
|
|
|
|
try_transfer(iaxs[fr->callno], &ies);
|
|
|
|
|