Files
asterisk/codecs/codec_ulaw.c
T

184 lines
4.4 KiB
C
Raw Normal View History

/*
* Asterisk -- An open source telephony toolkit.
*
* Copyright (C) 1999 - 2005, Digium, Inc.
2001-04-07 01:45:34 +00:00
*
* Mark Spencer <markster@digium.com>
2001-04-07 01:45:34 +00:00
*
* See http://www.asterisk.org for more information about
* the Asterisk project. Please do not directly contact
* any of the maintainers of this project for assistance;
* the project provides a web site, mailing lists and IRC
* channels for your use.
2001-04-07 01:45:34 +00:00
*
* This program is free software, distributed under the terms of
* the GNU General Public License Version 2. See the LICENSE file
* at the top of the source tree.
*/
2005-10-26 13:03:17 +00:00
/*! \file
*
2005-10-26 13:03:17 +00:00
* \brief codec_ulaw.c - translate between signed linear and ulaw
*
2005-11-06 15:09:47 +00:00
* \ingroup codecs
2001-04-07 01:45:34 +00:00
*/
#include "asterisk.h"
ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
#include "asterisk/module.h"
#include "asterisk/config.h"
#include "asterisk/translate.h"
#include "asterisk/ulaw.h"
#include "asterisk/utils.h"
2001-04-07 01:45:34 +00:00
#define BUFFER_SAMPLES 8096 /* size for the translation buffers */
2001-04-07 01:45:34 +00:00
/* Sample frame data */
#include "asterisk/slin.h"
#include "ex_ulaw.h"
2001-04-07 01:45:34 +00:00
/*! \brief convert and store samples in outbuf */
static int ulawtolin_framein(struct ast_trans_pvt *pvt, struct ast_frame *f)
2001-04-07 01:45:34 +00:00
{
int i = f->samples;
unsigned char *src = f->data.ptr;
int16_t *dst = pvt->outbuf.i16 + pvt->samples;
pvt->samples += i;
pvt->datalen += i * 2; /* 2 bytes/sample */
2001-04-07 01:45:34 +00:00
/* convert and copy in outbuf */
while (i--)
*dst++ = AST_MULAW(*src++);
2006-01-20 23:23:00 +00:00
return 0;
2001-04-07 01:45:34 +00:00
}
/*! \brief convert and store samples in outbuf */
static int lintoulaw_framein(struct ast_trans_pvt *pvt, struct ast_frame *f)
2001-04-07 01:45:34 +00:00
{
int i = f->samples;
char *dst = pvt->outbuf.c + pvt->samples;
int16_t *src = f->data.ptr;
pvt->samples += i;
pvt->datalen += i; /* 1 byte/sample */
2006-01-20 23:23:00 +00:00
while (i--)
*dst++ = AST_LIN2MU(*src++);
2006-01-20 23:23:00 +00:00
return 0;
2001-04-07 01:45:34 +00:00
}
2006-01-20 23:23:00 +00:00
/*!
* \brief The complete translator for ulawToLin.
2001-04-07 01:45:34 +00:00
*/
static struct ast_translator ulawtolin = {
.name = "ulawtolin",
.srcfmt = AST_FORMAT_ULAW,
.dstfmt = AST_FORMAT_SLINEAR,
.framein = ulawtolin_framein,
.sample = ulaw_sample,
.buffer_samples = BUFFER_SAMPLES,
.buf_size = BUFFER_SAMPLES * 2,
.plc_samples = 160,
2001-04-07 01:45:34 +00:00
};
static struct ast_translator testlawtolin = {
.name = "testlawtolin",
.srcfmt = AST_FORMAT_TESTLAW,
.dstfmt = AST_FORMAT_SLINEAR,
.framein = ulawtolin_framein,
.sample = ulaw_sample,
.buffer_samples = BUFFER_SAMPLES,
.buf_size = BUFFER_SAMPLES * 2,
.plc_samples = 160,
};
2006-01-20 23:23:00 +00:00
/*!
* \brief The complete translator for LinToulaw.
2001-04-07 01:45:34 +00:00
*/
static struct ast_translator lintoulaw = {
.name = "lintoulaw",
.srcfmt = AST_FORMAT_SLINEAR,
.dstfmt = AST_FORMAT_ULAW,
.framein = lintoulaw_framein,
.sample = slin8_sample,
.buf_size = BUFFER_SAMPLES,
.buffer_samples = BUFFER_SAMPLES,
2001-04-07 01:45:34 +00:00
};
static struct ast_translator lintotestlaw = {
.name = "lintotestlaw",
.srcfmt = AST_FORMAT_SLINEAR,
.dstfmt = AST_FORMAT_TESTLAW,
.framein = lintoulaw_framein,
.sample = slin8_sample,
.buf_size = BUFFER_SAMPLES,
.buffer_samples = BUFFER_SAMPLES,
};
static int parse_config(int reload)
{
2006-01-20 23:23:00 +00:00
struct ast_variable *var;
struct ast_flags config_flags = { reload ? CONFIG_FLAG_FILEUNCHANGED : 0 };
struct ast_config *cfg = ast_config_load("codecs.conf", config_flags);
if (cfg == CONFIG_STATUS_FILEMISSING || cfg == CONFIG_STATUS_FILEUNCHANGED || cfg == CONFIG_STATUS_FILEINVALID)
return 0;
for (var = ast_variable_browse(cfg, "plc"); var; var = var->next) {
if (!strcasecmp(var->name, "genericplc")) {
ulawtolin.useplc = ast_true(var->value) ? 1 : 0;
ast_verb(3, "codec_ulaw: %susing generic PLC\n", ulawtolin.useplc ? "" : "not ");
2006-01-20 23:23:00 +00:00
}
}
ast_config_destroy(cfg);
return 0;
}
static int reload(void)
{
if (parse_config(1))
return AST_MODULE_LOAD_DECLINE;
return AST_MODULE_LOAD_SUCCESS;
}
static int unload_module(void)
2001-04-07 01:45:34 +00:00
{
2006-01-20 23:23:00 +00:00
int res;
2006-01-20 23:23:00 +00:00
res = ast_unregister_translator(&lintoulaw);
res |= ast_unregister_translator(&ulawtolin);
res |= ast_unregister_translator(&testlawtolin);
res |= ast_unregister_translator(&lintotestlaw);
2006-01-20 23:23:00 +00:00
return res;
2001-04-07 01:45:34 +00:00
}
static int load_module(void)
2001-04-07 01:45:34 +00:00
{
2006-01-20 23:23:00 +00:00
int res;
if (parse_config(0))
return AST_MODULE_LOAD_DECLINE;
res = ast_register_translator(&ulawtolin);
if (!res) {
res = ast_register_translator(&lintoulaw);
res |= ast_register_translator(&lintotestlaw);
res |= ast_register_translator(&testlawtolin);
} else
2006-01-20 23:23:00 +00:00
ast_unregister_translator(&ulawtolin);
if (res)
return AST_MODULE_LOAD_FAILURE;
return AST_MODULE_LOAD_SUCCESS;
2001-04-07 01:45:34 +00:00
}
AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_DEFAULT, "mu-Law Coder/Decoder",
.load = load_module,
.unload = unload_module,
.reload = reload,
);