mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-05 04:11:08 +00:00
Revert adding the packed attribute, as it really doesn't make sense why that
would do any good. Fix the real bug, which is to do the check to see if the frame came from a translator at the beginning of ast_frame_free(), instead of at the end. This ensures that it always gets checked, even if none of the parts of the frame are malloc'd, and also ensures that we aren't looking at free'd memory in the case that it is a malloc'd frame. (closes issue #11792, reported by explidous, patched by me) git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@99081 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -149,7 +149,7 @@ struct ast_trans_pvt {
|
||||
struct ast_trans_pvt *next; /*!< next in translator chain */
|
||||
struct timeval nextin;
|
||||
struct timeval nextout;
|
||||
} attribute_packed;
|
||||
};
|
||||
|
||||
/*! \brief generic frameout function */
|
||||
struct ast_frame *ast_trans_frameout(struct ast_trans_pvt *pvt,
|
||||
|
@@ -334,6 +334,9 @@ static void frame_cache_cleanup(void *data)
|
||||
|
||||
void ast_frame_free(struct ast_frame *fr, int cache)
|
||||
{
|
||||
if (ast_test_flag(fr, AST_FRFLAG_FROM_TRANSLATOR))
|
||||
ast_translate_frame_freed(fr);
|
||||
|
||||
if (!fr->mallocd)
|
||||
return;
|
||||
|
||||
@@ -369,9 +372,6 @@ void ast_frame_free(struct ast_frame *fr, int cache)
|
||||
#endif
|
||||
free(fr);
|
||||
}
|
||||
|
||||
if (ast_test_flag(fr, AST_FRFLAG_FROM_TRANSLATOR))
|
||||
ast_translate_frame_freed(fr);
|
||||
}
|
||||
|
||||
/*!
|
||||
|
Reference in New Issue
Block a user