mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-18 18:56:25 +00:00
Fixed various bugs towards getting audio flow happening.
This commit is contained in:
parent
6746fc4e36
commit
8c86cf3b0e
27
vomp.c
27
vomp.c
@ -169,7 +169,7 @@ vomp_call_state *vomp_find_or_create_call(unsigned char *remote_sid,
|
|||||||
|
|
||||||
int vomp_send_status(vomp_call_state *call,int flags,overlay_mdp_frame *arg)
|
int vomp_send_status(vomp_call_state *call,int flags,overlay_mdp_frame *arg)
|
||||||
{
|
{
|
||||||
if (flags&VOMP_TELLREMOTE) {
|
if (flags&(VOMP_TELLREMOTE|VOMP_SENDAUDIO)) {
|
||||||
int combined_status=(call->remote.state<<4)|call->local.state;
|
int combined_status=(call->remote.state<<4)|call->local.state;
|
||||||
if (call->last_sent_status!=combined_status
|
if (call->last_sent_status!=combined_status
|
||||||
||(flags&VOMP_FORCETELLREMOTE)==VOMP_FORCETELLREMOTE
|
||(flags&VOMP_FORCETELLREMOTE)==VOMP_FORCETELLREMOTE
|
||||||
@ -215,9 +215,9 @@ int vomp_send_status(vomp_call_state *call,int flags,overlay_mdp_frame *arg)
|
|||||||
mdp.out.payload[mdp.out.payload_length++]=0;
|
mdp.out.payload[mdp.out.payload_length++]=0;
|
||||||
if (0) WHYF("mdp frame with codec list is %d bytes",mdp.out.payload_length);
|
if (0) WHYF("mdp frame with codec list is %d bytes",mdp.out.payload_length);
|
||||||
}
|
}
|
||||||
if (flags&VOMP_SENDAUDIO
|
if (flags&VOMP_SENDAUDIO) {
|
||||||
&&vomp_sample_size(arg->vompevent.audio_sample_codec)
|
if (vomp_sample_size(arg->vompevent.audio_sample_codec)
|
||||||
==arg->vompevent.audio_sample_bytes) {
|
==arg->vompevent.audio_sample_bytes) {
|
||||||
WHY("We should remember the last few audio frames so that we can send more than one in a packet, so that we have implicit preemptive retry of packets. Also helps resolve jitter");
|
WHY("We should remember the last few audio frames so that we can send more than one in a packet, so that we have implicit preemptive retry of packets. Also helps resolve jitter");
|
||||||
unsigned short *len=&mdp.out.payload_length;
|
unsigned short *len=&mdp.out.payload_length;
|
||||||
unsigned char *p=&mdp.out.payload[0];
|
unsigned char *p=&mdp.out.payload[0];
|
||||||
@ -225,6 +225,11 @@ int vomp_send_status(vomp_call_state *call,int flags,overlay_mdp_frame *arg)
|
|||||||
int i;
|
int i;
|
||||||
for(i=0;i<arg->vompevent.audio_sample_bytes;i++)
|
for(i=0;i<arg->vompevent.audio_sample_bytes;i++)
|
||||||
p[(*len)++]=arg->vompevent.audio_bytes[i];
|
p[(*len)++]=arg->vompevent.audio_bytes[i];
|
||||||
|
} else {
|
||||||
|
WHYF("Sample bytes(%d) != codec specification(%d)",
|
||||||
|
arg->vompevent.audio_sample_bytes,
|
||||||
|
vomp_sample_size(arg->vompevent.audio_sample_codec));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
overlay_mdp_send(&mdp,0,0);
|
overlay_mdp_send(&mdp,0,0);
|
||||||
@ -273,7 +278,18 @@ int vomp_call_start_audio(vomp_call_state *call)
|
|||||||
|
|
||||||
int vomp_process_audio(vomp_call_state *call,overlay_mdp_frame *mdp)
|
int vomp_process_audio(vomp_call_state *call,overlay_mdp_frame *mdp)
|
||||||
{
|
{
|
||||||
|
int ofs=14;
|
||||||
|
WHYF("got here (payload has %d bytes)",mdp->in.payload_length);
|
||||||
|
while(ofs<mdp->in.payload_length)
|
||||||
|
{
|
||||||
|
int codec=mdp->in.payload[ofs];
|
||||||
|
WHYF("Spotted a %s sample block",vomp_describe_codec(codec));
|
||||||
|
if (!codec||vomp_sample_size(codec)<0) break;
|
||||||
|
|
||||||
|
/* Pass audio frame to all registered listeners */
|
||||||
|
|
||||||
|
ofs+=1+vomp_sample_size(codec);
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -583,6 +599,7 @@ int vomp_mdp_event(overlay_mdp_frame *mdp,
|
|||||||
break;
|
break;
|
||||||
case VOMPEVENT_AUDIOPACKET: /* user supplying audio */
|
case VOMPEVENT_AUDIOPACKET: /* user supplying audio */
|
||||||
{
|
{
|
||||||
|
WHY("Audio packet arrived");
|
||||||
vomp_call_state *call
|
vomp_call_state *call
|
||||||
=vomp_find_call_by_session(mdp->vompevent.call_session_token);
|
=vomp_find_call_by_session(mdp->vompevent.call_session_token);
|
||||||
return vomp_send_status(call,VOMP_SENDAUDIO,mdp);
|
return vomp_send_status(call,VOMP_SENDAUDIO,mdp);
|
||||||
@ -1136,6 +1153,8 @@ int app_vomp_dtmf(int argc, const char *const *argv, struct command_line_option
|
|||||||
|
|
||||||
/* One digit per sample block. */
|
/* One digit per sample block. */
|
||||||
mdp.vompevent.audio_sample_codec=VOMP_CODEC_DTMF;
|
mdp.vompevent.audio_sample_codec=VOMP_CODEC_DTMF;
|
||||||
|
mdp.vompevent.audio_sample_bytes=1;
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
for(i=0;i<strlen(digits);i++) {
|
for(i=0;i<strlen(digits);i++) {
|
||||||
int digit=vomp_parse_dtmf_digit(digits[i]);
|
int digit=vomp_parse_dtmf_digit(digits[i]);
|
||||||
|
Loading…
Reference in New Issue
Block a user