summaryrefslogtreecommitdiffstats
path: root/libmpcodecs
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-09-15 21:23:59 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-09-15 21:23:59 +0000
commitbb8a55c4f8b1c468b033b6838242966a0f8666f6 (patch)
tree628a24cac874cba3fd67dfcfbe829020316ab795 /libmpcodecs
parenta3d81b74f97c354e3b9b0842c5e17dab46eb55ca (diff)
downloadmpv-bb8a55c4f8b1c468b033b6838242966a0f8666f6.tar.bz2
mpv-bb8a55c4f8b1c468b033b6838242966a0f8666f6.tar.xz
standard GSM support for .mov files
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@7411 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpcodecs')
-rw-r--r--libmpcodecs/ad_msgsm.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/libmpcodecs/ad_msgsm.c b/libmpcodecs/ad_msgsm.c
index a4dbe122df..141f153494 100644
--- a/libmpcodecs/ad_msgsm.c
+++ b/libmpcodecs/ad_msgsm.c
@@ -7,7 +7,7 @@
static ad_info_t info =
{
- "native MSGSM audio decoder",
+ "native GSM/MSGSM audio decoder",
"msgsm",
"A'rpi",
"XAnim",
@@ -28,7 +28,12 @@ static int init(sh_audio_t *sh_audio)
// decodes 65 byte -> 320 short
// 1 sec: sh_audio->channels*sh_audio->samplerate samples
// 1 frame: 320 samples
- sh_audio->i_bps=65*(sh_audio->channels*sh_audio->samplerate)/320; // 1:10
+ if(sh_audio->format==0x31 || sh_audio->format==0x32){
+ sh_audio->ds->ss_mul=65; sh_audio->ds->ss_div=320;
+ } else {
+ sh_audio->ds->ss_mul=33; sh_audio->ds->ss_div=160;
+ }
+ sh_audio->i_bps=sh_audio->ds->ss_mul*(sh_audio->channels*sh_audio->samplerate)/sh_audio->ds->ss_div; // 1:10
return 1;
}
@@ -49,8 +54,15 @@ static int control(sh_audio_t *sh,int cmd,void* arg, ...)
static int decode_audio(sh_audio_t *sh_audio,unsigned char *buf,int minlen,int maxlen)
{
+ if(sh_audio->format==0x31 || sh_audio->format==0x32){
unsigned char ibuf[65]; // 65 bytes / frame
if(demux_read_data(sh_audio->ds,ibuf,65)!=65) return -1; // EOF
XA_MSGSM_Decoder(ibuf,(unsigned short *) buf); // decodes 65 byte -> 320 short
return 2*320;
+ } else {
+ unsigned char ibuf[33]; // 33 bytes / frame
+ if(demux_read_data(sh_audio->ds,ibuf,33)!=33) return -1; // EOF
+ XA_GSM_Decoder(ibuf,(unsigned short *) buf); // decodes 33 byte -> 160 short
+ return 2*160;
+ }
}