Mercurial > mplayer.hg
annotate dec_audio.c @ 1528:a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
author | arpi |
---|---|
date | Wed, 15 Aug 2001 11:50:55 +0000 |
parents | 0e9c29538a86 |
children | 81aa2d701ae0 |
rev | line source |
---|---|
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
1 |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
2 #include <stdio.h> |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
3 #include <stdlib.h> |
1430 | 4 #include <unistd.h> |
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
5 |
1038
b36fb1ae4b53
applied solaris8/netbsd/other fixes patch by J¸«ärgen Keil <jk@tools.de>
arpi_esp
parents:
1020
diff
changeset
|
6 #include "config.h" |
1058 | 7 #include "libao2/afmt.h" |
758 | 8 |
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
9 extern int verbose; // defined in mplayer.c |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
10 |
732
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
11 #ifdef USE_FAKE_MONO |
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
12 int fakemono=0; |
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
13 #endif |
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
14 |
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
15 #include "stream.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
16 #include "demuxer.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
17 |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
18 #include "wine/mmreg.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
19 #include "wine/avifmt.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
20 #include "wine/vfw.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
21 |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
22 #include "codec-cfg.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
23 #include "stheader.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
24 |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
25 #include "mp3lib/mp3.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
26 #include "libac3/ac3.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
27 |
883 | 28 #include "alaw.h" |
29 | |
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
30 #include "xa/xa_gsm.h" |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
31 |
1528
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
32 #include "ac3-iec958.h" |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
33 |
1291 | 34 #ifdef USE_DIRECTSHOW |
604 | 35 #include "loader/DirectShow/DS_AudioDec.h" |
1291 | 36 #endif |
1038
b36fb1ae4b53
applied solaris8/netbsd/other fixes patch by J¸«ärgen Keil <jk@tools.de>
arpi_esp
parents:
1020
diff
changeset
|
37 |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
38 extern int init_acm_audio_codec(sh_audio_t *sh_audio); |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
39 extern int acm_decode_audio(sh_audio_t *sh_audio, void* a_buffer,int minlen,int maxlen); |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
40 |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
41 |
1289 | 42 static sh_audio_t* dec_audio_sh=NULL; |
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
43 |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
44 // AC3 decoder buffer callback: |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
45 static void ac3_fill_buffer(uint8_t **start,uint8_t **end){ |
1289 | 46 int len=ds_get_packet(dec_audio_sh->ds,start); |
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
47 //printf("<ac3:%d>\n",len); |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
48 if(len<0) |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
49 *start = *end = NULL; |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
50 else |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
51 *end = *start + len; |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
52 } |
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
53 |
1289 | 54 // MP3 decoder buffer callback: |
55 int mplayer_audio_read(char *buf,int size){ | |
56 int len; | |
57 len=demux_read_data(dec_audio_sh->ds,buf,size); | |
58 return len; | |
59 } | |
60 | |
296 | 61 int init_audio(sh_audio_t *sh_audio){ |
303 | 62 int driver=sh_audio->codec->driver; |
296 | 63 |
64 sh_audio->samplesize=2; | |
1320
18374d49befa
On big-endian architectures, all audio decoders default to big-endian 16-bit
jkeil
parents:
1313
diff
changeset
|
65 #if WORDS_BIGENDIAN |
18374d49befa
On big-endian architectures, all audio decoders default to big-endian 16-bit
jkeil
parents:
1313
diff
changeset
|
66 sh_audio->sample_format=AFMT_S16_BE; |
18374d49befa
On big-endian architectures, all audio decoders default to big-endian 16-bit
jkeil
parents:
1313
diff
changeset
|
67 #else |
758 | 68 sh_audio->sample_format=AFMT_S16_LE; |
1320
18374d49befa
On big-endian architectures, all audio decoders default to big-endian 16-bit
jkeil
parents:
1313
diff
changeset
|
69 #endif |
303 | 70 sh_audio->samplerate=0; |
401 | 71 //sh_audio->pcm_bswap=0; |
303 | 72 |
758 | 73 sh_audio->a_buffer_size=0; |
303 | 74 sh_audio->a_buffer=NULL; |
296 | 75 |
746 | 76 sh_audio->a_in_buffer_len=0; |
77 | |
758 | 78 // setup required min. in/out buffer size: |
79 sh_audio->audio_out_minsize=8192;// default size, maybe not enough for Win32/ACM | |
80 | |
81 switch(driver){ | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
82 case AFM_ACM: |
1517
0e9c29538a86
Use USE_WIN32DLL define instead of ARCH_X86 to decide whether or not to compile
jkeil
parents:
1485
diff
changeset
|
83 #ifndef USE_WIN32DLL |
0e9c29538a86
Use USE_WIN32DLL define instead of ARCH_X86 to decide whether or not to compile
jkeil
parents:
1485
diff
changeset
|
84 printf("Win32/ACM audio codec disabled, or unavailable on non-x86 CPU -> force nosound :(\n"); |
1309
598e3047ce13
Add some preliminary support for non-x86 architectures to mplayer
jkeil
parents:
1291
diff
changeset
|
85 driver=0; |
598e3047ce13
Add some preliminary support for non-x86 architectures to mplayer
jkeil
parents:
1291
diff
changeset
|
86 #else |
296 | 87 // Win32 ACM audio codec: |
88 if(init_acm_audio_codec(sh_audio)){ | |
746 | 89 sh_audio->i_bps=sh_audio->wf->nAvgBytesPerSec; |
296 | 90 sh_audio->channels=sh_audio->o_wf.nChannels; |
91 sh_audio->samplerate=sh_audio->o_wf.nSamplesPerSec; | |
758 | 92 // if(sh_audio->audio_out_minsize>16384) sh_audio->audio_out_minsize=16384; |
93 // sh_audio->a_buffer_size=sh_audio->audio_out_minsize; | |
94 // if(sh_audio->a_buffer_size<sh_audio->audio_out_minsize+MAX_OUTBURST) | |
95 // sh_audio->a_buffer_size=sh_audio->audio_out_minsize+MAX_OUTBURST; | |
296 | 96 } else { |
97 printf("Could not load/initialize Win32/ACM AUDIO codec (missing DLL file?)\n"); | |
303 | 98 driver=0; |
296 | 99 } |
1309
598e3047ce13
Add some preliminary support for non-x86 architectures to mplayer
jkeil
parents:
1291
diff
changeset
|
100 #endif |
758 | 101 break; |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
102 case AFM_DSHOW: |
296 | 103 #ifndef USE_DIRECTSHOW |
104 printf("Compiled without DirectShow support -> force nosound :(\n"); | |
303 | 105 driver=0; |
296 | 106 #else |
107 // Win32 DShow audio codec: | |
340 | 108 // printf("DShow_audio: channs=%d rate=%d\n",sh_audio->channels,sh_audio->samplerate); |
432
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
109 if(DS_AudioDecoder_Open(sh_audio->codec->dll,&sh_audio->codec->guid,sh_audio->wf)){ |
303 | 110 printf("ERROR: Could not load/initialize Win32/DirctShow AUDIO codec: %s\n",sh_audio->codec->dll); |
111 driver=0; | |
112 } else { | |
746 | 113 sh_audio->i_bps=sh_audio->wf->nAvgBytesPerSec; |
432
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
114 sh_audio->channels=sh_audio->wf->nChannels; |
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
115 sh_audio->samplerate=sh_audio->wf->nSamplesPerSec; |
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
116 sh_audio->audio_in_minsize=2*sh_audio->wf->nBlockAlign; |
296 | 117 if(sh_audio->audio_in_minsize<8192) sh_audio->audio_in_minsize=8192; |
118 sh_audio->a_in_buffer_size=sh_audio->audio_in_minsize; | |
119 sh_audio->a_in_buffer=malloc(sh_audio->a_in_buffer_size); | |
120 sh_audio->a_in_buffer_len=0; | |
758 | 121 sh_audio->audio_out_minsize=16384; |
296 | 122 } |
123 #endif | |
758 | 124 break; |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
125 case AFM_PCM: |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
126 case AFM_DVDPCM: |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
127 case AFM_ALAW: |
758 | 128 // PCM, aLaw |
129 sh_audio->audio_out_minsize=2048; | |
130 break; | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
131 case AFM_AC3: |
758 | 132 // Dolby AC3 audio: |
133 sh_audio->audio_out_minsize=4*256*6; | |
134 break; | |
1528
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
135 case AFM_HWAC3: |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
136 // Dolby AC3 audio: |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
137 sh_audio->audio_out_minsize=4*256*6; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
138 sh_audio->sample_format = AFMT_AC3; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
139 break; |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
140 case AFM_GSM: |
758 | 141 // MS-GSM audio codec: |
142 sh_audio->audio_out_minsize=4*320; | |
143 break; | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
144 case AFM_MPEG: |
758 | 145 // MPEG Audio: |
146 sh_audio->audio_out_minsize=4608; | |
147 break; | |
296 | 148 } |
149 | |
303 | 150 if(!driver) return 0; |
296 | 151 |
152 // allocate audio out buffer: | |
758 | 153 sh_audio->a_buffer_size=sh_audio->audio_out_minsize+MAX_OUTBURST; // worst case calc. |
154 | |
1456
8c57a5a3c645
printfs cleanup - moved to higher -v level or moved to stderr
arpi
parents:
1430
diff
changeset
|
155 if(verbose) printf("dec_audio: Allocating %d + %d = %d bytes for output buffer\n", |
758 | 156 sh_audio->audio_out_minsize,MAX_OUTBURST,sh_audio->a_buffer_size); |
157 | |
296 | 158 sh_audio->a_buffer=malloc(sh_audio->a_buffer_size); |
758 | 159 if(!sh_audio->a_buffer){ |
1456
8c57a5a3c645
printfs cleanup - moved to higher -v level or moved to stderr
arpi
parents:
1430
diff
changeset
|
160 fprintf(stderr,"Cannot allocate audio out buffer\n"); |
758 | 161 return 0; |
162 } | |
296 | 163 memset(sh_audio->a_buffer,0,sh_audio->a_buffer_size); |
164 sh_audio->a_buffer_len=0; | |
165 | |
303 | 166 switch(driver){ |
1517
0e9c29538a86
Use USE_WIN32DLL define instead of ARCH_X86 to decide whether or not to compile
jkeil
parents:
1485
diff
changeset
|
167 #ifdef USE_WIN32DLL |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
168 case AFM_ACM: { |
758 | 169 int ret=acm_decode_audio(sh_audio,sh_audio->a_buffer,4096,sh_audio->a_buffer_size); |
296 | 170 if(ret<0){ |
303 | 171 printf("ACM decoding error: %d\n",ret); |
172 driver=0; | |
296 | 173 } |
640 | 174 sh_audio->a_buffer_len=ret; |
303 | 175 break; |
296 | 176 } |
1309
598e3047ce13
Add some preliminary support for non-x86 architectures to mplayer
jkeil
parents:
1291
diff
changeset
|
177 #endif |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
178 case AFM_PCM: { |
296 | 179 // AVI PCM Audio: |
432
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
180 WAVEFORMATEX *h=sh_audio->wf; |
746 | 181 sh_audio->i_bps=h->nAvgBytesPerSec; |
296 | 182 sh_audio->channels=h->nChannels; |
183 sh_audio->samplerate=h->nSamplesPerSec; | |
184 sh_audio->samplesize=(h->wBitsPerSample+7)/8; | |
758 | 185 switch(sh_audio->format){ // hardware formats: |
186 case 0x6: sh_audio->sample_format=AFMT_A_LAW;break; | |
187 case 0x7: sh_audio->sample_format=AFMT_MU_LAW;break; | |
188 case 0x11: sh_audio->sample_format=AFMT_IMA_ADPCM;break; | |
189 case 0x50: sh_audio->sample_format=AFMT_MPEG;break; | |
190 // case 0x2000: sh_audio->sample_format=AFMT_AC3; | |
191 default: sh_audio->sample_format=(sh_audio->samplesize==2)?AFMT_S16_LE:AFMT_U8; | |
192 } | |
401 | 193 break; |
194 } | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
195 case AFM_DVDPCM: { |
401 | 196 // DVD PCM Audio: |
197 sh_audio->channels=2; | |
198 sh_audio->samplerate=48000; | |
746 | 199 sh_audio->i_bps=2*2*48000; |
296 | 200 // sh_audio->pcm_bswap=1; |
303 | 201 break; |
202 } | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
203 case AFM_AC3: { |
296 | 204 // Dolby AC3 audio: |
1289 | 205 dec_audio_sh=sh_audio; // save sh_audio for the callback: |
296 | 206 ac3_config.fill_buffer_callback = ac3_fill_buffer; |
207 ac3_config.num_output_ch = 2; | |
208 ac3_config.flags = 0; | |
209 #ifdef HAVE_MMX | |
210 ac3_config.flags |= AC3_MMX_ENABLE; | |
211 #endif | |
212 #ifdef HAVE_3DNOW | |
213 ac3_config.flags |= AC3_3DNOW_ENABLE; | |
214 #endif | |
215 ac3_init(); | |
216 sh_audio->ac3_frame = ac3_decode_frame(); | |
217 if(sh_audio->ac3_frame){ | |
746 | 218 ac3_frame_t* fr=(ac3_frame_t*)sh_audio->ac3_frame; |
219 sh_audio->samplerate=fr->sampling_rate; | |
296 | 220 sh_audio->channels=2; |
746 | 221 // 1 frame: 6*256 samples 1 sec: sh_audio->samplerate samples |
222 //sh_audio->i_bps=fr->frame_size*fr->sampling_rate/(6*256); | |
223 sh_audio->i_bps=fr->bit_rate*(1000/8); | |
303 | 224 } else { |
225 driver=0; // bad frame -> disable audio | |
226 } | |
227 break; | |
228 } | |
1528
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
229 case AFM_HWAC3: { |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
230 unsigned char *buffer; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
231 struct hwac3info ai; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
232 int len, skipped; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
233 len = ds_get_packet(sh_audio->ds, &buffer); |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
234 if(ac3_iec958_parse_syncinfo(buffer, len, &ai, &skipped) < 0) { |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
235 fprintf(stderr, "AC3 stream not valid.\n"); |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
236 driver = 0; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
237 break; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
238 } |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
239 if(ai.samplerate != 48000) { |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
240 fprintf(stderr, "Only 48000 Hz streams supported.\n"); |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
241 driver = 0; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
242 break; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
243 } |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
244 sh_audio->samplerate=ai.samplerate; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
245 // sh_audio->samplesize=ai.framesize; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
246 sh_audio->channels=1; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
247 sh_audio->i_bps=ai.bitrate*(1000/8); |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
248 sh_audio->ac3_frame=malloc(6144); |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
249 break; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
250 } |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
251 case AFM_ALAW: { |
296 | 252 // aLaw audio codec: |
432
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
253 sh_audio->channels=sh_audio->wf->nChannels; |
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
254 sh_audio->samplerate=sh_audio->wf->nSamplesPerSec; |
746 | 255 sh_audio->i_bps=sh_audio->channels*sh_audio->samplerate; |
303 | 256 break; |
257 } | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
258 case AFM_GSM: { |
296 | 259 // MS-GSM audio codec: |
260 GSM_Init(); | |
432
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
261 sh_audio->channels=sh_audio->wf->nChannels; |
5251b0c57e39
sh_audio->wf and sh_video->bih changed to dynamic (thanx to Jens Hoffmann)
arpi_esp
parents:
401
diff
changeset
|
262 sh_audio->samplerate=sh_audio->wf->nSamplesPerSec; |
746 | 263 // decodes 65 byte -> 320 short |
264 // 1 sec: sh_audio->channels*sh_audio->samplerate samples | |
265 // 1 frame: 320 samples | |
266 sh_audio->i_bps=65*(sh_audio->channels*sh_audio->samplerate)/320; // 1:10 | |
303 | 267 break; |
296 | 268 } |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
269 case AFM_MPEG: { |
296 | 270 // MPEG Audio: |
1289 | 271 dec_audio_sh=sh_audio; // save sh_audio for the callback: |
732
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
272 #ifdef USE_FAKE_MONO |
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
273 MP3_Init(fakemono); |
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
274 #else |
296 | 275 MP3_Init(); |
732
e14114170e01
applied 'fakemono' patch by Bryan Chan scorpio@acm.org
arpi_esp
parents:
640
diff
changeset
|
276 #endif |
296 | 277 MP3_samplerate=MP3_channels=0; |
278 // printf("[\n"); | |
279 sh_audio->a_buffer_len=MP3_DecodeFrame(sh_audio->a_buffer,-1); | |
280 // printf("]\n"); | |
281 sh_audio->channels=2; // hack | |
282 sh_audio->samplerate=MP3_samplerate; | |
746 | 283 sh_audio->i_bps=MP3_bitrate*(1000/8); |
303 | 284 break; |
285 } | |
296 | 286 } |
287 | |
288 if(!sh_audio->channels || !sh_audio->samplerate){ | |
289 printf("Unknown/missing audio format, using nosound\n"); | |
303 | 290 driver=0; |
296 | 291 } |
292 | |
303 | 293 if(!driver){ |
294 if(sh_audio->a_buffer) free(sh_audio->a_buffer); | |
1313
d797ecb9778f
sh_audio->a_buffer is freed twice (here and in mplayer.c), can result to
jkeil
parents:
1309
diff
changeset
|
295 sh_audio->a_buffer=NULL; |
303 | 296 sh_audio->o_bps=0; |
297 return 0; | |
298 } | |
296 | 299 |
303 | 300 sh_audio->o_bps=sh_audio->channels*sh_audio->samplerate*sh_audio->samplesize; |
301 return driver; | |
296 | 302 } |
291 | 303 |
746 | 304 // Audio decoding: |
291 | 305 |
746 | 306 // Decode a single frame (mp3,acm etc) or 'minlen' bytes (pcm/alaw etc) |
307 // buffer length is 'maxlen' bytes, it shouldn't be exceeded... | |
308 | |
309 int decode_audio(sh_audio_t *sh_audio,unsigned char *buf,int minlen,int maxlen){ | |
291 | 310 int len=-1; |
303 | 311 switch(sh_audio->codec->driver){ |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
312 case AFM_MPEG: // MPEG layer 2 or 3 |
291 | 313 len=MP3_DecodeFrame(buf,-1); |
1485
b895f95e7657
AVI demuxer cleanups, fileformat-dependent stuff moved to priv_t
arpi
parents:
1456
diff
changeset
|
314 // len=MP3_DecodeFrame(buf,3); |
291 | 315 break; |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
316 case AFM_PCM: // AVI PCM |
1058 | 317 len=demux_read_data(sh_audio->ds,buf,minlen); |
401 | 318 break; |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
319 case AFM_DVDPCM: // DVD PCM |
401 | 320 { int j; |
746 | 321 len=demux_read_data(sh_audio->ds,buf,minlen); |
291 | 322 //if(i&1){ printf("Warning! pcm_audio_size&1 !=0 (%d)\n",i);i&=~1; } |
746 | 323 // swap endian: |
291 | 324 for(j=0;j<len;j+=2){ |
325 char x=buf[j]; | |
326 buf[j]=buf[j+1]; | |
327 buf[j+1]=x; | |
328 } | |
329 break; | |
330 } | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
331 case AFM_ALAW: // aLaw decoder |
746 | 332 { int l=demux_read_data(sh_audio->ds,buf,minlen/2); |
291 | 333 unsigned short *d=(unsigned short *) buf; |
334 unsigned char *s=buf; | |
335 len=2*l; | |
758 | 336 if(sh_audio->format==6){ |
337 // aLaw | |
883 | 338 while(l>0){ --l; d[l]=alaw2short[s[l]]; } |
758 | 339 } else { |
340 // uLaw | |
883 | 341 while(l>0){ --l; d[l]=ulaw2short[s[l]]; } |
291 | 342 } |
343 break; | |
344 } | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
345 case AFM_GSM: // MS-GSM decoder |
291 | 346 { unsigned char buf[65]; // 65 bytes / frame |
746 | 347 if(demux_read_data(sh_audio->ds,buf,65)!=65) break; // EOF |
348 XA_MSGSM_Decoder(buf,(unsigned short *) buf); // decodes 65 byte -> 320 short | |
349 // XA_GSM_Decoder(buf,(unsigned short *) &sh_audio->a_buffer[sh_audio->a_buffer_len]); // decodes 33 byte -> 160 short | |
350 len=2*320; | |
291 | 351 break; |
352 } | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
353 case AFM_AC3: // AC3 decoder |
291 | 354 //printf("{1:%d}",avi_header.idx_pos);fflush(stdout); |
355 if(!sh_audio->ac3_frame) sh_audio->ac3_frame=ac3_decode_frame(); | |
356 //printf("{2:%d}",avi_header.idx_pos);fflush(stdout); | |
357 if(sh_audio->ac3_frame){ | |
296 | 358 len = 256 * 6 *sh_audio->channels*sh_audio->samplesize; |
587
8511095c5283
stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents:
432
diff
changeset
|
359 memcpy(buf,((ac3_frame_t*)sh_audio->ac3_frame)->audio_data,len); |
291 | 360 sh_audio->ac3_frame=NULL; |
361 } | |
362 //printf("{3:%d}",avi_header.idx_pos);fflush(stdout); | |
363 break; | |
1528
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
364 case AFM_HWAC3: // AC3 through SPDIF |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
365 if(demux_read_data(sh_audio->ds,sh_audio->ac3_frame, 6144) != 6144) |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
366 break; //EOF |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
367 ac3_iec958_build_burst(1536, 0x1F, 1, buf, sh_audio->ac3_frame); |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
368 len = 6144; |
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
369 break; |
1517
0e9c29538a86
Use USE_WIN32DLL define instead of ARCH_X86 to decide whether or not to compile
jkeil
parents:
1485
diff
changeset
|
370 #ifdef USE_WIN32DLL |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
371 case AFM_ACM: |
758 | 372 // len=sh_audio->audio_out_minsize; // optimal decoded fragment size |
373 // if(len<minlen) len=minlen; else | |
374 // if(len>maxlen) len=maxlen; | |
375 // len=acm_decode_audio(sh_audio,buf,len); | |
376 len=acm_decode_audio(sh_audio,buf,minlen,maxlen); | |
291 | 377 break; |
1309
598e3047ce13
Add some preliminary support for non-x86 architectures to mplayer
jkeil
parents:
1291
diff
changeset
|
378 #endif |
746 | 379 |
291 | 380 #ifdef USE_DIRECTSHOW |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
381 case AFM_DSHOW: // DirectShow |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
382 { int size_in=0; |
291 | 383 int size_out=0; |
384 int srcsize=DS_AudioDecoder_GetSrcSize(maxlen); | |
385 if(verbose>2)printf("DShow says: srcsize=%d (buffsize=%d) out_size=%d\n",srcsize,sh_audio->a_in_buffer_size,maxlen); | |
386 if(srcsize>sh_audio->a_in_buffer_size) srcsize=sh_audio->a_in_buffer_size; // !!!!!! | |
387 if(sh_audio->a_in_buffer_len<srcsize){ | |
388 sh_audio->a_in_buffer_len+= | |
389 demux_read_data(sh_audio->ds,&sh_audio->a_in_buffer[sh_audio->a_in_buffer_len], | |
390 srcsize-sh_audio->a_in_buffer_len); | |
391 } | |
392 DS_AudioDecoder_Convert(sh_audio->a_in_buffer,sh_audio->a_in_buffer_len, | |
393 buf,maxlen, &size_in,&size_out); | |
754 | 394 if(verbose) |
395 printf("DShow: audio %d -> %d converted (in_buf_len=%d of %d) %d\n",size_in,size_out,sh_audio->a_in_buffer_len,sh_audio->a_in_buffer_size,ds_tell_pts(sh_audio->ds)); | |
291 | 396 if(size_in>=sh_audio->a_in_buffer_len){ |
397 sh_audio->a_in_buffer_len=0; | |
398 } else { | |
399 sh_audio->a_in_buffer_len-=size_in; | |
400 memcpy(sh_audio->a_in_buffer,&sh_audio->a_in_buffer[size_in],sh_audio->a_in_buffer_len); | |
401 } | |
402 len=size_out; | |
403 break; | |
404 } | |
405 #endif | |
406 } | |
407 return len; | |
408 } | |
409 | |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
410 void resync_audio_stream(sh_audio_t *sh_audio){ |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
411 switch(sh_audio->codec->driver){ |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
412 case AFM_MPEG: |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
413 MP3_DecodeFrame(NULL,-2); // resync |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
414 MP3_DecodeFrame(NULL,-2); // resync |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
415 MP3_DecodeFrame(NULL,-2); // resync |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
416 break; |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
417 case AFM_AC3: |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
418 ac3_bitstream_reset(); // reset AC3 bitstream buffer |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
419 // if(verbose){ printf("Resyncing AC3 audio...");fflush(stdout);} |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
420 sh_audio->ac3_frame=ac3_decode_frame(); // resync |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
421 // if(verbose) printf(" OK!\n"); |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
422 break; |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
423 case AFM_ACM: |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
424 case AFM_DSHOW: |
1528
a444bd456fcc
ac3/spdif patch by German Gomez Garcia <german@piraos.com>
arpi
parents:
1517
diff
changeset
|
425 case AFM_HWAC3: |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
426 sh_audio->a_in_buffer_len=0; // reset ACM/DShow audio buffer |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
427 break; |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
428 } |
1408 | 429 |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
430 } |
291 | 431 |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
432 void skip_audio_frame(sh_audio_t *sh_audio){ |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
433 switch(sh_audio->codec->driver){ |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
434 case AFM_MPEG: MP3_DecodeFrame(NULL,-2);break; // skip MPEG frame |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
435 case AFM_AC3: sh_audio->ac3_frame=ac3_decode_frame();break; // skip AC3 frame |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
436 case AFM_ACM: |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
437 case AFM_DSHOW: { |
1408 | 438 int skip=sh_audio->wf->nBlockAlign; |
439 if(skip<16){ | |
440 skip=(sh_audio->wf->nAvgBytesPerSec/16)&(~7); | |
441 if(skip<16) skip=16; | |
442 } | |
443 demux_read_data(sh_audio->ds,NULL,skip); | |
444 break; | |
445 } | |
1410
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
446 case AFM_PCM: |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
447 case AFM_DVDPCM: |
eda16e490ae7
using AFM_/VFM_ macros instead of hardcoded constants (idea by al3x)
arpi
parents:
1408
diff
changeset
|
448 case AFM_ALAW: { |
1408 | 449 int skip=sh_audio->i_bps/16; |
450 skip=skip&(~3); | |
451 demux_read_data(sh_audio->ds,NULL,skip); | |
452 break; | |
453 } | |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
454 default: ds_fill_buffer(sh_audio->ds); // skip PCM frame |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
455 } |
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1320
diff
changeset
|
456 } |