summaryrefslogtreecommitdiffstats
path: root/libmpcodecs/ad_pcm.c
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-04-25 12:29:55 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-04-25 12:29:55 +0000
commita8b78d514924326cfff1cca164300a20144592c3 (patch)
tree4c11b266ecceb81adbb23c0568e8692efe2ce0f7 /libmpcodecs/ad_pcm.c
parent5cb32bfa63da870a9b8a4af7ca6bf823308af23b (diff)
downloadmpv-a8b78d514924326cfff1cca164300a20144592c3.tar.bz2
mpv-a8b78d514924326cfff1cca164300a20144592c3.tar.xz
bigendian fix - thx to Rogério Brito <linuxconsult@yahoo.com.br>
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@5828 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpcodecs/ad_pcm.c')
-rw-r--r--libmpcodecs/ad_pcm.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/libmpcodecs/ad_pcm.c b/libmpcodecs/ad_pcm.c
index a2efd63b10..13d77666e7 100644
--- a/libmpcodecs/ad_pcm.c
+++ b/libmpcodecs/ad_pcm.c
@@ -30,7 +30,7 @@ static int init(sh_audio_t *sh_audio)
case 0x11: sh_audio->sample_format=AFMT_IMA_ADPCM;break;
case 0x50: sh_audio->sample_format=AFMT_MPEG;break;
/* case 0x2000: sh_audio->sample_format=AFMT_AC3; */
- default: sh_audio->sample_format=(sh_audio->samplesize==2)?AFMT_S16_LE:AFMT_U8;
+ default: if(sh_audio->samplesize!=2) sh_audio->sample_format=AFMT_U8;
}
return 1;
}
@@ -64,7 +64,11 @@ static int decode_audio(sh_audio_t *sh_audio,unsigned char *buf,int minlen,int m
int len=sh_audio->channels*sh_audio->samplesize-1;
len=(minlen+len)&(~len); // sample align
len=demux_read_data(sh_audio->ds,buf,len);
+#ifdef WORDS_BIGENDIAN
+ if(sh_audio->format!=0x736F7774){
+#else
if(sh_audio->format==0x736F7774){ // "twos" is swapped byteorder
+#endif
int j;
for(j=0;j<len;j+=2){
char x=buf[j];