2007-05-04 21:11:27 +00:00
|
|
|
/*
|
|
|
|
* STFU (S)ort (T)ransportable (F)ramed (U)tterances
|
2012-04-25 22:14:55 +00:00
|
|
|
* Copyright (c) 2007-2012 Anthony Minessale II <anthm@freeswitch.org>
|
2007-05-04 21:11:27 +00:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person
|
|
|
|
* obtaining a copy of this software and associated documentation
|
|
|
|
* files (the "Software"), to deal in the Software without
|
|
|
|
* restriction, including without limitation the rights to use,
|
|
|
|
* copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
* copies of the Software, and to permit persons to whom the
|
|
|
|
* Software is furnished to do so, subject to the following
|
|
|
|
* conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be
|
|
|
|
* included in all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
|
|
|
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
|
|
|
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
|
|
|
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
|
|
* OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*
|
2010-08-24 18:20:24 +00:00
|
|
|
* THOSE WHO DISAGREE MAY CERTAINLY STFU
|
2007-05-04 21:11:27 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef STFU_H
|
|
|
|
#define STFU_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
#ifdef __STUPIDFORMATBUG__
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2007-05-04 21:27:54 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2010-12-15 15:39:42 +00:00
|
|
|
#include <stdarg.h>
|
|
|
|
|
2011-06-02 03:36:19 +00:00
|
|
|
#if (_MSC_VER >= 1400) // VC8+
|
|
|
|
#define stfu_assert(expr) assert(expr);__analysis_assume( expr )
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef stfu_assert
|
|
|
|
#define stfu_assert(_x) assert(_x)
|
|
|
|
#endif
|
2007-05-04 21:11:27 +00:00
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
2012-09-27 00:15:24 +00:00
|
|
|
#if !defined(_STDINT) && !defined(uint32_t)
|
2007-05-04 21:11:27 +00:00
|
|
|
typedef unsigned __int8 uint8_t;
|
|
|
|
typedef unsigned __int16 uint16_t;
|
|
|
|
typedef unsigned __int32 uint32_t;
|
|
|
|
typedef unsigned __int64 uint64_t;
|
|
|
|
typedef __int8 int8_t;
|
|
|
|
typedef __int16 int16_t;
|
|
|
|
typedef __int32 int32_t;
|
|
|
|
typedef __int64 int64_t;
|
|
|
|
typedef unsigned long in_addr_t;
|
|
|
|
#endif
|
|
|
|
#define snprintf _snprintf
|
|
|
|
#else
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <time.h>
|
|
|
|
#include <inttypes.h>
|
|
|
|
#endif
|
|
|
|
#include <assert.h>
|
|
|
|
|
2010-12-15 15:39:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef WIN32
|
|
|
|
#include <winsock2.h>
|
|
|
|
#include <windows.h>
|
|
|
|
typedef SOCKET stfu_socket_t;
|
|
|
|
typedef unsigned __int64 uint64_t;
|
|
|
|
typedef unsigned __int32 uint32_t;
|
|
|
|
typedef unsigned __int16 uint16_t;
|
|
|
|
typedef unsigned __int8 uint8_t;
|
|
|
|
typedef __int64 int64_t;
|
|
|
|
typedef __int32 int32_t;
|
|
|
|
typedef __int16 int16_t;
|
|
|
|
typedef __int8 int8_t;
|
|
|
|
typedef intptr_t stfu_ssize_t;
|
|
|
|
typedef int stfu_filehandle_t;
|
|
|
|
#define STFU_SOCK_INVALID INVALID_SOCKET
|
|
|
|
#define strerror_r(num, buf, size) strerror_s(buf, size, num)
|
|
|
|
#if defined(STFU_DECLARE_STATIC)
|
|
|
|
#define STFU_DECLARE(type) type __stdcall
|
|
|
|
#define STFU_DECLARE_NONSTD(type) type __cdecl
|
|
|
|
#define STFU_DECLARE_DATA
|
|
|
|
#elif defined(STFU_EXPORTS)
|
|
|
|
#define STFU_DECLARE(type) __declspec(dllexport) type __stdcall
|
|
|
|
#define STFU_DECLARE_NONSTD(type) __declspec(dllexport) type __cdecl
|
|
|
|
#define STFU_DECLARE_DATA __declspec(dllexport)
|
|
|
|
#else
|
|
|
|
#define STFU_DECLARE(type) __declspec(dllimport) type __stdcall
|
|
|
|
#define STFU_DECLARE_NONSTD(type) __declspec(dllimport) type __cdecl
|
|
|
|
#define STFU_DECLARE_DATA __declspec(dllimport)
|
|
|
|
#endif
|
|
|
|
#else
|
|
|
|
#define STFU_DECLARE(type) type
|
|
|
|
#define STFU_DECLARE_NONSTD(type) type
|
|
|
|
#define STFU_DECLARE_DATA
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#include <netdb.h>
|
|
|
|
#define STFU_SOCK_INVALID -1
|
|
|
|
typedef int stfu_socket_t;
|
|
|
|
typedef ssize_t stfu_ssize_t;
|
|
|
|
typedef int stfu_filehandle_t;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#define STFU_PRE __FILE__, __FUNCTION__, __LINE__
|
|
|
|
#define STFU_LOG_LEVEL_DEBUG 7
|
|
|
|
#define STFU_LOG_LEVEL_INFO 6
|
|
|
|
#define STFU_LOG_LEVEL_NOTICE 5
|
|
|
|
#define STFU_LOG_LEVEL_WARNING 4
|
|
|
|
#define STFU_LOG_LEVEL_ERROR 3
|
|
|
|
#define STFU_LOG_LEVEL_CRIT 2
|
|
|
|
#define STFU_LOG_LEVEL_ALERT 1
|
|
|
|
#define STFU_LOG_LEVEL_EMERG 0
|
|
|
|
|
|
|
|
#define STFU_LOG_DEBUG STFU_PRE, STFU_LOG_LEVEL_DEBUG
|
|
|
|
#define STFU_LOG_INFO STFU_PRE, STFU_LOG_LEVEL_INFO
|
|
|
|
#define STFU_LOG_NOTICE STFU_PRE, STFU_LOG_LEVEL_NOTICE
|
|
|
|
#define STFU_LOG_WARNING STFU_PRE, STFU_LOG_LEVEL_WARNING
|
|
|
|
#define STFU_LOG_ERROR STFU_PRE, STFU_LOG_LEVEL_ERROR
|
|
|
|
#define STFU_LOG_CRIT STFU_PRE, STFU_LOG_LEVEL_CRIT
|
|
|
|
#define STFU_LOG_ALERT STFU_PRE, STFU_LOG_LEVEL_ALERT
|
|
|
|
#define STFU_LOG_EMERG STFU_PRE, STFU_LOG_LEVEL_EMERG
|
|
|
|
typedef void (*stfu_logger_t)(const char *file, const char *func, int line, int level, const char *fmt, ...);
|
|
|
|
|
|
|
|
|
|
|
|
int stfu_vasprintf(char **ret, const char *fmt, va_list ap);
|
|
|
|
|
2010-12-15 16:37:57 +00:00
|
|
|
extern stfu_logger_t stfu_log;
|
2010-12-15 15:39:42 +00:00
|
|
|
|
|
|
|
/*! Sets the logger for libstfu. Default is the null_logger */
|
|
|
|
void stfu_global_set_logger(stfu_logger_t logger);
|
|
|
|
/*! Sets the default log level for libstfu */
|
|
|
|
void stfu_global_set_default_logger(int level);
|
|
|
|
|
2007-05-04 21:11:27 +00:00
|
|
|
#define STFU_DATALEN 16384
|
|
|
|
#define STFU_QLEN 300
|
|
|
|
#define STFU_MAX_TRACK 256
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
STFU_IT_FAILED,
|
|
|
|
STFU_IT_WORKED,
|
2010-12-15 15:39:42 +00:00
|
|
|
STFU_IM_DONE,
|
|
|
|
STFU_ITS_TOO_LATE
|
2007-05-04 21:11:27 +00:00
|
|
|
} stfu_status_t;
|
|
|
|
|
|
|
|
struct stfu_frame {
|
|
|
|
uint32_t ts;
|
2012-10-18 19:29:00 +00:00
|
|
|
uint16_t seq;
|
2010-01-08 00:45:09 +00:00
|
|
|
uint32_t pt;
|
2007-05-04 21:11:27 +00:00
|
|
|
uint8_t data[STFU_DATALEN];
|
|
|
|
size_t dlen;
|
|
|
|
uint8_t was_read;
|
|
|
|
uint8_t plc;
|
|
|
|
};
|
|
|
|
typedef struct stfu_frame stfu_frame_t;
|
|
|
|
|
|
|
|
struct stfu_instance;
|
|
|
|
typedef struct stfu_instance stfu_instance_t;
|
|
|
|
|
2009-09-15 18:45:19 +00:00
|
|
|
typedef struct {
|
2010-12-10 23:48:19 +00:00
|
|
|
uint32_t qlen;
|
|
|
|
uint32_t packet_in_count;
|
|
|
|
uint32_t clean_count;
|
|
|
|
uint32_t consecutive_good_count;
|
|
|
|
uint32_t consecutive_bad_count;
|
2009-09-15 18:45:19 +00:00
|
|
|
} stfu_report_t;
|
|
|
|
|
2010-12-10 23:48:19 +00:00
|
|
|
typedef void (*stfu_n_call_me_t)(stfu_instance_t *i, void *);
|
2009-09-15 18:45:19 +00:00
|
|
|
|
|
|
|
void stfu_n_report(stfu_instance_t *i, stfu_report_t *r);
|
2007-05-04 21:11:27 +00:00
|
|
|
void stfu_n_destroy(stfu_instance_t **i);
|
2011-02-25 18:45:31 +00:00
|
|
|
stfu_instance_t *stfu_n_init(uint32_t qlen, uint32_t max_qlen, uint32_t samples_per_packet, uint32_t samples_per_second, uint32_t max_drift_ms);
|
2009-09-15 18:45:19 +00:00
|
|
|
stfu_status_t stfu_n_resize(stfu_instance_t *i, uint32_t qlen);
|
2012-10-18 19:29:00 +00:00
|
|
|
stfu_status_t stfu_n_add_data(stfu_instance_t *i, uint32_t ts, uint16_t seq, uint32_t pt, void *data, size_t datalen, uint32_t timer_ts, int last);
|
2007-05-04 21:11:27 +00:00
|
|
|
stfu_frame_t *stfu_n_read_a_frame(stfu_instance_t *i);
|
2007-05-05 01:31:54 +00:00
|
|
|
void stfu_n_reset(stfu_instance_t *i);
|
2010-12-10 23:48:19 +00:00
|
|
|
stfu_status_t stfu_n_sync(stfu_instance_t *i, uint32_t packets);
|
|
|
|
void stfu_n_call_me(stfu_instance_t *i, stfu_n_call_me_t callback, void *udata);
|
2010-12-15 15:39:42 +00:00
|
|
|
void stfu_n_debug(stfu_instance_t *i, const char *name);
|
2010-12-21 21:35:30 +00:00
|
|
|
int32_t stfu_n_get_drift(stfu_instance_t *i);
|
2011-05-06 20:25:07 +00:00
|
|
|
int32_t stfu_n_get_most_qlen(stfu_instance_t *i);
|
2007-05-05 01:31:54 +00:00
|
|
|
|
2012-10-18 19:29:00 +00:00
|
|
|
#define stfu_im_done(i) stfu_n_add_data(i, 0, 0, NULL, 0, 0, 1)
|
|
|
|
#define stfu_n_eat(i,t,s,p,d,l,tt) stfu_n_add_data(i, t, s, p, d, l, tt, 0)
|
2007-05-04 21:11:27 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /*STFU_H*/
|
|
|
|
|