mirror of
https://github.com/irungentoo/toxcore.git
synced 2024-03-22 13:30:51 +08:00
Fixed tests and conflicts
This commit is contained in:
commit
fc230c8671
|
@ -1,7 +1,7 @@
|
||||||
if BUILD_TESTS
|
if BUILD_TESTS
|
||||||
|
|
||||||
TESTS = messenger_autotest# crypto_test network_test assoc_test onion_test TCP_test tox_test
|
TESTS = messenger_autotest crypto_test network_test assoc_test onion_test TCP_test tox_test
|
||||||
check_PROGRAMS = messenger_autotest# crypto_test network_test assoc_test onion_test TCP_test tox_test
|
check_PROGRAMS = messenger_autotest crypto_test network_test assoc_test onion_test TCP_test tox_test
|
||||||
|
|
||||||
AUTOTEST_CFLAGS = \
|
AUTOTEST_CFLAGS = \
|
||||||
$(LIBSODIUM_CFLAGS) \
|
$(LIBSODIUM_CFLAGS) \
|
||||||
|
@ -20,8 +20,8 @@ AUTOTEST_LDADD = \
|
||||||
|
|
||||||
|
|
||||||
if BUILD_AV
|
if BUILD_AV
|
||||||
TESTS += toxav_basic_test #toxav_many_test
|
TESTS += toxav_basic_test toxav_many_test
|
||||||
check_PROGRAMS += toxav_basic_test #toxav_many_test
|
check_PROGRAMS += toxav_basic_test toxav_many_test
|
||||||
AUTOTEST_LDADD += libtoxav.la
|
AUTOTEST_LDADD += libtoxav.la
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -32,7 +32,46 @@ messenger_autotest_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
messenger_autotest_LDADD = $(AUTOTEST_LDADD)
|
messenger_autotest_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
|
crypto_test_SOURCES = ../auto_tests/crypto_test.c
|
||||||
|
|
||||||
|
crypto_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
|
|
||||||
|
crypto_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
|
network_test_SOURCES = ../auto_tests/network_test.c
|
||||||
|
|
||||||
|
network_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
|
|
||||||
|
network_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
|
assoc_test_SOURCES = ../auto_tests/assoc_test.c
|
||||||
|
|
||||||
|
assoc_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
|
|
||||||
|
assoc_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
|
onion_test_SOURCES = ../auto_tests/onion_test.c
|
||||||
|
|
||||||
|
onion_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
|
|
||||||
|
onion_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
|
TCP_test_SOURCES = ../auto_tests/TCP_test.c
|
||||||
|
|
||||||
|
TCP_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
|
|
||||||
|
TCP_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
|
tox_test_SOURCES = ../auto_tests/tox_test.c
|
||||||
|
|
||||||
|
tox_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
|
|
||||||
|
tox_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -44,14 +83,13 @@ toxav_basic_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
toxav_basic_test_LDADD = $(AUTOTEST_LDADD)
|
toxav_basic_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
|
|
||||||
|
|
||||||
#toxav_many_test_SOURCES = ../auto_tests/toxav_many_test.c
|
toxav_many_test_SOURCES = ../auto_tests/toxav_many_test.c
|
||||||
|
|
||||||
#toxav_many_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
toxav_many_test_CFLAGS = $(AUTOTEST_CFLAGS)
|
||||||
|
|
||||||
#toxav_many_test_LDADD = $(AUTOTEST_LDADD)
|
toxav_many_test_LDADD = $(AUTOTEST_LDADD)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
EXTRA_DIST += $(top_srcdir)/auto_tests/friends_test.c
|
EXTRA_DIST += $(top_srcdir)/auto_tests/friends_test.c
|
||||||
|
|
|
@ -49,7 +49,7 @@ typedef struct _Status {
|
||||||
} Status;
|
} Status;
|
||||||
|
|
||||||
/* My default settings */
|
/* My default settings */
|
||||||
static ToxAvCodecSettings muhcaps;
|
static ToxAvCSettings muhcaps;
|
||||||
|
|
||||||
void accept_friend_request(Tox *m, const uint8_t *public_key, const uint8_t *data, uint16_t length, void *userdata)
|
void accept_friend_request(Tox *m, const uint8_t *public_key, const uint8_t *data, uint16_t length, void *userdata)
|
||||||
{
|
{
|
||||||
|
@ -82,7 +82,7 @@ void callback_recv_starting ( void *av, int32_t call_index, void *_arg )
|
||||||
/* Alice always sends invite */
|
/* Alice always sends invite */
|
||||||
printf("Call started on Alice side...\n");
|
printf("Call started on Alice side...\n");
|
||||||
cast->Alice.status = InCall;
|
cast->Alice.status = InCall;
|
||||||
toxav_prepare_transmission(av, call_index, 3, 0, 1);
|
toxav_prepare_transmission(av, call_index, av_jbufdc, av_VADd, 1);
|
||||||
}
|
}
|
||||||
void callback_recv_ending ( void *av, int32_t call_index, void *_arg )
|
void callback_recv_ending ( void *av, int32_t call_index, void *_arg )
|
||||||
{
|
{
|
||||||
|
@ -105,7 +105,7 @@ void callback_call_started ( void *av, int32_t call_index, void *_arg )
|
||||||
/* Alice always sends invite */
|
/* Alice always sends invite */
|
||||||
printf("Call started on Bob side...\n");
|
printf("Call started on Bob side...\n");
|
||||||
cast->Bob.status = InCall;
|
cast->Bob.status = InCall;
|
||||||
toxav_prepare_transmission(av, call_index, 3, 0, 1);
|
toxav_prepare_transmission(av, call_index, av_jbufdc, av_VADd, 1);
|
||||||
}
|
}
|
||||||
void callback_call_canceled ( void *av, int32_t call_index, void *_arg )
|
void callback_call_canceled ( void *av, int32_t call_index, void *_arg )
|
||||||
{
|
{
|
||||||
|
@ -133,7 +133,7 @@ void callback_call_ended ( void *av, int32_t call_index, void *_arg )
|
||||||
|
|
||||||
void callback_call_type_change ( void *av, int32_t call_index, void *_arg )
|
void callback_call_type_change ( void *av, int32_t call_index, void *_arg )
|
||||||
{
|
{
|
||||||
ToxAvCodecSettings csettings;
|
ToxAvCSettings csettings;
|
||||||
toxav_get_peer_csettings(av, call_index, 0, &csettings);
|
toxav_get_peer_csettings(av, call_index, 0, &csettings);
|
||||||
|
|
||||||
printf("New settings: \n"
|
printf("New settings: \n"
|
||||||
|
|
|
@ -174,7 +174,7 @@ void *in_thread_call (void *arg)
|
||||||
|
|
||||||
switch ( step ) {
|
switch ( step ) {
|
||||||
case 0: /* CALLER */
|
case 0: /* CALLER */
|
||||||
toxav_call(this_call->Caller.av, &call_idx, this_call->Callee.id, TypeVideo, 10);
|
toxav_call(this_call->Caller.av, &call_idx, this_call->Callee.id, &av_DefaultSettings, 10);
|
||||||
call_print(call_idx, "Calling ...");
|
call_print(call_idx, "Calling ...");
|
||||||
step++;
|
step++;
|
||||||
break;
|
break;
|
||||||
|
@ -182,7 +182,7 @@ void *in_thread_call (void *arg)
|
||||||
case 1: /* CALLEE */
|
case 1: /* CALLEE */
|
||||||
if (this_call->Caller.status == Ringing) {
|
if (this_call->Caller.status == Ringing) {
|
||||||
call_print(call_idx, "Callee answers ...");
|
call_print(call_idx, "Callee answers ...");
|
||||||
toxav_answer(this_call->Callee.av, 0, TypeVideo);
|
toxav_answer(this_call->Callee.av, 0, &av_DefaultSettings);
|
||||||
step++;
|
step++;
|
||||||
start = time(NULL);
|
start = time(NULL);
|
||||||
}
|
}
|
||||||
|
@ -193,11 +193,9 @@ void *in_thread_call (void *arg)
|
||||||
if (this_call->Caller.status == InCall) { /* I think this is okay */
|
if (this_call->Caller.status == InCall) { /* I think this is okay */
|
||||||
call_print(call_idx, "Sending rtp ...");
|
call_print(call_idx, "Sending rtp ...");
|
||||||
|
|
||||||
ToxAvCodecSettings cast = av_DefaultSettings;
|
|
||||||
|
|
||||||
c_sleep(1000); /* We have race condition here */
|
c_sleep(1000); /* We have race condition here */
|
||||||
toxav_prepare_transmission(this_call->Callee.av, 0, &cast, 1);
|
toxav_prepare_transmission(this_call->Callee.av, 0, 3, 0, 1);
|
||||||
toxav_prepare_transmission(this_call->Caller.av, call_idx, &cast, 1);
|
toxav_prepare_transmission(this_call->Caller.av, call_idx, 3, 0, 1);
|
||||||
|
|
||||||
int payload_size = toxav_prepare_audio_frame(this_call->Caller.av, call_idx, prepared_payload, RTP_PAYLOAD_SIZE,
|
int payload_size = toxav_prepare_audio_frame(this_call->Caller.av, call_idx, prepared_payload, RTP_PAYLOAD_SIZE,
|
||||||
sample_payload, frame_size);
|
sample_payload, frame_size);
|
||||||
|
|
164
toxav/codec.c
164
toxav/codec.c
|
@ -36,152 +36,96 @@
|
||||||
#include "rtp.h"
|
#include "rtp.h"
|
||||||
#include "codec.h"
|
#include "codec.h"
|
||||||
|
|
||||||
const uint16_t min_jbuf_size = 4;
|
JitterBuffer *create_queue(unsigned int capacity)
|
||||||
const uint16_t min_readiness_idx = 2; /* when is buffer ready to dqq */
|
|
||||||
|
|
||||||
int empty_queue(JitterBuffer *q)
|
|
||||||
{
|
{
|
||||||
while (q->size > 0) {
|
unsigned int size = 1;
|
||||||
rtp_free_msg(NULL, q->queue[q->front]);
|
|
||||||
q->front++;
|
|
||||||
|
|
||||||
if (q->front == q->capacity)
|
while (size <= (capacity + 4) * 2) {
|
||||||
q->front = 0;
|
size *= 2;
|
||||||
|
|
||||||
q->size--;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
q->id_set = 0;
|
|
||||||
q->queue_ready = 0;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
JitterBuffer *create_queue(int capacity)
|
|
||||||
{
|
|
||||||
JitterBuffer *q;
|
JitterBuffer *q;
|
||||||
|
|
||||||
if ( !(q = calloc(sizeof(JitterBuffer), 1)) ) return NULL;
|
if ( !(q = calloc(sizeof(JitterBuffer), 1)) ) return NULL;
|
||||||
|
|
||||||
if (!(q->queue = calloc(sizeof(RTPMessage *), capacity))) {
|
if (!(q->queue = calloc(sizeof(RTPMessage *), size))) {
|
||||||
free(q);
|
free(q);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
q->size = 0;
|
q->size = size;
|
||||||
q->capacity = capacity >= min_jbuf_size ? capacity : min_jbuf_size;
|
q->capacity = capacity;
|
||||||
q->front = 0;
|
|
||||||
q->rear = -1;
|
|
||||||
q->queue_ready = 0;
|
|
||||||
q->current_id = 0;
|
|
||||||
q->current_ts = 0;
|
|
||||||
q->id_set = 0;
|
|
||||||
return q;
|
return q;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void clear_queue(JitterBuffer *q)
|
||||||
|
{
|
||||||
|
for (; q->bottom != q->top; ++q->bottom) {
|
||||||
|
if (q->queue[q->bottom % q->size]) {
|
||||||
|
rtp_free_msg(NULL, q->queue[q->bottom % q->size]);
|
||||||
|
q->queue[q->bottom % q->size] = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void terminate_queue(JitterBuffer *q)
|
void terminate_queue(JitterBuffer *q)
|
||||||
{
|
{
|
||||||
if (!q) return;
|
if (!q) return;
|
||||||
|
|
||||||
empty_queue(q);
|
clear_queue(q);
|
||||||
free(q->queue);
|
free(q->queue);
|
||||||
|
|
||||||
LOGGER_DEBUG("Terminated jitter buffer: %p", q);
|
|
||||||
free(q);
|
free(q);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define sequnum_older(sn_a, sn_b, ts_a, ts_b) (sn_a > sn_b || ts_a > ts_b)
|
void queue(JitterBuffer *q, RTPMessage *pk)
|
||||||
|
{
|
||||||
|
uint16_t sequnum = pk->header->sequnum;
|
||||||
|
|
||||||
|
unsigned int num = sequnum % q->size;
|
||||||
|
|
||||||
|
if (sequnum - q->bottom > q->size) {
|
||||||
|
clear_queue(q);
|
||||||
|
q->bottom = sequnum;
|
||||||
|
q->queue[num] = pk;
|
||||||
|
q->top = sequnum + 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (q->queue[num])
|
||||||
|
return;
|
||||||
|
|
||||||
|
q->queue[num] = pk;
|
||||||
|
|
||||||
|
if ((sequnum - q->bottom) >= (q->top - q->bottom))
|
||||||
|
q->top = sequnum + 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* success is 0 when there is nothing to dequeue, 1 when there's a good packet, 2 when there's a lost packet */
|
/* success is 0 when there is nothing to dequeue, 1 when there's a good packet, 2 when there's a lost packet */
|
||||||
RTPMessage *dequeue(JitterBuffer *q, int *success)
|
RTPMessage *dequeue(JitterBuffer *q, int *success)
|
||||||
{
|
{
|
||||||
if (q->size == 0 || q->queue_ready == 0) { /* Empty queue */
|
if (q->top == q->bottom) {
|
||||||
q->queue_ready = 0;
|
|
||||||
*success = 0;
|
*success = 0;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int front = q->front;
|
unsigned int num = q->bottom % q->size;
|
||||||
|
|
||||||
if (q->id_set == 0) {
|
if (q->queue[num]) {
|
||||||
q->current_id = q->queue[front]->header->sequnum;
|
RTPMessage *ret = q->queue[num];
|
||||||
q->current_ts = q->queue[front]->header->timestamp;
|
q->queue[num] = NULL;
|
||||||
q->id_set = 1;
|
++q->bottom;
|
||||||
} else {
|
*success = 1;
|
||||||
int next_id = q->queue[front]->header->sequnum;
|
return ret;
|
||||||
int next_ts = q->queue[front]->header->timestamp;
|
|
||||||
|
|
||||||
/* if this packet is indeed the expected packet */
|
|
||||||
if (next_id == (q->current_id + 1) % MAX_SEQU_NUM) {
|
|
||||||
q->current_id = next_id;
|
|
||||||
q->current_ts = next_ts;
|
|
||||||
} else {
|
|
||||||
if (sequnum_older(next_id, q->current_id, next_ts, q->current_ts)) {
|
|
||||||
LOGGER_DEBUG("nextid: %d current: %d\n", next_id, q->current_id);
|
|
||||||
q->current_id = (q->current_id + 1) % MAX_SEQU_NUM;
|
|
||||||
*success = 2; /* tell the decoder the packet is lost */
|
|
||||||
return NULL;
|
|
||||||
} else {
|
|
||||||
LOGGER_DEBUG("Packet too old");
|
|
||||||
*success = 0;
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
q->size--;
|
if (q->top - q->bottom > q->capacity) {
|
||||||
q->front++;
|
++q->bottom;
|
||||||
|
*success = 2;
|
||||||
if (q->front == q->capacity)
|
return NULL;
|
||||||
q->front = 0;
|
|
||||||
|
|
||||||
*success = 1;
|
|
||||||
q->current_id = q->queue[front]->header->sequnum;
|
|
||||||
q->current_ts = q->queue[front]->header->timestamp;
|
|
||||||
return q->queue[front];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void queue(JitterBuffer *q, RTPMessage *pk)
|
|
||||||
{
|
|
||||||
if (q->size == q->capacity) { /* Full, empty queue */
|
|
||||||
LOGGER_DEBUG("Queue full s(%d) c(%d), emptying...", q->size, q->capacity);
|
|
||||||
empty_queue(q);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (q->size >= min_readiness_idx) q->queue_ready = 1;
|
*success = 0;
|
||||||
|
return NULL;
|
||||||
++q->size;
|
|
||||||
++q->rear;
|
|
||||||
|
|
||||||
if (q->rear == q->capacity) q->rear = 0;
|
|
||||||
|
|
||||||
q->queue[q->rear] = pk;
|
|
||||||
|
|
||||||
int a;
|
|
||||||
int j;
|
|
||||||
a = q->rear;
|
|
||||||
|
|
||||||
for (j = 0; j < q->size - 1; ++j) {
|
|
||||||
int b = a - 1;
|
|
||||||
|
|
||||||
if (b < 0)
|
|
||||||
b += q->capacity;
|
|
||||||
|
|
||||||
if (sequnum_older(q->queue[b]->header->sequnum, q->queue[a]->header->sequnum,
|
|
||||||
q->queue[b]->header->timestamp, q->queue[a]->header->timestamp)) {
|
|
||||||
RTPMessage *temp;
|
|
||||||
temp = q->queue[a];
|
|
||||||
q->queue[a] = q->queue[b];
|
|
||||||
q->queue[b] = temp;
|
|
||||||
LOGGER_DEBUG("Had to swap");
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
a -= 1;
|
|
||||||
|
|
||||||
if (a < 0) a += q->capacity;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -78,17 +78,13 @@ typedef struct _CodecState {
|
||||||
|
|
||||||
typedef struct _JitterBuffer {
|
typedef struct _JitterBuffer {
|
||||||
RTPMessage **queue;
|
RTPMessage **queue;
|
||||||
uint16_t capacity;
|
unsigned int size;
|
||||||
uint16_t size;
|
unsigned int capacity;
|
||||||
uint16_t front;
|
uint16_t bottom;
|
||||||
uint16_t rear;
|
uint16_t top;
|
||||||
uint8_t queue_ready;
|
|
||||||
uint16_t current_id;
|
|
||||||
uint32_t current_ts;
|
|
||||||
uint8_t id_set;
|
|
||||||
} JitterBuffer;
|
} JitterBuffer;
|
||||||
|
|
||||||
JitterBuffer *create_queue(int capacity);
|
JitterBuffer *create_queue(unsigned int capacity);
|
||||||
void terminate_queue(JitterBuffer *q);
|
void terminate_queue(JitterBuffer *q);
|
||||||
void queue(JitterBuffer *q, RTPMessage *pk);
|
void queue(JitterBuffer *q, RTPMessage *pk);
|
||||||
RTPMessage *dequeue(JitterBuffer *q, int *success);
|
RTPMessage *dequeue(JitterBuffer *q, int *success);
|
||||||
|
|
|
@ -551,7 +551,7 @@ RTPSession *rtp_init_session ( int payload_type, Messenger *messenger, int frien
|
||||||
|
|
||||||
_retu->dest = friend_num;
|
_retu->dest = friend_num;
|
||||||
|
|
||||||
_retu->rsequnum = _retu->sequnum = 1;
|
_retu->rsequnum = _retu->sequnum = 0;
|
||||||
|
|
||||||
_retu->ext_header = NULL; /* When needed allocate */
|
_retu->ext_header = NULL; /* When needed allocate */
|
||||||
|
|
||||||
|
|
|
@ -51,6 +51,24 @@
|
||||||
/* call index invalid: true if invalid */
|
/* call index invalid: true if invalid */
|
||||||
#define cii(c_idx, session) (c_idx < 0 || c_idx >= session->max_calls)
|
#define cii(c_idx, session) (c_idx < 0 || c_idx >= session->max_calls)
|
||||||
|
|
||||||
|
|
||||||
|
const ToxAvCSettings av_DefaultSettings = {
|
||||||
|
TypeAudio,
|
||||||
|
|
||||||
|
500,
|
||||||
|
1280,
|
||||||
|
720,
|
||||||
|
|
||||||
|
64000,
|
||||||
|
20,
|
||||||
|
48000,
|
||||||
|
1
|
||||||
|
};
|
||||||
|
|
||||||
|
const uint32_t av_jbufdc = 3;
|
||||||
|
const uint32_t av_VADd = 40;
|
||||||
|
|
||||||
|
|
||||||
static const uint8_t audio_index = 0, video_index = 1;
|
static const uint8_t audio_index = 0, video_index = 1;
|
||||||
|
|
||||||
typedef struct _CallSpecific {
|
typedef struct _CallSpecific {
|
||||||
|
@ -84,20 +102,7 @@ struct _ToxAv {
|
||||||
uint32_t max_calls;
|
uint32_t max_calls;
|
||||||
};
|
};
|
||||||
|
|
||||||
const ToxAvCodecSettings av_DefaultSettings = {
|
static MSICSettings msicsettings_cast (const ToxAvCSettings* from)
|
||||||
TypeAudio,
|
|
||||||
|
|
||||||
500,
|
|
||||||
1280,
|
|
||||||
720,
|
|
||||||
|
|
||||||
64000,
|
|
||||||
20,
|
|
||||||
48000,
|
|
||||||
1
|
|
||||||
};
|
|
||||||
|
|
||||||
static MSICSettings msicsettings_cast (const ToxAvCodecSettings* from)
|
|
||||||
{
|
{
|
||||||
MSICSettings csettings;
|
MSICSettings csettings;
|
||||||
csettings.call_type = from->call_type;
|
csettings.call_type = from->call_type;
|
||||||
|
@ -114,9 +119,9 @@ static MSICSettings msicsettings_cast (const ToxAvCodecSettings* from)
|
||||||
return csettings;
|
return csettings;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ToxAvCodecSettings toxavcsettings_cast (const MSICSettings* from)
|
static ToxAvCSettings toxavcsettings_cast (const MSICSettings* from)
|
||||||
{
|
{
|
||||||
ToxAvCodecSettings csettings;
|
ToxAvCSettings csettings;
|
||||||
csettings.call_type = from->call_type;
|
csettings.call_type = from->call_type;
|
||||||
|
|
||||||
csettings.video_bitrate = from->video_bitrate;
|
csettings.video_bitrate = from->video_bitrate;
|
||||||
|
@ -237,7 +242,7 @@ void toxav_register_video_recv_callback (ToxAv *av, void (*callback)(ToxAv *, in
|
||||||
* @retval 0 Success.
|
* @retval 0 Success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_call (ToxAv* av, int32_t* call_index, int user, const ToxAvCodecSettings* csettings, int ringing_seconds )
|
int toxav_call (ToxAv* av, int32_t* call_index, int user, const ToxAvCSettings* csettings, int ringing_seconds )
|
||||||
{
|
{
|
||||||
return msi_invite(av->msi_session, call_index, msicsettings_cast(csettings), ringing_seconds * 1000, user);
|
return msi_invite(av->msi_session, call_index, msicsettings_cast(csettings), ringing_seconds * 1000, user);
|
||||||
}
|
}
|
||||||
|
@ -272,7 +277,7 @@ int toxav_hangup ( ToxAv *av, int32_t call_index )
|
||||||
* @retval 0 Success.
|
* @retval 0 Success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_answer ( ToxAv* av, int32_t call_index, const ToxAvCodecSettings* csettings )
|
int toxav_answer ( ToxAv* av, int32_t call_index, const ToxAvCSettings* csettings )
|
||||||
{
|
{
|
||||||
if ( cii(call_index, av->msi_session) || !av->msi_session->calls[call_index] ) {
|
if ( cii(call_index, av->msi_session) || !av->msi_session->calls[call_index] ) {
|
||||||
return ErrorNoCall;
|
return ErrorNoCall;
|
||||||
|
@ -339,7 +344,7 @@ int toxav_cancel ( ToxAv *av, int32_t call_index, int peer_id, const char *reaso
|
||||||
* @retval 0 Success.
|
* @retval 0 Success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_change_settings(ToxAv* av, int32_t call_index, const ToxAvCodecSettings* csettings)
|
int toxav_change_settings(ToxAv* av, int32_t call_index, const ToxAvCSettings* csettings)
|
||||||
{
|
{
|
||||||
if ( cii(call_index, av->msi_session) || !av->msi_session->calls[call_index] ) {
|
if ( cii(call_index, av->msi_session) || !av->msi_session->calls[call_index] ) {
|
||||||
return ErrorNoCall;
|
return ErrorNoCall;
|
||||||
|
@ -426,7 +431,7 @@ int toxav_prepare_transmission ( ToxAv* av, int32_t call_index, uint32_t jbuf_ca
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ToxAvCodecSettings csettings = toxavcsettings_cast(&av->msi_session->calls[call_index]->csettings_peer[0]);
|
ToxAvCSettings csettings = toxavcsettings_cast(&av->msi_session->calls[call_index]->csettings_peer[0]);
|
||||||
LOGGER_DEBUG(
|
LOGGER_DEBUG(
|
||||||
"Type: %u \n"
|
"Type: %u \n"
|
||||||
"Video bitrate: %u \n"
|
"Video bitrate: %u \n"
|
||||||
|
@ -754,7 +759,7 @@ inline__ int toxav_prepare_audio_frame ( ToxAv *av, int32_t call_index, uint8_t
|
||||||
* @retval ToxAvCallType On success.
|
* @retval ToxAvCallType On success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_get_peer_csettings ( ToxAv *av, int32_t call_index, int peer, ToxAvCodecSettings* dest )
|
int toxav_get_peer_csettings ( ToxAv *av, int32_t call_index, int peer, ToxAvCSettings* dest )
|
||||||
{
|
{
|
||||||
if ( peer < 0 || cii(call_index, av->msi_session) || !av->msi_session->calls[call_index]
|
if ( peer < 0 || cii(call_index, av->msi_session) || !av->msi_session->calls[call_index]
|
||||||
|| av->msi_session->calls[call_index]->peer_count <= peer )
|
|| av->msi_session->calls[call_index]->peer_count <= peer )
|
||||||
|
|
|
@ -129,9 +129,11 @@ typedef struct _ToxAvCodecSettings {
|
||||||
uint16_t audio_frame_duration; /* In ms */
|
uint16_t audio_frame_duration; /* In ms */
|
||||||
uint32_t audio_sample_rate; /* In Hz */
|
uint32_t audio_sample_rate; /* In Hz */
|
||||||
uint32_t audio_channels;
|
uint32_t audio_channels;
|
||||||
} ToxAvCodecSettings;
|
} ToxAvCSettings;
|
||||||
|
|
||||||
extern const ToxAvCodecSettings av_DefaultSettings;
|
extern const ToxAvCSettings av_DefaultSettings;
|
||||||
|
extern const uint32_t av_jbufdc; /* Jitter buffer default capacity */
|
||||||
|
extern const uint32_t av_VADd; /* VAD default treshold */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Start new A/V session. There can only be one session at the time. If you register more
|
* @brief Start new A/V session. There can only be one session at the time. If you register more
|
||||||
|
@ -193,7 +195,7 @@ void toxav_register_video_recv_callback (ToxAv *av, void (*callback)(ToxAv *, in
|
||||||
* @retval 0 Success.
|
* @retval 0 Success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_call(ToxAv* av, int32_t* call_index, int user, const ToxAvCodecSettings* csettings, int ringing_seconds);
|
int toxav_call(ToxAv* av, int32_t* call_index, int user, const ToxAvCSettings* csettings, int ringing_seconds);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Hangup active call.
|
* @brief Hangup active call.
|
||||||
|
@ -214,7 +216,7 @@ int toxav_hangup(ToxAv *av, int32_t call_index);
|
||||||
* @retval 0 Success.
|
* @retval 0 Success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_answer(ToxAv *av, int32_t call_index, const ToxAvCodecSettings* csettings );
|
int toxav_answer(ToxAv *av, int32_t call_index, const ToxAvCSettings* csettings );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Reject incomming call.
|
* @brief Reject incomming call.
|
||||||
|
@ -240,14 +242,14 @@ int toxav_reject(ToxAv *av, int32_t call_index, const char *reason);
|
||||||
int toxav_cancel(ToxAv *av, int32_t call_index, int peer_id, const char *reason);
|
int toxav_cancel(ToxAv *av, int32_t call_index, int peer_id, const char *reason);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Notify peer that we are changing call type
|
* @brief Notify peer that we are changing call settings
|
||||||
*
|
*
|
||||||
* @param av Handler.
|
* @param av Handler.
|
||||||
* @return int
|
* @return int
|
||||||
* @retval 0 Success.
|
* @retval 0 Success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_change_settings(ToxAv *av, int32_t call_index, const ToxAvCodecSettings* csettings);
|
int toxav_change_settings(ToxAv *av, int32_t call_index, const ToxAvCSettings* csettings);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Terminate transmission. Note that transmission will be terminated without informing remote peer.
|
* @brief Terminate transmission. Note that transmission will be terminated without informing remote peer.
|
||||||
|
@ -342,7 +344,7 @@ int toxav_prepare_audio_frame ( ToxAv *av, int32_t call_index, uint8_t *dest, in
|
||||||
* @retval ToxAvCallType On success.
|
* @retval ToxAvCallType On success.
|
||||||
* @retval ToxAvError On error.
|
* @retval ToxAvError On error.
|
||||||
*/
|
*/
|
||||||
int toxav_get_peer_csettings ( ToxAv *av, int32_t call_index, int peer, ToxAvCodecSettings* dest );
|
int toxav_get_peer_csettings ( ToxAv *av, int32_t call_index, int peer, ToxAvCSettings* dest );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Get id of peer participating in conversation
|
* @brief Get id of peer participating in conversation
|
||||||
|
|
Loading…
Reference in New Issue
Block a user