summaryrefslogtreecommitdiffstats
path: root/libmpcodecs
diff options
context:
space:
mode:
authorreimar <reimar@b3059339-0415-0410-9bf9-f77b7e298cf2>2010-03-12 18:19:51 +0000
committerreimar <reimar@b3059339-0415-0410-9bf9-f77b7e298cf2>2010-03-12 18:19:51 +0000
commitd06c04bb678dcbda68949bbd88637de192be3399 (patch)
treed7e4cd79a838435e98759f7e43f3c7ab4145e009 /libmpcodecs
parentfdd4ddccd46830f9439d545c54da98d50bf49951 (diff)
downloadmpv-d06c04bb678dcbda68949bbd88637de192be3399.tar.bz2
mpv-d06c04bb678dcbda68949bbd88637de192be3399.tar.xz
Support extradata format of the speex.acm windows codec formerly available
from openacm.org. git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@30884 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpcodecs')
-rw-r--r--libmpcodecs/ad_speex.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/libmpcodecs/ad_speex.c b/libmpcodecs/ad_speex.c
index 9abc1ad032..a93a245492 100644
--- a/libmpcodecs/ad_speex.c
+++ b/libmpcodecs/ad_speex.c
@@ -52,8 +52,15 @@ static int preinit(sh_audio_t *sh) {
return 1;
}
+static int read_le32(const uint8_t **src) {
+ const uint8_t *p = *src;
+ *src += 4;
+ return p[0] + (p[1] << 8) + (p[2] << 16) + (p[3] << 24);
+}
+
static int init(sh_audio_t *sh) {
context_t *ctx = calloc(1, sizeof(context_t));
+ const uint8_t *hdr = (const uint8_t *)(sh->wf + 1);
const SpeexMode *spx_mode;
const SpeexStereoState st_st = SPEEX_STEREO_STATE_INIT; // hack
if (!sh->wf || sh->wf->cbSize < 80) {
@@ -61,6 +68,23 @@ static int init(sh_audio_t *sh) {
return 0;
}
ctx->hdr = speex_packet_to_header((char *)&sh->wf[1], sh->wf->cbSize);
+ if (!ctx->hdr && sh->wf->cbSize == 0x72 && hdr[0] == 1 && hdr[1] == 0) {
+ // speex.acm format: raw SpeexHeader dump
+ ctx->hdr = calloc(1, sizeof(*ctx->hdr));
+ hdr += 2;
+ hdr += 8; // identifier string
+ hdr += 20; // version string
+ ctx->hdr->speex_version_id = read_le32(&hdr);
+ ctx->hdr->header_size = read_le32(&hdr);
+ ctx->hdr->rate = read_le32(&hdr);
+ ctx->hdr->mode = read_le32(&hdr);
+ ctx->hdr->mode_bitstream_version = read_le32(&hdr);
+ ctx->hdr->nb_channels = read_le32(&hdr);
+ ctx->hdr->bitrate = read_le32(&hdr);
+ ctx->hdr->frame_size = read_le32(&hdr);
+ ctx->hdr->vbr = read_le32(&hdr);
+ ctx->hdr->frames_per_packet = read_le32(&hdr);
+ }
if (!ctx->hdr) {
mp_msg(MSGT_DECAUDIO, MSGL_FATAL, "Invalid extradata!\n");
return 0;