[svn-commits] russell: branch russell/ast_verbose_threadstorage
r38440 - in /team/russell/a...
svn-commits at lists.digium.com
svn-commits at lists.digium.com
Fri Jul 28 12:29:12 MST 2006
Author: russell
Date: Fri Jul 28 14:29:12 2006
New Revision: 38440
URL: http://svn.digium.com/view/asterisk?rev=38440&view=rev
Log:
Merged revisions 38418,38421-38422,38439 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk
................
r38418 | kpfleming | 2006-07-28 14:03:57 -0400 (Fri, 28 Jul 2006) | 4 lines
more slinfactory structure definition to inside implementation module
make read/write/hold work on samples, not bytes
add an API call to find out how many samples are available in a slinfactory
................
r38421 | file | 2006-07-28 14:53:43 -0400 (Fri, 28 Jul 2006) | 10 lines
Merged revisions 38420 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r38420 | file | 2006-07-28 14:49:00 -0400 (Fri, 28 Jul 2006) | 2 lines
Make a copy of the request URI in check_user_full instead of modifying the one on the structure, and also strip params properly from the user portion of the SIP URI so as to preserve the domain (issue #7552 reported by dan42)
........
................
r38422 | kpfleming | 2006-07-28 14:59:59 -0400 (Fri, 28 Jul 2006) | 3 lines
move slinfactory structure definition back to header... it's just easier to use this way
add infrastructure for whispering onto a channel
................
r38439 | russell | 2006-07-28 15:17:56 -0400 (Fri, 28 Jul 2006) | 8 lines
As discussed and decided on the asterisk-dev mailing list ...
- Fix some breakage I introduced a while ago that made the timestamps option
not functional for CLI verbose output.
- Remove the use of the timestamps option for log output, since it was not
functional.
- clarify text referring to the timestamps option so that it is clear that it
only applies to CLI verbose output
................
Modified:
team/russell/ast_verbose_threadstorage/ (props changed)
team/russell/ast_verbose_threadstorage/asterisk.c
team/russell/ast_verbose_threadstorage/channel.c
team/russell/ast_verbose_threadstorage/channels/chan_sip.c
team/russell/ast_verbose_threadstorage/doc/asterisk-conf.txt
team/russell/ast_verbose_threadstorage/frame.c
team/russell/ast_verbose_threadstorage/include/asterisk/channel.h
team/russell/ast_verbose_threadstorage/include/asterisk/frame.h
team/russell/ast_verbose_threadstorage/include/asterisk/options.h
team/russell/ast_verbose_threadstorage/include/asterisk/slinfactory.h
team/russell/ast_verbose_threadstorage/logger.c
team/russell/ast_verbose_threadstorage/slinfactory.c
Propchange: team/russell/ast_verbose_threadstorage/
------------------------------------------------------------------------------
automerge = no
Propchange: team/russell/ast_verbose_threadstorage/
------------------------------------------------------------------------------
Binary property 'branch-1.2-merged' - no diff available.
Propchange: team/russell/ast_verbose_threadstorage/
------------------------------------------------------------------------------
--- svnmerge-integrated (original)
+++ svnmerge-integrated Fri Jul 28 14:29:12 2006
@@ -1,1 +1,1 @@
-/trunk:1-38398
+/trunk:1-38439
Modified: team/russell/ast_verbose_threadstorage/asterisk.c
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/asterisk.c?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/asterisk.c (original)
+++ team/russell/ast_verbose_threadstorage/asterisk.c Fri Jul 28 14:29:12 2006
@@ -2197,7 +2197,7 @@
/* verbose level (-v at startup) */
if (!strcasecmp(v->name, "verbose")) {
option_verbose = atoi(v->value);
- /* whether or not to force timestamping. (-T at startup) */
+ /* whether or not to force timestamping in CLI verbose output. (-T at startup) */
} else if (!strcasecmp(v->name, "timestamp")) {
ast_set2_flag(&ast_options, ast_true(v->value), AST_OPT_FLAG_TIMESTAMP);
/* whether or not to support #exec in config files */
Modified: team/russell/ast_verbose_threadstorage/channel.c
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/channel.c?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/channel.c (original)
+++ team/russell/ast_verbose_threadstorage/channel.c Fri Jul 28 14:29:12 2006
@@ -67,6 +67,7 @@
#include "asterisk/devicestate.h"
#include "asterisk/sha1.h"
#include "asterisk/threadstorage.h"
+#include "asterisk/slinfactory.h"
struct channel_spy_trans {
int last_format;
@@ -77,6 +78,12 @@
struct channel_spy_trans read_translator;
struct channel_spy_trans write_translator;
AST_LIST_HEAD_NOLOCK(, ast_channel_spy) list;
+};
+
+struct ast_channel_whisper_buffer {
+ ast_mutex_t lock;
+ struct ast_slinfactory sf;
+ unsigned int original_format;
};
/* uncomment if you have problems with 'monitoring' synchronized files */
@@ -969,13 +976,16 @@
ast_copy_string(name, chan->name, sizeof(name));
/* Stop monitoring */
- if (chan->monitor) {
+ if (chan->monitor)
chan->monitor->stop( chan, 0 );
- }
/* If there is native format music-on-hold state, free it */
- if(chan->music_state)
+ if (chan->music_state)
ast_moh_cleanup(chan);
+
+ /* if someone is whispering on the channel, stop them */
+ if (chan->whisper)
+ ast_channel_whisper_stop(chan);
/* Free translators */
if (chan->readtrans)
@@ -2427,6 +2437,25 @@
}
}
+ if (ast_test_flag(chan, AST_FLAG_WHISPER)) {
+ /* frame is assumed to be in SLINEAR, since that is
+ required for whisper mode */
+ ast_frame_adjust_volume(f, -2);
+ if (ast_slinfactory_available(&chan->whisper->sf) >= f->samples) {
+ short buf[f->samples];
+ struct ast_frame whisper = {
+ .frametype = AST_FRAME_VOICE,
+ .subclass = AST_FORMAT_SLINEAR,
+ .data = buf,
+ .datalen = sizeof(buf),
+ .samples = f->samples,
+ };
+
+ if (ast_slinfactory_read(&chan->whisper->sf, buf, f->samples))
+ ast_frame_slinear_sum(f, &whisper);
+ }
+ }
+
res = chan->tech->write(chan, f);
}
break;
@@ -3153,6 +3182,16 @@
if (x != AST_GENERATOR_FD)
original->fds[x] = clone->fds[x];
}
+
+ /* move any whisperer over */
+ ast_channel_whisper_stop(original);
+ if (ast_test_flag(clone, AST_FLAG_WHISPER)) {
+ original->whisper = clone->whisper;
+ ast_set_flag(original, AST_FLAG_WHISPER);
+ clone->whisper = NULL;
+ ast_clear_flag(clone, AST_FLAG_WHISPER);
+ }
+
/* Move data stores over */
if (AST_LIST_FIRST(&clone->datastores))
AST_LIST_INSERT_TAIL(&original->datastores, AST_LIST_FIRST(&clone->datastores), entry);
@@ -4383,4 +4422,43 @@
return ast_say_digit_str_full(chan, buf, ints, lang, audiofd, ctrlfd);
}
-/* end of file */
+int ast_channel_whisper_start(struct ast_channel *chan)
+{
+ if (chan->whisper)
+ return -1;
+
+ if (!(chan->whisper = ast_calloc(1, sizeof(*chan->whisper))))
+ return -1;
+
+ ast_mutex_init(&chan->whisper->lock);
+ ast_slinfactory_init(&chan->whisper->sf);
+ chan->whisper->original_format = ast_set_write_format(chan, AST_FORMAT_SLINEAR);
+ ast_set_flag(chan, AST_FLAG_WHISPER);
+
+ return 0;
+}
+
+int ast_channel_whisper_feed(struct ast_channel *chan, struct ast_frame *f)
+{
+ if (!chan->whisper)
+ return -1;
+
+ ast_mutex_lock(&chan->whisper->lock);
+ ast_slinfactory_feed(&chan->whisper->sf, f);
+ ast_mutex_unlock(&chan->whisper->lock);
+
+ return 0;
+}
+
+void ast_channel_whisper_stop(struct ast_channel *chan)
+{
+ if (!chan->whisper)
+ return;
+
+ ast_clear_flag(chan, AST_FLAG_WHISPER);
+ ast_set_write_format(chan, chan->whisper->original_format);
+ ast_slinfactory_destroy(&chan->whisper->sf);
+ ast_mutex_destroy(&chan->whisper->lock);
+ free(chan->whisper);
+ chan->whisper = NULL;
+}
Modified: team/russell/ast_verbose_threadstorage/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/channels/chan_sip.c?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/channels/chan_sip.c (original)
+++ team/russell/ast_verbose_threadstorage/channels/chan_sip.c Fri Jul 28 14:29:12 2006
@@ -8526,9 +8526,10 @@
int debug=sip_debug_test_addr(sin);
struct ast_variable *tmpvar = NULL, *v = NULL;
int usenatroute;
+ char *uri2 = ast_strdupa(uri);
/* Terminate URI */
- t = uri;
+ t = uri2;
while (*t && *t > 32 && *t != ';')
t++;
*t = '\0';
@@ -8548,7 +8549,7 @@
of = get_in_brackets(from);
if (ast_strlen_zero(p->exten)) {
- t = uri;
+ t = uri2;
if (!strncmp(t, "sip:", 4))
t+= 4;
ast_string_field_set(p, exten, t);
@@ -8621,7 +8622,7 @@
ast_log(LOG_DEBUG, "Setting NAT on UDPTL to %s\n", usenatroute ? "On" : "Off");
ast_udptl_setnat(p->udptl, usenatroute);
}
- if (!(res = check_auth(p, req, user->name, user->secret, user->md5secret, sipmethod, uri, reliable, ast_test_flag(req, SIP_PKT_IGNORE)))) {
+ if (!(res = check_auth(p, req, user->name, user->secret, user->md5secret, sipmethod, uri2, reliable, ast_test_flag(req, SIP_PKT_IGNORE)))) {
sip_cancel_destroy(p);
ast_copy_flags(&p->flags[0], &user->flags[0], SIP_FLAGS_TO_COPY);
ast_copy_flags(&p->flags[1], &user->flags[1], SIP_PAGE2_FLAGS_TO_COPY);
@@ -8748,7 +8749,7 @@
ast_string_field_free(p, peersecret);
ast_string_field_free(p, peermd5secret);
}
- if (!(res = check_auth(p, req, peer->name, p->peersecret, p->peermd5secret, sipmethod, uri, reliable, ast_test_flag(req, SIP_PKT_IGNORE)))) {
+ if (!(res = check_auth(p, req, peer->name, p->peersecret, p->peermd5secret, sipmethod, uri2, reliable, ast_test_flag(req, SIP_PKT_IGNORE)))) {
ast_copy_flags(&p->flags[0], &peer->flags[0], SIP_FLAGS_TO_COPY);
ast_copy_flags(&p->flags[1], &peer->flags[1], SIP_PAGE2_FLAGS_TO_COPY);
/* If we have a call limit, set flag */
Modified: team/russell/ast_verbose_threadstorage/doc/asterisk-conf.txt
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/doc/asterisk-conf.txt?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/doc/asterisk-conf.txt (original)
+++ team/russell/ast_verbose_threadstorage/doc/asterisk-conf.txt Fri Jul 28 14:29:12 2006
@@ -49,7 +49,7 @@
nocolor = yes | no ; Disable ANSI colors (-n)
dumpcore = yes | no ; Dump core on failure (-g)
quiet = yes | no ; Run quietly (-q)
-timestamp = yes | no ; Force timestamping on log entries to console (-T)
+timestamp = yes | no ; Force timestamping in CLI verbose output (-T)
runuser = asterisk ; User to run asterisk as (-U) NOTE: will require changes to
; directory and device permisions
rungroup = asterisk ; Group to run asterisk as (-G)
Modified: team/russell/ast_verbose_threadstorage/frame.c
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/frame.c?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/frame.c (original)
+++ team/russell/ast_verbose_threadstorage/frame.c Fri Jul 28 14:29:12 2006
@@ -359,7 +359,7 @@
return out;
}
-struct ast_frame *ast_frdup(struct ast_frame *f)
+struct ast_frame *ast_frdup(const struct ast_frame *f)
{
struct ast_frame *out;
int len, srclen = 0;
Modified: team/russell/ast_verbose_threadstorage/include/asterisk/channel.h
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/include/asterisk/channel.h?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/include/asterisk/channel.h (original)
+++ team/russell/ast_verbose_threadstorage/include/asterisk/channel.h Fri Jul 28 14:29:12 2006
@@ -268,6 +268,7 @@
};
struct ast_channel_spy_list;
+struct ast_channel_whisper_buffer;
#define DEBUGCHAN_FLAG 0x80000000
#define FRAMECOUNT_INC(x) ( ((x) & DEBUGCHAN_FLAG) | ((x++) & ~DEBUGCHAN_FLAG) )
@@ -382,6 +383,7 @@
int rawwriteformat; /*!< Raw write format */
struct ast_channel_spy_list *spies; /*!< Chan Spy stuff */
+ struct ast_channel_whisper_buffer *whisper; /*!< Whisper Paging buffer */
AST_LIST_ENTRY(ast_channel) chan_list; /*!< For easy linking */
struct ast_jb jb; /*!< The jitterbuffer state */
@@ -397,21 +399,20 @@
/*! \brief Channels have this property if they can create jitter; i.e. most VoIP channels */
#define AST_CHAN_TP_CREATESJITTER (1 << 1)
-/* This flag has been deprecated by the transfercapbilty data member in struct ast_channel */
-/* #define AST_FLAG_DIGITAL (1 << 0) */ /* if the call is a digital ISDN call */
#define AST_FLAG_DEFER_DTMF (1 << 1) /*!< if dtmf should be deferred */
#define AST_FLAG_WRITE_INT (1 << 2) /*!< if write should be interrupt generator */
#define AST_FLAG_BLOCKING (1 << 3) /*!< if we are blocking */
#define AST_FLAG_ZOMBIE (1 << 4) /*!< if we are a zombie */
#define AST_FLAG_EXCEPTION (1 << 5) /*!< if there is a pending exception */
#define AST_FLAG_MOH (1 << 6) /*!< XXX anthm promises me this will disappear XXX listening to moh */
-#define AST_FLAG_SPYING (1 << 7) /*!< XXX might also go away XXX is spying on someone */
+#define AST_FLAG_SPYING (1 << 7) /*!< is spying on someone */
#define AST_FLAG_NBRIDGE (1 << 8) /*!< is it in a native bridge */
#define AST_FLAG_IN_AUTOLOOP (1 << 9) /*!< the channel is in an auto-incrementing dialplan processor,
so when ->priority is set, it will get incremented before
- finding the next priority to run
- */
-#define AST_FLAG_OUTGOING (1 << 10) /*! Is this call outgoing */
+ finding the next priority to run */
+#define AST_FLAG_OUTGOING (1 << 10) /*!< Is this call outgoing */
+#define AST_FLAG_WHISPER (1 << 11) /*!< Is this channel being whispered on */
+
/* @} */
#define AST_FEATURE_PLAY_WARNING (1 << 0)
@@ -1277,6 +1278,38 @@
/*! \brief return an ast_variable list of channeltypes */
struct ast_variable *ast_channeltype_list(void);
+/*!
+ \brief Begin 'whispering' onto a channel
+ \param chan The channel to whisper onto
+ \return 0 for success, non-zero for failure
+
+ This function will add a whisper buffer onto a channel and set a flag
+ causing writes to the channel to reduce the volume level of the written
+ audio samples, and then to mix in audio from the whisper buffer if it
+ is available.
+
+ Note: This function performs no locking; you must hold the channel's lock before
+ calling this function.
+ */
+int ast_channel_whisper_start(struct ast_channel *chan);
+
+/*!
+ \brief Feed an audio frame into the whisper buffer on a channel
+ \param chan The channel to whisper onto
+ \return 0 for success, non-zero for failure
+ */
+int ast_channel_whisper_feed(struct ast_channel *chan, struct ast_frame *f);
+
+/*!
+ \brief Stop 'whispering' onto a channel
+ \param chan The channel to whisper onto
+ \return 0 for success, non-zero for failure
+
+ Note: This function performs no locking; you must hold the channel's lock before
+ calling this function.
+ */
+void ast_channel_whisper_stop(struct ast_channel *chan);
+
#if defined(__cplusplus) || defined(c_plusplus)
}
#endif
Modified: team/russell/ast_verbose_threadstorage/include/asterisk/frame.h
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/include/asterisk/frame.h?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/include/asterisk/frame.h (original)
+++ team/russell/ast_verbose_threadstorage/include/asterisk/frame.h Fri Jul 28 14:29:12 2006
@@ -354,7 +354,7 @@
*/
void ast_frfree(struct ast_frame *fr);
-/*! \brief Copies a frame
+/*! \brief Makes a frame independent of any static storage
* \param fr frame to act upon
* Take a frame, and if it's not been malloc'd, make a malloc'd copy
* and if the data hasn't been malloced then make the
@@ -366,10 +366,10 @@
/*! \brief Copies a frame
* \param fr frame to copy
- * Dupliates a frame -- should only rarely be used, typically frisolate is good enough
+ * Duplicates a frame -- should only rarely be used, typically frisolate is good enough
* \return Returns a frame on success, NULL on error
*/
-struct ast_frame *ast_frdup(struct ast_frame *fr);
+struct ast_frame *ast_frdup(const struct ast_frame *fr);
/*! \brief Reads a frame from an fd
* Read a frame from a stream or packet fd, as written by fd_write
Modified: team/russell/ast_verbose_threadstorage/include/asterisk/options.h
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/include/asterisk/options.h?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/include/asterisk/options.h (original)
+++ team/russell/ast_verbose_threadstorage/include/asterisk/options.h Fri Jul 28 14:29:12 2006
@@ -60,7 +60,7 @@
AST_OPT_FLAG_DUMP_CORE = (1 << 12),
/*! Cache sound files */
AST_OPT_FLAG_CACHE_RECORD_FILES = (1 << 13),
- /*! Display timestamp in log messages */
+ /*! Display timestamp in CLI verbose output */
AST_OPT_FLAG_TIMESTAMP = (1 << 14),
/*! Override config */
AST_OPT_FLAG_OVERRIDE_CONFIG = (1 << 15),
Modified: team/russell/ast_verbose_threadstorage/include/asterisk/slinfactory.h
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/include/asterisk/slinfactory.h?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/include/asterisk/slinfactory.h (original)
+++ team/russell/ast_verbose_threadstorage/include/asterisk/slinfactory.h Fri Jul 28 14:29:12 2006
@@ -27,7 +27,6 @@
#include <unistd.h>
#include <string.h>
-
#if defined(__cplusplus) || defined(c_plusplus)
extern "C" {
#endif
@@ -37,17 +36,16 @@
struct ast_trans_pvt *trans;
short hold[1280];
short *offset;
- size_t holdlen;
- int size;
- int format;
+ size_t holdlen; /*!< in samples */
+ unsigned int size; /*!< in samples */
+ unsigned int format;
};
void ast_slinfactory_init(struct ast_slinfactory *sf);
void ast_slinfactory_destroy(struct ast_slinfactory *sf);
int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f);
-int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t bytes);
-
-
+int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples);
+unsigned int ast_slinfactory_available(const struct ast_slinfactory *sf);
#if defined(__cplusplus) || defined(c_plusplus)
}
Modified: team/russell/ast_verbose_threadstorage/logger.c
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/logger.c?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/logger.c (original)
+++ team/russell/ast_verbose_threadstorage/logger.c Fri Jul 28 14:29:12 2006
@@ -740,9 +740,8 @@
if (level != __LOG_VERBOSE) {
int res;
sprintf(linestr, "%d", line);
-
ast_dynamic_str_threadbuild(&buf, BUFSIZ, &log_buf,
- ast_opt_timestamp ? "[%s] %s[%ld]: %s:%s %s: " : "%s %s[%ld]: %s:%s %s: ",
+ "[%s] %s[%ld]: %s:%s %s: ",
date,
term_color(tmp1, levels[level], colors[level], 0, sizeof(tmp1)),
(long)GETTID(),
@@ -762,7 +761,7 @@
} else if ((chan->logmask & (1 << level)) && (chan->fileptr)) {
int res;
ast_dynamic_str_threadbuild(&buf, BUFSIZ, &log_buf,
- ast_opt_timestamp ? "[%s] %s[%ld]: " : "%s %s[%ld] %s: ",
+ "[%s] %s[%ld] %s: ",
date, levels[level], (long)GETTID(), file);
res = fprintf(chan->fileptr, "%s", buf->str);
if (res <= 0 && !ast_strlen_zero(buf->str)) { /* Error, no characters printed */
@@ -848,6 +847,20 @@
int res;
va_list ap;
+ if (ast_opt_timestamp) {
+ time_t t;
+ struct tm tm;
+ char date[40];
+ char *datefmt;
+
+ time(&t);
+ localtime_r(&t, &tm);
+ strftime(date, sizeof(date), dateformat, &tm);
+ datefmt = alloca(strlen(date) + 3 + strlen(fmt) + 1);
+ sprintf(datefmt, "[%s] %s", date, fmt);
+ fmt = datefmt;
+ }
+
if (!(buf = ast_dynamic_str_threadget(&verbose_buf, VERBOSE_BUF_INIT_SIZE)))
return;
Modified: team/russell/ast_verbose_threadstorage/slinfactory.c
URL: http://svn.digium.com/view/asterisk/team/russell/ast_verbose_threadstorage/slinfactory.c?rev=38440&r1=38439&r2=38440&view=diff
==============================================================================
--- team/russell/ast_verbose_threadstorage/slinfactory.c (original)
+++ team/russell/ast_verbose_threadstorage/slinfactory.c Fri Jul 28 14:29:12 2006
@@ -30,14 +30,14 @@
#include <string.h>
+#include "asterisk/frame.h"
#include "asterisk/slinfactory.h"
#include "asterisk/logger.h"
#include "asterisk/translate.h"
-
void ast_slinfactory_init(struct ast_slinfactory *sf)
{
- memset(sf, 0, sizeof(struct ast_slinfactory));
+ memset(sf, 0, sizeof(*sf));
sf->offset = sf->hold;
sf->queue = NULL;
}
@@ -51,7 +51,7 @@
sf->trans = NULL;
}
- while((f = sf->queue)) {
+ while ((f = sf->queue)) {
sf->queue = f->next;
ast_frfree(f);
}
@@ -60,10 +60,7 @@
int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f)
{
struct ast_frame *frame, *frame_ptr;
-
- if (!f) {
- return 0;
- }
+ unsigned int x;
if (f->subclass != AST_FORMAT_SLINEAR) {
if (sf->trans && f->subclass != sf->format) {
@@ -80,52 +77,49 @@
}
}
- if (sf->trans) {
+ if (sf->trans)
frame = ast_translate(sf->trans, f, 0);
- } else {
+ else
frame = ast_frdup(f);
- }
- if (frame) {
- int x = 0;
- for (frame_ptr = sf->queue; frame_ptr && frame_ptr->next; frame_ptr = frame_ptr->next) {
- x++;
- }
- if (frame_ptr) {
- frame_ptr->next = frame;
- } else {
- sf->queue = frame;
- }
- frame->next = NULL;
- sf->size += frame->datalen;
- return x;
- }
+ if (!frame)
+ return 0;
- return 0;
-
+ for (x = 0, frame_ptr = sf->queue; frame_ptr && frame_ptr->next; frame_ptr = frame_ptr->next)
+ x++;
+
+ if (frame_ptr)
+ frame_ptr->next = frame;
+ else
+ sf->queue = frame;
+
+ frame->next = NULL;
+ sf->size += frame->samples;
+
+ return x;
}
-int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t bytes)
+int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples)
{
struct ast_frame *frame_ptr;
- int sofar = 0, ineed, remain;
+ unsigned int sofar = 0, ineed, remain;
short *frame_data, *offset = buf;
- while (sofar < bytes) {
- ineed = bytes - sofar;
+ while (sofar < samples) {
+ ineed = samples - sofar;
if (sf->holdlen) {
if ((sofar + sf->holdlen) <= ineed) {
- memcpy(offset, sf->hold, sf->holdlen);
+ memcpy(offset, sf->hold, sf->holdlen * sizeof(*offset));
sofar += sf->holdlen;
- offset += (sf->holdlen / sizeof(short));
+ offset += sf->holdlen;
sf->holdlen = 0;
sf->offset = sf->hold;
} else {
remain = sf->holdlen - ineed;
- memcpy(offset, sf->offset, ineed);
+ memcpy(offset, sf->offset, ineed * sizeof(*offset));
sofar += ineed;
- sf->offset += (ineed / sizeof(short));
+ sf->offset += ineed;
sf->holdlen = remain;
}
continue;
@@ -135,16 +129,16 @@
sf->queue = frame_ptr->next;
frame_data = frame_ptr->data;
- if ((sofar + frame_ptr->datalen) <= ineed) {
- memcpy(offset, frame_data, frame_ptr->datalen);
- sofar += frame_ptr->datalen;
- offset += (frame_ptr->datalen / sizeof(short));
+ if ((sofar + frame_ptr->samples) <= ineed) {
+ memcpy(offset, frame_data, frame_ptr->samples * sizeof(*offset));
+ sofar += frame_ptr->samples;
+ offset += frame_ptr->samples;
} else {
- remain = frame_ptr->datalen - ineed;
- memcpy(offset, frame_data, ineed);
+ remain = frame_ptr->samples - ineed;
+ memcpy(offset, frame_data, ineed * sizeof(*offset));
sofar += ineed;
- frame_data += (ineed / sizeof(short));
- memcpy(sf->hold, frame_data, remain);
+ frame_data += ineed;
+ memcpy(sf->hold, frame_data, remain * sizeof(*offset));
sf->holdlen = remain;
}
ast_frfree(frame_ptr);
@@ -156,3 +150,8 @@
sf->size -= sofar;
return sofar;
}
+
+unsigned int ast_slinfactory_available(const struct ast_slinfactory *sf)
+{
+ return sf->size;
+}
More information about the svn-commits
mailing list