123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642 |
- /* Gstreamer
- * Copyright (C) <2011> Intel
- * Copyright (C) <2011> Collabora Ltd.
- * Copyright (C) <2011> Thibault Saunier <thibault.saunier@collabora.com>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Library General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Library General Public License for more details.
- *
- * You should have received a copy of the GNU Library General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
- * Boston, MA 02110-1301, USA.
- */
- #ifndef __GST_VC1_PARSER_H__
- #define __GST_VC1_PARSER_H__
- #ifndef GST_USE_UNSTABLE_API
- #warning "The VC1 parsing library is unstable API and may change in future."
- #warning "You can define GST_USE_UNSTABLE_API to avoid this warning."
- #endif
- #include <gst/gst.h>
- G_BEGIN_DECLS
- #define MAX_HRD_NUM_LEAKY_BUCKETS 31
- /**
- * GST_VC1_BFRACTION_BASIS:
- * The @bfraction variable should be divided
- * by this constant to have the actual value.
- */
- #define GST_VC1_BFRACTION_BASIS 840
- #define GST_VC1_BFRACTION_RESERVED (GST_VC1_BFRACTION_BASIS + 1)
- #define GST_VC1_BFRACTION_PTYPE_BI (GST_VC1_BFRACTION_BASIS + 2)
- typedef enum {
- GST_VC1_END_OF_SEQ = 0x0A,
- GST_VC1_SLICE = 0x0B,
- GST_VC1_FIELD = 0x0C,
- GST_VC1_FRAME = 0x0D,
- GST_VC1_ENTRYPOINT = 0x0E,
- GST_VC1_SEQUENCE = 0x0F,
- GST_VC1_SLICE_USER = 0x1B,
- GST_VC1_FIELD_USER = 0x1C,
- GST_VC1_FRAME_USER = 0x1D,
- GST_VC1_ENTRY_POINT_USER = 0x1E,
- GST_VC1_SEQUENCE_USER = 0x1F
- } GstVC1StartCode;
- typedef enum {
- GST_VC1_PROFILE_SIMPLE,
- GST_VC1_PROFILE_MAIN,
- GST_VC1_PROFILE_RESERVED,
- GST_VC1_PROFILE_ADVANCED
- } GstVC1Profile;
- typedef enum {
- GST_VC1_PARSER_OK,
- GST_VC1_PARSER_BROKEN_DATA,
- GST_VC1_PARSER_NO_BDU,
- GST_VC1_PARSER_NO_BDU_END,
- GST_VC1_PARSER_ERROR,
- } GstVC1ParserResult;
- typedef enum
- {
- GST_VC1_PICTURE_TYPE_P,
- GST_VC1_PICTURE_TYPE_B,
- GST_VC1_PICTURE_TYPE_I,
- GST_VC1_PICTURE_TYPE_BI,
- GST_VC1_PICTURE_TYPE_SKIPPED
- } GstVC1PictureType;
- typedef enum
- {
- GST_VC1_LEVEL_LOW = 0, /* Simple/Main profile low level */
- GST_VC1_LEVEL_MEDIUM = 2, /* Simple/Main profile medium level */
- GST_VC1_LEVEL_HIGH = 4, /* Main profile high level */
- GST_VC1_LEVEL_L0 = 0, /* Advanced profile level 0 */
- GST_VC1_LEVEL_L1 = 1, /* Advanced profile level 1 */
- GST_VC1_LEVEL_L2 = 2, /* Advanced profile level 2 */
- GST_VC1_LEVEL_L3 = 3, /* Advanced profile level 3 */
- GST_VC1_LEVEL_L4 = 4, /* Advanced profile level 4 */
- /* 5 to 7 reserved */
- GST_VC1_LEVEL_UNKNOWN = 255 /* Unknown profile */
- } GstVC1Level;
- typedef enum
- {
- GST_VC1_QUANTIZER_IMPLICITLY,
- GST_VC1_QUANTIZER_EXPLICITLY,
- GST_VC1_QUANTIZER_NON_UNIFORM,
- GST_VC1_QUANTIZER_UNIFORM
- } GstVC1QuantizerSpec;
- typedef enum {
- GST_VC1_DQPROFILE_FOUR_EDGES,
- GST_VC1_DQPROFILE_DOUBLE_EDGES,
- GST_VC1_DQPROFILE_SINGLE_EDGE,
- GST_VC1_DQPROFILE_ALL_MBS
- } GstVC1DQProfile;
- typedef enum {
- GST_VC1_CONDOVER_NONE,
- GST_VC1_CONDOVER_ALL,
- GST_VC1_CONDOVER_SELECT
- } GstVC1Condover;
- /**
- * GstVC1MvMode:
- *
- */
- typedef enum
- {
- GST_VC1_MVMODE_1MV_HPEL_BILINEAR,
- GST_VC1_MVMODE_1MV,
- GST_VC1_MVMODE_1MV_HPEL,
- GST_VC1_MVMODE_MIXED_MV,
- GST_VC1_MVMODE_INTENSITY_COMP
- } GstVC1MvMode;
- typedef enum
- {
- GST_VC1_FRAME_PROGRESSIVE = 0x0,
- GST_VC1_FRAME_INTERLACE = 0x10,
- GST_VC1_FIELD_INTERLACE = 0x11
- } GstVC1FrameCodingMode;
- typedef struct _GstVC1SeqHdr GstVC1SeqHdr;
- typedef struct _GstVC1AdvancedSeqHdr GstVC1AdvancedSeqHdr;
- typedef struct _GstVC1HrdParam GstVC1HrdParam;
- typedef struct _GstVC1EntryPointHdr GstVC1EntryPointHdr;
- typedef struct _GstVC1SeqLayer GstVC1SeqLayer;
- typedef struct _GstVC1SeqStructA GstVC1SeqStructA;
- typedef struct _GstVC1SeqStructB GstVC1SeqStructB;
- typedef struct _GstVC1SeqStructC GstVC1SeqStructC;
- /* Pictures Structures */
- typedef struct _GstVC1FrameLayer GstVC1FrameLayer;
- typedef struct _GstVC1FrameHdr GstVC1FrameHdr;
- typedef struct _GstVC1PicAdvanced GstVC1PicAdvanced;
- typedef struct _GstVC1PicSimpleMain GstVC1PicSimpleMain;
- typedef struct _GstVC1Picture GstVC1Picture;
- typedef struct _GstVC1SliceHdr GstVC1SliceHdr;
- typedef struct _GstVC1VopDquant GstVC1VopDquant;
- typedef struct _GstVC1BitPlanes GstVC1BitPlanes;
- typedef struct _GstVC1BDU GstVC1BDU;
- struct _GstVC1HrdParam
- {
- guint8 hrd_num_leaky_buckets;
- guint8 bit_rate_exponent;
- guint8 buffer_size_exponent;
- guint16 hrd_rate[MAX_HRD_NUM_LEAKY_BUCKETS];
- guint16 hrd_buffer[MAX_HRD_NUM_LEAKY_BUCKETS];
- };
- /**
- * GstVC1EntryPointHdr:
- *
- * Structure for entrypoint header, this will be used only in advanced profiles
- */
- struct _GstVC1EntryPointHdr
- {
- guint8 broken_link;
- guint8 closed_entry;
- guint8 panscan_flag;
- guint8 refdist_flag;
- guint8 loopfilter;
- guint8 fastuvmc;
- guint8 extended_mv;
- guint8 dquant;
- guint8 vstransform;
- guint8 overlap;
- guint8 quantizer;
- guint8 coded_size_flag;
- guint16 coded_width;
- guint16 coded_height;
- guint8 extended_dmv;
- guint8 range_mapy_flag;
- guint8 range_mapy;
- guint8 range_mapuv_flag;
- guint8 range_mapuv;
- guint8 hrd_full[MAX_HRD_NUM_LEAKY_BUCKETS];
- };
- /**
- * GstVC1AdvancedSeqHdr:
- *
- * Structure for the advanced profile sequence headers specific parameters.
- */
- struct _GstVC1AdvancedSeqHdr
- {
- GstVC1Level level;
- guint8 frmrtq_postproc;
- guint8 bitrtq_postproc;
- guint8 postprocflag;
- guint16 max_coded_width;
- guint16 max_coded_height;
- guint8 pulldown;
- guint8 interlace;
- guint8 tfcntrflag;
- guint8 finterpflag;
- guint8 psf;
- guint8 display_ext;
- guint16 disp_horiz_size;
- guint16 disp_vert_size;
- guint8 aspect_ratio_flag;
- guint8 aspect_ratio;
- guint8 aspect_horiz_size;
- guint8 aspect_vert_size;
- guint8 framerate_flag;
- guint8 framerateind;
- guint8 frameratenr;
- guint8 frameratedr;
- guint16 framerateexp;
- guint8 color_format_flag;
- guint8 color_prim;
- guint8 transfer_char;
- guint8 matrix_coef;
- guint8 hrd_param_flag;
- guint8 colordiff_format;
- GstVC1HrdParam hrd_param;
- /* computed */
- guint framerate; /* Around in fps, 0 if unknown*/
- guint bitrate; /* Around in kpbs, 0 if unknown*/
- guint par_n;
- guint par_d;
- guint fps_n;
- guint fps_d;
- /* The last parsed entry point */
- GstVC1EntryPointHdr entrypoint;
- };
- struct _GstVC1SeqStructA
- {
- guint32 vert_size;
- guint32 horiz_size;
- };
- struct _GstVC1SeqStructB
- {
- GstVC1Level level;
- guint8 cbr;
- guint32 framerate;
- /* In simple and main profiles only */
- guint32 hrd_buffer;
- guint32 hrd_rate;
- };
- struct _GstVC1SeqStructC
- {
- GstVC1Profile profile;
- /* Only in simple and main profiles */
- guint8 frmrtq_postproc;
- guint8 bitrtq_postproc;
- guint8 res_sprite;
- guint8 loop_filter;
- guint8 multires;
- guint8 fastuvmc;
- guint8 extended_mv;
- guint8 dquant;
- guint8 vstransform;
- guint8 overlap;
- guint8 syncmarker;
- guint8 rangered;
- guint8 maxbframes;
- guint8 quantizer;
- guint8 finterpflag;
- /* Computed */
- guint framerate; /* Around in fps, 0 if unknown*/
- guint bitrate; /* Around in kpbs, 0 if unknown*/
- /* This should be filled by user if previously known */
- guint16 coded_width;
- /* This should be filled by user if previously known */
- guint16 coded_height;
- /* Wmvp specific */
- guint8 wmvp; /* Specify if the stream is wmp or not */
- /* In the wmvp case, the framerate is not computed but in the bistream */
- guint8 slice_code;
- };
- struct _GstVC1SeqLayer
- {
- guint32 numframes;
- GstVC1SeqStructA struct_a;
- GstVC1SeqStructB struct_b;
- GstVC1SeqStructC struct_c;
- };
- /**
- * GstVC1SeqHdr:
- *
- * Structure for sequence headers in any profile.
- */
- struct _GstVC1SeqHdr
- {
- GstVC1Profile profile;
- GstVC1SeqStructC struct_c;
- /* calculated */
- guint mb_height;
- guint mb_width;
- guint mb_stride;
- GstVC1AdvancedSeqHdr advanced;
- };
- /**
- * GstVC1PicSimpleMain:
- * @bfaction: Should be divided by #GST_VC1_BFRACTION_BASIS
- * to get the real value.
- */
- struct _GstVC1PicSimpleMain
- {
- guint8 frmcnt;
- guint8 mvrange;
- guint8 rangeredfrm;
- /* I and P pic simple and main profiles only */
- guint8 respic;
- /* I and BI pic simple and main profiles only */
- guint8 transacfrm2;
- guint8 bf;
- /* B and P pic simple and main profiles only */
- guint8 mvmode;
- guint8 mvtab;
- guint8 ttmbf;
- /* P pic simple and main profiles only */
- guint8 mvmode2;
- guint8 lumscale;
- guint8 lumshift;
- guint8 cbptab;
- guint8 ttfrm;
- /* B and BI picture only
- * Should be divided by #GST_VC1_BFRACTION_BASIS
- * to get the real value. */
- guint16 bfraction;
- /* Biplane value, those fields only mention the fact
- * that the bitplane is in raw mode or not */
- guint8 mvtypemb;
- guint8 skipmb;
- guint8 directmb; /* B pic main profile only */
- };
- /**
- * GstVC1PicAdvanced:
- * @bfaction: Should be divided by #GST_VC1_BFRACTION_BASIS
- * to get the real value.
- */
- struct _GstVC1PicAdvanced
- {
- GstVC1FrameCodingMode fcm;
- guint8 tfcntr;
- guint8 rptfrm;
- guint8 tff;
- guint8 rff;
- guint8 ps_present;
- guint32 ps_hoffset;
- guint32 ps_voffset;
- guint16 ps_width;
- guint16 ps_height;
- guint8 rndctrl;
- guint8 uvsamp;
- guint8 postproc;
- /* B and P picture specific */
- guint8 mvrange;
- guint8 mvmode;
- guint8 mvtab;
- guint8 cbptab;
- guint8 ttmbf;
- guint8 ttfrm;
- /* B and BI picture only
- * Should be divided by #GST_VC1_BFRACTION_BASIS
- * to get the real value. */
- guint16 bfraction;
- /* ppic */
- guint8 mvmode2;
- guint8 lumscale;
- guint8 lumshift;
- /* bipic */
- guint8 bf;
- guint8 condover;
- guint8 transacfrm2;
- /* Biplane value, those fields only mention the fact
- * that the bitplane is in raw mode or not */
- guint8 acpred;
- guint8 overflags;
- guint8 mvtypemb;
- guint8 skipmb;
- guint8 directmb;
- guint8 forwardmb; /* B pic interlace field only */
- /* For interlaced pictures only */
- guint8 fieldtx;
- /* P and B pictures */
- guint8 intcomp;
- guint8 dmvrange;
- guint8 mbmodetab;
- guint8 imvtab;
- guint8 icbptab;
- guint8 mvbptab2;
- guint8 mvbptab4; /* If 4mvswitch in ppic */
- /* P picture */
- guint8 mvswitch4;
- /* For interlaced fields only */
- guint16 refdist;
- guint8 fptype; /* Raw value */
- /* P pic */
- guint8 numref;
- guint8 reffield;
- guint8 lumscale2;
- guint8 lumshift2;
- guint8 intcompfield;
- };
- struct _GstVC1BitPlanes
- {
- guint8 *acpred;
- guint8 *fieldtx;
- guint8 *overflags;
- guint8 *mvtypemb;
- guint8 *skipmb;
- guint8 *directmb;
- guint8 *forwardmb;
- guint size; /* Size of the arrays */
- };
- struct _GstVC1VopDquant
- {
- guint8 pqdiff;
- guint8 abspq;
- /* Computed */
- guint8 altpquant;
- /* if dqant != 2*/
- guint8 dquantfrm;
- guint8 dqprofile;
- /* Boundary edge selection. This represents DQSBEDGE
- * if dqprofile == GST_VC1_DQPROFILE_SINGLE_EDGE or
- * DQDBEDGE if dqprofile == GST_VC1_DQPROFILE_DOUBLE_EDGE */
- guint8 dqbedge;
- /* FIXME: remove */
- guint8 unused;
- /* if dqprofile == GST_VC1_DQPROFILE_ALL_MBS */
- guint8 dqbilevel;
- };
- struct _GstVC1FrameLayer
- {
- guint8 key;
- guint32 framesize;
- guint32 timestamp;
- /* calculated */
- guint32 next_framelayer_offset;
- guint8 skiped_p_frame;
- };
- /**
- * GstVC1FrameHdr:
- *
- * Structure that represent picture in any profile or mode.
- * You should look at @ptype and @profile to know what is currently
- * in use.
- */
- struct _GstVC1FrameHdr
- {
- /* common fields */
- GstVC1PictureType ptype;
- guint8 interpfrm;
- guint8 halfqp;
- guint8 transacfrm;
- guint8 transdctab;
- guint8 pqindex;
- guint8 pquantizer;
- /* Computed */
- guint8 pquant;
- /* Convenience fields */
- guint8 profile;
- guint8 dquant;
- /* If dquant */
- GstVC1VopDquant vopdquant;
- union {
- GstVC1PicSimpleMain simple;
- GstVC1PicAdvanced advanced;
- } pic;
- /* Size of the picture layer in bits */
- guint header_size;
- };
- /**
- * GstVC1SliceHdr:
- *
- * Structure that represents slice layer in advanced profile.
- */
- struct _GstVC1SliceHdr
- {
- guint16 slice_addr;
- /* Size of the slice layer in bits */
- guint header_size;
- };
- /**
- * GstVC1BDU:
- *
- * Structure that represents a Bitstream Data Unit.
- */
- struct _GstVC1BDU
- {
- GstVC1StartCode type;
- guint size;
- guint sc_offset;
- guint offset;
- guint8 * data;
- };
- GstVC1ParserResult gst_vc1_identify_next_bdu (const guint8 *data,
- gsize size,
- GstVC1BDU *bdu);
- GstVC1ParserResult gst_vc1_parse_sequence_header (const guint8 *data,
- gsize size,
- GstVC1SeqHdr * seqhdr);
- GstVC1ParserResult gst_vc1_parse_entry_point_header (const guint8 *data,
- gsize size,
- GstVC1EntryPointHdr * entrypoint,
- GstVC1SeqHdr *seqhdr);
- GstVC1ParserResult gst_vc1_parse_sequence_layer (const guint8 *data,
- gsize size,
- GstVC1SeqLayer * seqlayer);
- GstVC1ParserResult
- gst_vc1_parse_sequence_header_struct_a (const guint8 *data,
- gsize size,
- GstVC1SeqStructA *structa);
- GstVC1ParserResult
- gst_vc1_parse_sequence_header_struct_b (const guint8 *data,
- gsize size,
- GstVC1SeqStructB *structb);
- GstVC1ParserResult
- gst_vc1_parse_sequence_header_struct_c (const guint8 *data,
- gsize size,
- GstVC1SeqStructC *structc);
- GstVC1ParserResult gst_vc1_parse_frame_layer (const guint8 *data,
- gsize size,
- GstVC1FrameLayer * framelayer);
- GstVC1ParserResult gst_vc1_parse_frame_header (const guint8 *data,
- gsize size,
- GstVC1FrameHdr * framehdr,
- GstVC1SeqHdr *seqhdr,
- GstVC1BitPlanes *bitplanes);
- GstVC1ParserResult gst_vc1_parse_field_header (const guint8 *data,
- gsize size,
- GstVC1FrameHdr * fieldhdr,
- GstVC1SeqHdr *seqhdr,
- GstVC1BitPlanes *bitplanes);
- GstVC1ParserResult gst_vc1_parse_slice_header (const guint8 *data,
- gsize size,
- GstVC1SliceHdr *slicehdr,
- GstVC1SeqHdr *seqhdr);
- GstVC1BitPlanes * gst_vc1_bitplanes_new (void);
- void gst_vc1_bitplanes_free (GstVC1BitPlanes *bitplanes);
- void gst_vc1_bitplanes_free_1 (GstVC1BitPlanes *bitplanes);
- gboolean gst_vc1_bitplanes_ensure_size (GstVC1BitPlanes *bitplanes,
- GstVC1SeqHdr *seqhdr);
- G_END_DECLS
- #endif
|