1
mirror of https://github.com/mpv-player/mpv synced 2025-07-27 19:38:10 +02:00
Files
DOCS
TOOLS
debian
drivers
etc
ffmpeg_files
help
input
liba52
libaf
libao2
libdvdcss
libfaad2
libmenu
libmpcodecs
native
ad.c
ad.h
ad_acm.c
ad_alaw.c
ad_dk3adpcm.c
ad_dmo.c
ad_dshow.c
ad_dvdpcm.c
ad_faad.c
ad_ffmpeg.c
ad_hwac3.c
ad_hwmpa.c
ad_imaadpcm.c
ad_internal.h
ad_liba52.c
ad_libdca.c
ad_libdv.c
ad_libmad.c
ad_libvorbis.c
ad_mp3lib.c
ad_mpc.c
ad_msadpcm.c
ad_msgsm.c
ad_pcm.c
ad_qtaudio.c
ad_realaud.c
ad_sample.c
ad_speex.c
ad_twin.c
ae.c
ae.h
ae_faac.c
ae_faac.h
ae_lame.c
ae_lame.h
ae_lavc.c
ae_lavc.h
ae_pcm.c
ae_pcm.h
ae_toolame.c
ae_toolame.h
ae_twolame.c
ae_twolame.h
cmmx.h
dec_audio.c
dec_audio.h
dec_video.c
dec_video.h
img_format.c
img_format.h
mp_image.c
mp_image.h
mpc_info.h
pullup.c
pullup.h
vd.c
vd.h
vd_dmo.c
vd_dshow.c
vd_ffmpeg.c
vd_hmblck.c
vd_ijpg.c
vd_internal.h
vd_libdv.c
vd_libmpeg2.c
vd_lzo.c
vd_mpegpes.c
vd_mpng.c
vd_mtga.c
vd_null.c
vd_qtvideo.c
vd_raw.c
vd_realvid.c
vd_sgi.c
vd_theora.c
vd_vfw.c
vd_vfwex.c
vd_xanim.c
vd_xvid4.c
vd_zrmjpeg.c
ve.c
ve_lavc.c
ve_libdv.c
ve_nuv.c
ve_qtvideo.c
ve_raw.c
ve_vfw.c
ve_x264.c
ve_xvid4.c
vf.c
vf.h
vf_1bpp.c
vf_2xsai.c
vf_ass.c
vf_blackframe.c
vf_bmovl.c
vf_boxblur.c
vf_crop.c
vf_cropdetect.c
vf_decimate.c
vf_delogo.c
vf_denoise3d.c
vf_detc.c
vf_dint.c
vf_divtc.c
vf_down3dright.c
vf_dsize.c
vf_dvbscale.c
vf_eq.c
vf_eq2.c
vf_expand.c
vf_field.c
vf_fil.c
vf_filmdint.c
vf_flip.c
vf_format.c
vf_framestep.c
vf_fspp.c
vf_geq.c
vf_gradfun.c
vf_halfpack.c
vf_harddup.c
vf_hqdn3d.c
vf_hue.c
vf_il.c
vf_ilpack.c
vf_ivtc.c
vf_kerndeint.c
vf_lavc.c
vf_lavcdeint.c
vf_mcdeint.c
vf_mirror.c
vf_noformat.c
vf_noise.c
vf_ow.c
vf_palette.c
vf_perspective.c
vf_phase.c
vf_pp.c
vf_pp7.c
vf_pullup.c
vf_qp.c
vf_rectangle.c
vf_remove_logo.c
vf_rgb2bgr.c
vf_rgbtest.c
vf_rotate.c
vf_sab.c
vf_scale.c
vf_scale.h
vf_screenshot.c
vf_smartblur.c
vf_softpulldown.c
vf_softskip.c
vf_spp.c
vf_swapuv.c
vf_telecine.c
vf_test.c
vf_tfields.c
vf_tile.c
vf_tinterlace.c
vf_unsharp.c
vf_uspp.c
vf_vo.c
vf_yadif.c
vf_yuvcsp.c
vf_yuy2.c
vf_yvu9.c
vf_zrmjpeg.c
vfcap.h
vqf.h
libmpdemux
libmpeg2
libvo
loader
mp3lib
osdep
rpm
stream
tremor
vidix
.gitignore
AUTHORS
Changelog
Copyright
LICENSE
Makefile
README
access_mpcontext.h
ass_mp.c
ass_mp.h
asxparser.c
asxparser.h
av_opts.c
av_opts.h
cfg-common-opts.h
cfg-common.h
cfg-mencoder.h
cfg-mplayer-def.h
cfg-mplayer.h
codec-cfg.c
codec-cfg.h
command.c
command.h
configure
cpudetect.c
cpudetect.h
cpuinfo.c
defaultopts.c
defaultopts.h
edl.c
edl.h
find_sub.c
fmt-conversion.c
fmt-conversion.h
get_path.c
get_path.h
m_config.c
m_config.h
m_option.c
m_option.h
m_property.c
m_property.h
m_struct.c
m_struct.h
mangle.h
mencoder.c
metadata.h
mixer.c
mixer.h
mp_core.h
mp_fifo.c
mp_fifo.h
mp_msg-mencoder.c
mp_msg.c
mp_msg.h
mp_osd.h
mpbswap.h
mpcommon.c
mpcommon.h
mplayer.c
mplayer.h
options.h
parser-cfg.c
parser-cfg.h
parser-mecmd.c
parser-mecmd.h
parser-mpcmd.c
parser-mpcmd.h
playtree.c
playtree.h
playtreeparser.c
playtreeparser.h
spudec.c
spudec.h
sub_cc.c
sub_cc.h
subopt-helper.c
subopt-helper.h
subreader.c
subreader.h
talloc.c
talloc.h
unrar_exec.c
unrar_exec.h
version.sh
vobsub.c
vobsub.h
xvid_vbr.c
xvid_vbr.h
mpv/libmpcodecs/ad_speex.c
2009-07-07 02:34:35 +03:00

