DASH Media Packaging SDK
 All Classes Namespaces Functions Variables Typedefs Enumerator
h264_bit_reader.h
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 //
5 // This file contains an implementation of an H264 Annex-B video stream parser.
6 
7 #ifndef MEDIA_FILTERS_H264_BIT_READER_H_
8 #define MEDIA_FILTERS_H264_BIT_READER_H_
9 
10 #include <stdint.h>
11 #include <sys/types.h>
12 
13 #include "packager/base/macros.h"
14 
15 namespace edash_packager {
16 namespace media {
17 
18 // A class to provide bit-granularity reading of H.264 streams.
19 // This is not a generic bit reader class, as it takes into account
20 // H.264 stream-specific constraints, such as skipping emulation-prevention
21 // bytes and stop bits. See spec for more details.
23  public:
24  H264BitReader();
25  ~H264BitReader();
26 
27  // Initialize the reader to start reading at |data|, |size| being size
28  // of |data| in bytes.
29  // Return false on insufficient size of stream..
30  bool Initialize(const uint8_t* data, off_t size);
31 
32  // Read |num_bits| next bits from stream and return in |*out|, first bit
33  // from the stream starting at |num_bits| position in |*out|.
34  // |num_bits| may be 1-32, inclusive.
35  // Return false if the given number of bits cannot be read (not enough
36  // bits in the stream), true otherwise.
37  bool ReadBits(int num_bits, int* out);
38 
39  // Exp-Golomb code parsing as specified in chapter 9.1 of the spec.
40  // Read one unsigned exp-Golomb code from the stream and return in |*val|.
41  bool ReadUE(int* val);
42 
43  // Read one signed exp-Golomb code from the stream and return in |*val|.
44  bool ReadSE(int* val);
45 
46  // Return the number of bits left in the stream.
47  off_t NumBitsLeft();
48 
49  // See the definition of more_rbsp_data() in spec.
50  bool HasMoreRBSPData();
51 
52  // Return the number of emulation prevention bytes already read.
53  size_t NumEmulationPreventionBytesRead();
54 
55  private:
56  // Advance to the next byte, loading it into curr_byte_.
57  // Return false on end of stream.
58  bool UpdateCurrByte();
59 
60  // Pointer to the next unread (not in curr_byte_) byte in the stream.
61  const uint8_t* data_;
62 
63  // Bytes left in the stream (without the curr_byte_).
64  off_t bytes_left_;
65 
66  // Contents of the current byte; first unread bit starting at position
67  // 8 - num_remaining_bits_in_curr_byte_ from MSB.
68  int curr_byte_;
69 
70  // Number of bits remaining in curr_byte_
71  int num_remaining_bits_in_curr_byte_;
72 
73  // Used in emulation prevention three byte detection (see spec).
74  // Initially set to 0xffff to accept all initial two-byte sequences.
75  int prev_two_bytes_;
76 
77  // Number of emulation preventation bytes (0x000003) we met.
78  size_t emulation_prevention_bytes_;
79 
80  DISALLOW_COPY_AND_ASSIGN(H264BitReader);
81 };
82 
83 } // namespace media
84 } // namespace edash_packager
85 
86 #endif // MEDIA_FILTERS_H264_BIT_READER_H_