1 /*****************************************************************************
2 * ogg.h : ogg stream demux module for vlc
3 *****************************************************************************
4 * Copyright (C) 2001-2010 VLC authors and VideoLAN
6 * Authors: Gildas Bazin <gbazin@netcourrier.com>
7 * Andre Pang <Andre.Pang@csiro.au> (Annodex support)
8 * Gabriel Finch <salsaman@gmail.com> (moved from ogg.c to ogg.h)
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU Lesser General Public License as published by
12 * the Free Software Foundation; either version 2.1 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License for more details.
20 * You should have received a copy of the GNU Lesser General Public License
21 * along with this program; if not, write to the Free Software Foundation,
22 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
25 /*****************************************************************************
26 * Definitions of structures and functions used by this plugin
27 *****************************************************************************/
29 //#define OGG_DEMUX_DEBUG 1
30 #ifdef OGG_DEMUX_DEBUG
31 #define DemuxDebug(code) code
33 #define DemuxDebug(code)
36 /* Some defines from OggDS http://svn.xiph.org/trunk/oggds/ */
37 #define PACKET_TYPE_HEADER 0x01
38 #define PACKET_TYPE_BITS 0x07
39 #define PACKET_LEN_BITS01 0xc0
40 #define PACKET_LEN_BITS2 0x02
41 #define PACKET_IS_SYNCPOINT 0x08
43 typedef struct oggseek_index_entry demux_index_entry_t;
44 typedef struct ogg_skeleton_t ogg_skeleton_t;
46 typedef struct logical_stream_s
48 ogg_stream_state os; /* logical stream of packets */
51 es_format_t fmt_old; /* format of old ES is reused */
57 /* the header of some logical streams (eg vorbis) contain essential
58 * data for the decoder. We back them up here in case we need to re-feed
59 * them to the decoder. */
62 int32_t i_extra_headers_packets;
65 ogg_int64_t i_previous_granulepos;
67 /* program clock reference (in units of 90kHz) derived from the previous
70 mtime_t i_interpolated_pcr;
71 mtime_t i_previous_pcr;
80 /* Opus has a starting offset in the headers. */
82 /* Vorbis and Opus can trim the end of a stream using granule positions. */
85 /* offset of first keyframe for theora; can be 0 or 1 depending on version number */
86 int8_t i_keyframe_offset;
88 /* keyframe index for seeking, created as we discover keyframes */
89 demux_index_entry_t *idx;
92 ogg_skeleton_t *p_skel;
94 /* skip some frames after a seek */
97 /* data start offset (absolute) in bytes */
100 /* kate streams have the number of headers in the ID header */
101 int i_kate_num_headers;
103 /* for Annodex logical bitstreams */
104 int i_secondary_header_packets;
106 block_t *p_preparse_block;
109 struct ogg_skeleton_t
112 char **ppsz_messages;
113 unsigned char *p_index;
115 uint64_t i_index_size;
116 int64_t i_indexstampden;/* time denominator */
117 int64_t i_indexfirstnum;/* first sample time numerator */
118 int64_t i_indexlastnum;
123 ogg_sync_state oy; /* sync and verify incoming physical bitstream */
125 int i_streams; /* number of logical bitstreams */
126 logical_stream_t **pp_stream; /* pointer to an array of logical streams */
127 logical_stream_t *p_skelstream; /* pointer to skeleton stream if any */
129 logical_stream_t *p_old_stream; /* pointer to a old logical stream to avoid recreating it */
131 /* program clock reference (in units of 90kHz) derived from the pcr of
134 mtime_t i_pcr_offset;
135 /* informative only */
136 mtime_t i_pcr_jitter;
137 int64_t i_access_delay;
139 /* new stream or starting from a chain */
140 bool b_chained_boundary;
144 bool b_partial_bitrate;
146 /* after reading all headers, the first data page is stuffed into the relevant stream, ready to use */
149 /* count of total frames in video stream */
150 int64_t i_total_frames;
152 /* length of file in bytes */
153 int64_t i_total_length;
155 /* offset position in file (for reading) */
156 int64_t i_input_position;
158 /* current page being parsed */
159 ogg_page current_page;
164 seekpoint_t **pp_seekpoints;
175 input_attachment_t **attachments;
177 /* preparsing info */
178 bool b_preparsing_done;
181 /* Length, if available. */
184 DemuxDebug( bool b_seeked; )
188 unsigned const char * Read7BitsVariableLE( unsigned const char *,
189 unsigned const char *,
191 bool Ogg_GetBoundsUsingSkeletonIndex( logical_stream_t *p_stream, int64_t i_time,
192 int64_t *pi_lower, int64_t *pi_upper );