2002-05-30 17:38:34 +00:00
|
|
|
/*
|
2005-09-14 20:46:50 +00:00
|
|
|
* Asterisk -- An open source telephony toolkit.
|
2002-05-30 17:38:34 +00:00
|
|
|
*
|
2005-09-14 20:46:50 +00:00
|
|
|
* Copyright (C) 1999 - 2005, Digium, Inc.
|
|
|
|
*
|
|
|
|
* Mark Spencer <markster@digium.com>
|
2002-05-30 17:38:34 +00:00
|
|
|
*
|
2005-09-14 20:46:50 +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.
|
2002-05-30 17:38:34 +00:00
|
|
|
*
|
|
|
|
* This program is free software, distributed under the terms of
|
2005-09-14 20:46:50 +00:00
|
|
|
* the GNU General Public License Version 2. See the LICENSE file
|
|
|
|
* at the top of the source tree.
|
|
|
|
*/
|
|
|
|
|
2005-10-24 20:12:06 +00:00
|
|
|
/*! \file
|
2005-09-14 20:46:50 +00:00
|
|
|
*
|
2005-10-24 20:12:06 +00:00
|
|
|
* \brief Digital Milliwatt Test
|
2005-12-30 21:18:06 +00:00
|
|
|
*
|
|
|
|
* \author Mark Spencer <markster@digium.com>
|
2005-09-14 20:46:50 +00:00
|
|
|
*
|
2005-11-06 15:09:47 +00:00
|
|
|
* \ingroup applications
|
2002-05-30 17:38:34 +00:00
|
|
|
*/
|
|
|
|
|
2006-06-07 18:54:56 +00:00
|
|
|
#include "asterisk.h"
|
|
|
|
|
|
|
|
ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
|
|
|
|
|
2005-06-06 22:39:32 +00:00
|
|
|
#include <stdlib.h>
|
2005-11-08 04:48:00 +00:00
|
|
|
#include <stdio.h>
|
2005-06-06 22:39:32 +00:00
|
|
|
#include <string.h>
|
2005-11-08 04:48:00 +00:00
|
|
|
#include <unistd.h>
|
2005-06-06 22:39:32 +00:00
|
|
|
#include <errno.h>
|
|
|
|
|
2005-04-21 06:02:45 +00:00
|
|
|
#include "asterisk/lock.h"
|
|
|
|
#include "asterisk/file.h"
|
|
|
|
#include "asterisk/logger.h"
|
|
|
|
#include "asterisk/channel.h"
|
|
|
|
#include "asterisk/pbx.h"
|
|
|
|
#include "asterisk/module.h"
|
2006-01-13 03:34:31 +00:00
|
|
|
#include "asterisk/utils.h"
|
2002-05-30 17:38:34 +00:00
|
|
|
|
|
|
|
static char *app = "Milliwatt";
|
|
|
|
|
|
|
|
static char *synopsis = "Generate a Constant 1000Hz tone at 0dbm (mu-law)";
|
|
|
|
|
|
|
|
static char *descrip =
|
|
|
|
"Milliwatt(): Generate a Constant 1000Hz tone at 0dbm (mu-law)\n";
|
|
|
|
|
|
|
|
|
|
|
|
static char digital_milliwatt[] = {0x1e,0x0b,0x0b,0x1e,0x9e,0x8b,0x8b,0x9e} ;
|
|
|
|
|
|
|
|
static void *milliwatt_alloc(struct ast_channel *chan, void *params)
|
|
|
|
{
|
2006-01-13 03:34:31 +00:00
|
|
|
return ast_calloc(1, sizeof(int));
|
2002-05-30 17:38:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void milliwatt_release(struct ast_channel *chan, void *data)
|
|
|
|
{
|
|
|
|
free(data);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2003-06-27 23:02:52 +00:00
|
|
|
static int milliwatt_generate(struct ast_channel *chan, void *data, int len, int samples)
|
2002-05-30 17:38:34 +00:00
|
|
|
{
|
2006-01-19 04:21:12 +00:00
|
|
|
unsigned char buf[AST_FRIENDLY_OFFSET + 640];
|
2006-03-30 06:07:04 +00:00
|
|
|
const int maxsamples = sizeof (buf) / sizeof (buf[0]);
|
|
|
|
int i, *indexp = (int *) data;
|
2006-08-29 20:50:36 +00:00
|
|
|
struct ast_frame wf = {
|
|
|
|
.frametype = AST_FRAME_VOICE,
|
|
|
|
.subclass = AST_FORMAT_ULAW,
|
|
|
|
.offset = AST_FRIENDLY_OFFSET,
|
|
|
|
.data = buf + AST_FRIENDLY_OFFSET,
|
|
|
|
.src = __FUNCTION__,
|
|
|
|
};
|
2006-03-30 06:07:04 +00:00
|
|
|
|
|
|
|
/* Instead of len, use samples, because channel.c generator_force
|
|
|
|
* generate(chan, tmp, 0, 160) ignores len. In any case, len is
|
|
|
|
* a multiple of samples, given by number of samples times bytes per
|
|
|
|
* sample. In the case of ulaw, len = samples. for signed linear
|
|
|
|
* len = 2 * samples */
|
|
|
|
|
|
|
|
if (samples > maxsamples) {
|
|
|
|
ast_log(LOG_WARNING, "Only doing %d samples (%d requested)\n", maxsamples, samples);
|
|
|
|
samples = maxsamples;
|
2002-05-30 17:38:34 +00:00
|
|
|
}
|
2006-03-30 06:07:04 +00:00
|
|
|
len = samples * sizeof (buf[0]);
|
2002-05-30 17:38:34 +00:00
|
|
|
wf.datalen = len;
|
2006-03-30 06:07:04 +00:00
|
|
|
wf.samples = samples;
|
2002-05-30 17:38:34 +00:00
|
|
|
/* create a buffer containing the digital milliwatt pattern */
|
|
|
|
for(i = 0; i < len; i++)
|
|
|
|
{
|
2006-01-19 04:21:12 +00:00
|
|
|
buf[AST_FRIENDLY_OFFSET + i] = digital_milliwatt[(*indexp)++];
|
2002-05-30 17:38:34 +00:00
|
|
|
*indexp &= 7;
|
|
|
|
}
|
|
|
|
if (ast_write(chan,&wf) < 0)
|
|
|
|
{
|
|
|
|
ast_log(LOG_WARNING,"Failed to write frame to '%s': %s\n",chan->name,strerror(errno));
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct ast_generator milliwattgen =
|
|
|
|
{
|
|
|
|
alloc: milliwatt_alloc,
|
|
|
|
release: milliwatt_release,
|
|
|
|
generate: milliwatt_generate,
|
|
|
|
} ;
|
|
|
|
|
|
|
|
static int milliwatt_exec(struct ast_channel *chan, void *data)
|
|
|
|
{
|
|
|
|
|
2006-08-21 02:11:39 +00:00
|
|
|
struct ast_module_user *u;
|
|
|
|
u = ast_module_user_add(chan);
|
2004-04-06 22:17:32 +00:00
|
|
|
ast_set_write_format(chan, AST_FORMAT_ULAW);
|
|
|
|
ast_set_read_format(chan, AST_FORMAT_ULAW);
|
2002-07-12 09:03:50 +00:00
|
|
|
if (chan->_state != AST_STATE_UP)
|
2002-05-30 17:38:34 +00:00
|
|
|
{
|
|
|
|
ast_answer(chan);
|
|
|
|
}
|
|
|
|
if (ast_activate_generator(chan,&milliwattgen,"milliwatt") < 0)
|
|
|
|
{
|
|
|
|
ast_log(LOG_WARNING,"Failed to activate generator on '%s'\n",chan->name);
|
2006-08-21 02:11:39 +00:00
|
|
|
ast_module_user_remove(u);
|
2002-05-30 17:38:34 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
while(!ast_safe_sleep(chan, 10000));
|
|
|
|
ast_deactivate_generator(chan);
|
2006-08-21 02:11:39 +00:00
|
|
|
ast_module_user_remove(u);
|
2002-05-30 17:38:34 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2006-08-21 02:11:39 +00:00
|
|
|
static int unload_module(void)
|
2002-05-30 17:38:34 +00:00
|
|
|
{
|
2005-10-18 22:52:21 +00:00
|
|
|
int res;
|
|
|
|
|
|
|
|
res = ast_unregister_application(app);
|
|
|
|
|
2006-08-21 02:11:39 +00:00
|
|
|
ast_module_user_hangup_all();
|
2005-10-18 22:52:21 +00:00
|
|
|
|
|
|
|
return res;
|
2002-05-30 17:38:34 +00:00
|
|
|
}
|
|
|
|
|
2006-08-21 02:11:39 +00:00
|
|
|
static int load_module(void)
|
2002-05-30 17:38:34 +00:00
|
|
|
{
|
|
|
|
return ast_register_application(app, milliwatt_exec, synopsis, descrip);
|
|
|
|
}
|
|
|
|
|
2006-08-21 02:11:39 +00:00
|
|
|
AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Digital Milliwatt (mu-law) Test Application");
|