1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * This file is part of FFmpeg.
3cabdff1aSopenharmony_ci *
4cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
5cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
6cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
7cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
8cabdff1aSopenharmony_ci *
9cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
10cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
11cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12cabdff1aSopenharmony_ci * Lesser General Public License for more details.
13cabdff1aSopenharmony_ci *
14cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
15cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
16cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17cabdff1aSopenharmony_ci */
18cabdff1aSopenharmony_ci
19cabdff1aSopenharmony_ci/**
20cabdff1aSopenharmony_ci * @file
21cabdff1aSopenharmony_ci * XMA2 audio parser
22cabdff1aSopenharmony_ci */
23cabdff1aSopenharmony_ci
24cabdff1aSopenharmony_ci#include "parser.h"
25cabdff1aSopenharmony_ci
26cabdff1aSopenharmony_citypedef struct XMAParserContext{
27cabdff1aSopenharmony_ci    int skip_packets;
28cabdff1aSopenharmony_ci} XMAParserContext;
29cabdff1aSopenharmony_ci
30cabdff1aSopenharmony_cistatic int xma_parse(AVCodecParserContext *s1, AVCodecContext *avctx,
31cabdff1aSopenharmony_ci                     const uint8_t **poutbuf, int *poutbuf_size,
32cabdff1aSopenharmony_ci                     const uint8_t *buf, int buf_size)
33cabdff1aSopenharmony_ci{
34cabdff1aSopenharmony_ci    XMAParserContext *s = s1->priv_data;
35cabdff1aSopenharmony_ci
36cabdff1aSopenharmony_ci    if (buf_size % 2048 == 0) {
37cabdff1aSopenharmony_ci        int duration = 0, packet, nb_packets = buf_size / 2048;
38cabdff1aSopenharmony_ci
39cabdff1aSopenharmony_ci        for (packet = 0; packet < nb_packets; packet++) {
40cabdff1aSopenharmony_ci            if (s->skip_packets == 0) {
41cabdff1aSopenharmony_ci                duration += buf[packet * 2048] * 128;
42cabdff1aSopenharmony_ci                s->skip_packets = buf[packet * 2048 + 3] + 1;
43cabdff1aSopenharmony_ci            }
44cabdff1aSopenharmony_ci            s->skip_packets--;
45cabdff1aSopenharmony_ci        }
46cabdff1aSopenharmony_ci
47cabdff1aSopenharmony_ci        s1->duration = duration;
48cabdff1aSopenharmony_ci        s1->key_frame = !!duration;
49cabdff1aSopenharmony_ci    }
50cabdff1aSopenharmony_ci
51cabdff1aSopenharmony_ci    /* always return the full packet. this parser isn't doing any splitting or
52cabdff1aSopenharmony_ci       combining, only packet analysis */
53cabdff1aSopenharmony_ci    *poutbuf      = buf;
54cabdff1aSopenharmony_ci    *poutbuf_size = buf_size;
55cabdff1aSopenharmony_ci    return buf_size;
56cabdff1aSopenharmony_ci}
57cabdff1aSopenharmony_ci
58cabdff1aSopenharmony_ciconst AVCodecParser ff_xma_parser = {
59cabdff1aSopenharmony_ci    .codec_ids      = { AV_CODEC_ID_XMA2 },
60cabdff1aSopenharmony_ci    .priv_data_size = sizeof(XMAParserContext),
61cabdff1aSopenharmony_ci    .parser_parse   = xma_parse,
62cabdff1aSopenharmony_ci};
63