aboutsummaryrefslogtreecommitdiffstats
path: root/main/translate.c
diff options
context:
space:
mode:
authorrussell <russell@f38db490-d61c-443f-a65b-d21fe96a405b>2009-10-21 16:42:13 +0000
committerrussell <russell@f38db490-d61c-443f-a65b-d21fe96a405b>2009-10-21 16:42:13 +0000
commit9a8be3b582156f007d9d86e8d5de2133f3056eff (patch)
treeb9c7fb7497a726060bc047a434aac204aef492ee /main/translate.c
parent09e751b29b76038ba3a98910c20d184ab674eba7 (diff)
Merged revisions 225169 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r225169 | russell | 2009-10-21 11:39:20 -0500 (Wed, 21 Oct 2009) | 2 lines Isolate the frame returned from ast_translate(). ........ git-svn-id: http://svn.digium.com/svn/asterisk/trunk@225170 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main/translate.c')
-rw-r--r--main/translate.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/main/translate.c b/main/translate.c
index a4a915291..223b5d30e 100644
--- a/main/translate.c
+++ b/main/translate.c
@@ -295,7 +295,7 @@ struct ast_trans_pvt *ast_translator_build_path(int dest, int source)
struct ast_frame *ast_translate(struct ast_trans_pvt *path, struct ast_frame *f, int consume)
{
struct ast_trans_pvt *p = path;
- struct ast_frame *out = f;
+ struct ast_frame *out = f, *ret;
struct timeval delivery;
int has_timing_info;
long ts;
@@ -364,7 +364,11 @@ struct ast_frame *ast_translate(struct ast_trans_pvt *path, struct ast_frame *f,
/* Invalidate prediction if we're entering a silence period */
if (out->frametype == AST_FRAME_CNG)
path->nextout = ast_tv(0, 0);
- return out;
+
+ ret = ast_frisolate(out);
+ ast_frfree(out);
+
+ return ret;
}
/*! \brief compute the cost of a single translation step */