diff options
author | Kevin P. Fleming <kpfleming@digium.com> | 2005-04-03 22:57:18 +0000 |
---|---|---|
committer | Kevin P. Fleming <kpfleming@digium.com> | 2005-04-03 22:57:18 +0000 |
commit | b96ae79baacf4012d524638c34f5eea97be426e5 (patch) | |
tree | 0377d7238fbc8640a0885f84f0b381aaef09d78c /channels/iax2-parser.c | |
parent | 7e3e619497db5bf939c16009e7a1e69d372d01a6 (diff) |
handle AST_FORMAT_SLINEAR endianness properly on big-endian systems (bug #3865)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@5373 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'channels/iax2-parser.c')
-rwxr-xr-x | channels/iax2-parser.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/channels/iax2-parser.c b/channels/iax2-parser.c index 3472b5008..f83e7413f 100755 --- a/channels/iax2-parser.c +++ b/channels/iax2-parser.c @@ -855,8 +855,15 @@ void iax_frame_wrap(struct iax_frame *fr, struct ast_frame *f) fr->af.delivery.tv_sec = 0; fr->af.delivery.tv_usec = 0; fr->af.data = fr->afdata; - if (fr->af.datalen) + if (fr->af.datalen) { +#if __BYTE_ORDER == __LITTLE_ENDIAN + /* We need to byte-swap slinear samples from network byte order */ + if (fr->af.subclass == AST_FORMAT_SLINEAR) { + ast_memcpy_byteswap(fr->af.data, f->data, fr->af.samples); + } else +#endif memcpy(fr->af.data, f->data, fr->af.datalen); + } } struct iax_frame *iax_frame_new(int direction, int datalen) |