diff options
author | kpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-04-03 22:57:18 +0000 |
---|---|---|
committer | kpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-04-03 22:57:18 +0000 |
commit | 4ce1edc05cec917ad15513344d46fed1e35b6f58 (patch) | |
tree | 0377d7238fbc8640a0885f84f0b381aaef09d78c /channels/iax2-parser.c | |
parent | bbbb1d493dfcc49a639c0d6fda114322041a4f2b (diff) |
handle AST_FORMAT_SLINEAR endianness properly on big-endian systems (bug #3865)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5373 f38db490-d61c-443f-a65b-d21fe96a405b
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) |