mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-03 03:20:57 +00:00
Merged revisions 112125 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r112125 | file | 2008-04-01 13:45:14 -0300 (Tue, 01 Apr 2008) | 5 lines Ensure that we do not exceed the hold's maximum size with a single frame. (closes issue #12047) Reported by: fabianoheringer Tested by: fabianoheringer ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@112126 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -28,10 +28,12 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define AST_SLINFACTORY_MAX_HOLD 1280
|
||||
|
||||
struct ast_slinfactory {
|
||||
AST_LIST_HEAD_NOLOCK(, ast_frame) queue; /*!< A list of unaltered frames */
|
||||
struct ast_trans_pvt *trans; /*!< Translation path that converts fed frames into signed linear */
|
||||
short hold[1280]; /*!< Hold for audio that no longer belongs to a frame (ie: if only some samples were taken from a frame) */
|
||||
short hold[AST_SLINFACTORY_MAX_HOLD]; /*!< Hold for audio that no longer belongs to a frame (ie: if only some samples were taken from a frame) */
|
||||
short *offset; /*!< Offset into the hold where audio begins */
|
||||
size_t holdlen; /*!< Number of samples currently in the hold */
|
||||
unsigned int size; /*!< Number of samples currently in the factory */
|
||||
|
@@ -172,6 +172,9 @@ int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples)
|
||||
memcpy(offset, frame_data, ineed * sizeof(*offset));
|
||||
sofar += ineed;
|
||||
frame_data += ineed;
|
||||
if (remain > (AST_SLINFACTORY_MAX_HOLD - sf->holdlen)) {
|
||||
remain = AST_SLINFACTORY_MAX_HOLD - sf->holdlen;
|
||||
}
|
||||
memcpy(sf->hold, frame_data, remain * sizeof(*offset));
|
||||
sf->holdlen = remain;
|
||||
}
|
||||
|
Reference in New Issue
Block a user