121 lines
3.6 KiB
C

/**
* Speex decoder by Reimar Döffinger <Reimar.Doeffinger@stud.uni-karlsruhe.de>
* License: GPL v2 or later
* This code may be be relicensed under the terms of the GNU LGPL when it
* becomes part of the FFmpeg project (ffmpeg.org)
*/
#include "config.h"
#include <stdlib.h>
#include <speex/speex.h>
#include <speex/speex_stereo.h>
#include <speex/speex_header.h>
#include "ad_internal.h"
static const ad_info_t info ={
"Speex audio decoder",
"speex",
"Reimar Döffinger",
"",
""
};
LIBAD_EXTERN(speex)
typedef struct {
SpeexBits bits;
void *dec_context;
SpeexStereoState stereo;
SpeexHeader *hdr;
} context_t;
#define MAX_FRAMES_PER_PACKET 100
static int preinit(sh_audio_t *sh) {
sh->audio_out_minsize = 2 * 320 * MAX_FRAMES_PER_PACKET * 2 * sizeof(short);
return 1;
}
static int init(sh_audio_t *sh) {
context_t *ctx = calloc(1, sizeof(context_t));
const SpeexMode *spx_mode;
const SpeexStereoState st_st = SPEEX_STEREO_STATE_INIT; // hack
if (!sh->wf || sh->wf->cbSize < 80) {
mp_msg(MSGT_DECAUDIO, MSGL_FATAL, "Missing extradata!\n");
return 0;
}
ctx->hdr = speex_packet_to_header((char *)&sh->wf[1], sh->wf->cbSize);
if (ctx->hdr->nb_channels != 1 && ctx->hdr->nb_channels != 2) {
mp_msg(MSGT_DECAUDIO, MSGL_WARN, "Invalid number of channels (%i), "
"assuming mono\n", ctx->hdr->nb_channels);
ctx->hdr->nb_channels = 1;
}
if (ctx->hdr->frames_per_packet > MAX_FRAMES_PER_PACKET) {
mp_msg(MSGT_DECAUDIO, MSGL_WARN, "Invalid number of frames per packet (%i), "
"assuming 1\n", ctx->hdr->frames_per_packet);
ctx->hdr->frames_per_packet = 1;
}
switch (ctx->hdr->mode) {
case 0:
spx_mode = &speex_nb_mode; break;
case 1:
spx_mode = &speex_wb_mode; break;
case 2:
spx_mode = &speex_uwb_mode; break;
default:
mp_msg(MSGT_DECAUDIO, MSGL_WARN, "Unknown speex mode (%i)\n", ctx->hdr->mode);
spx_mode = &speex_nb_mode;
}
ctx->dec_context = speex_decoder_init(spx_mode);
speex_bits_init(&ctx->bits);
memcpy(&ctx->stereo, &st_st, sizeof(ctx->stereo)); // hack part 2
sh->channels = ctx->hdr->nb_channels;
sh->samplerate = ctx->hdr->rate;
sh->samplesize = 2;
sh->sample_format = AF_FORMAT_S16_NE;
sh->context = ctx;
return 1;
}
static void uninit(sh_audio_t *sh) {
context_t *ctx = sh->context;
if (ctx) {
speex_bits_destroy(&ctx->bits);
speex_decoder_destroy(ctx->dec_context);
if (ctx->hdr)
free(ctx->hdr);
free(ctx);
}
ctx = NULL;
}
static int decode_audio(sh_audio_t *sh, unsigned char *buf,
int minlen, int maxlen) {
context_t *ctx = sh->context;
int len, framelen, framesamples;
char *packet;
int i, err;
speex_decoder_ctl(ctx->dec_context, SPEEX_GET_FRAME_SIZE, &framesamples);
framelen = framesamples * ctx->hdr->nb_channels * sizeof(short);
if (maxlen < ctx->hdr->frames_per_packet * framelen) {
mp_msg(MSGT_DECAUDIO, MSGL_V, "maxlen too small in decode_audio\n");
return -1;
}
len = ds_get_packet(sh->ds, (unsigned char **)&packet);
if (len <= 0) return -1;
speex_bits_read_from(&ctx->bits, packet, len);
i = ctx->hdr->frames_per_packet;
do {
err = speex_decode_int(ctx->dec_context, &ctx->bits, (short *)buf);
if (err == -2)
mp_msg(MSGT_DECAUDIO, MSGL_ERR, "Error decoding file.\n");
if (ctx->hdr->nb_channels == 2)
speex_decode_stereo_int((short *)buf, framesamples, &ctx->stereo);
buf = &buf[framelen];
} while (--i > 0);
return ctx->hdr->frames_per_packet * framelen;
}
static int control(sh_audio_t *sh, int cmd, void *arg, ...) {
return CONTROL_UNKNOWN;
}