Shaka Packager SDK
ac3_header.cc
1 // Copyright 2017 Google Inc. All rights reserved.
2 //
3 // Use of this source code is governed by a BSD-style
4 // license that can be found in the LICENSE file or at
5 // https://developers.google.com/open-source/licenses/bsd
6 
7 #include "packager/media/formats/mp2t/ac3_header.h"
8 
9 #include "packager/media/base/bit_reader.h"
10 #include "packager/media/base/bit_writer.h"
11 #include "packager/media/formats/mp2t/mp2t_common.h"
12 
13 namespace shaka {
14 namespace media {
15 namespace mp2t {
16 namespace {
17 
18 // ASTC Standard A/52:2012 Table 5.6 Sample Rate Codes.
19 const uint32_t kAc3SampleRateTable[] = {48000, 44100, 32000};
20 
21 // ASTC Standard A/52:2012 Table 5.8 Audio Coding Mode.
22 const uint8_t kAc3NumChannelsTable[] = {2, 1, 2, 3, 3, 4, 4, 5};
23 
24 // ATSC Standard A/52:2012 Table 5.18 Frame Size Code Table
25 // (in words = 16 bits).
26 const size_t kFrameSizeCodeTable[][3] = {
27  // {32kHz, 44.1kHz, 48kHz}
28  {96, 69, 64}, {96, 70, 64}, {120, 87, 80},
29  {120, 88, 80}, {144, 104, 96}, {144, 105, 96},
30  {168, 121, 112}, {168, 122, 112}, {192, 139, 128},
31  {192, 140, 128}, {240, 174, 160}, {240, 175, 160},
32  {288, 208, 192}, {288, 209, 192}, {336, 243, 224},
33  {336, 244, 224}, {384, 278, 256}, {384, 279, 256},
34  {480, 348, 320}, {480, 349, 320}, {576, 417, 384},
35  {576, 418, 384}, {672, 487, 448}, {672, 488, 448},
36  {768, 557, 512}, {768, 558, 512}, {960, 696, 640},
37  {960, 697, 640}, {1152, 835, 768}, {1152, 836, 768},
38  {1344, 975, 896}, {1344, 976, 896}, {1536, 1114, 1024},
39  {1536, 1115, 1024}, {1728, 1253, 1152}, {1728, 1254, 1152},
40  {1920, 1393, 1280}, {1920, 1394, 1280},
41 };
42 
43 } // namespace
44 
45 bool Ac3Header::IsSyncWord(const uint8_t* buf) const {
46  DCHECK(buf);
47  // ATSC Standard A/52:2012 5.4.1 syncinfo: Synchronization Information.
48  return buf[0] == 0x0B && buf[1] == 0x77;
49 }
50 
52  // Arbitrary. Actual frame size starts with 96 words.
53  const size_t kMinAc3FrameSize = 10u;
54  return kMinAc3FrameSize;
55 }
56 
58  // ATSC Standard A/52:2012
59  // Annex A: AC-3 Elementary Streams in the MPEG-2 Multiplex.
60  const size_t kSamplesPerAc3Frame = 1536;
61  return kSamplesPerAc3Frame;
62 }
63 
64 bool Ac3Header::Parse(const uint8_t* audio_frame, size_t audio_frame_size) {
65  BitReader frame(audio_frame, audio_frame_size);
66 
67  // ASTC Standard A/52:2012 5. BIT STREAM SYNTAX.
68  // syncinfo: synchronization information section.
69  uint16_t syncword;
70  RCHECK(frame.ReadBits(16, &syncword));
71  RCHECK(syncword == 0x0B77);
72  uint16_t crc1;
73  RCHECK(frame.ReadBits(16, &crc1));
74  RCHECK(frame.ReadBits(2, &fscod_));
75  RCHECK(fscod_ < arraysize(kAc3SampleRateTable));
76  RCHECK(frame.ReadBits(6, &frmsizecod_));
77  RCHECK(frmsizecod_ < arraysize(kFrameSizeCodeTable));
78 
79  // bsi: bit stream information section.
80  RCHECK(frame.ReadBits(5, &bsid_));
81  RCHECK(frame.ReadBits(3, &bsmod_));
82 
83  RCHECK(frame.ReadBits(3, &acmod_));
84  RCHECK(acmod_ < arraysize(kAc3NumChannelsTable));
85  // If 3 front channels.
86  if ((acmod_ & 0x01) && (acmod_ != 0x01))
87  RCHECK(frame.SkipBits(2)); // cmixlev.
88  // If a surround channel exists.
89  if (acmod_ & 0x04)
90  RCHECK(frame.SkipBits(2)); // surmixlev.
91  // If in 2/0 mode.
92  if (acmod_ == 0x02)
93  RCHECK(frame.SkipBits(2)); // dsurmod.
94 
95  RCHECK(frame.ReadBits(1, &lfeon_));
96 
97  return true;
98 }
99 
100 size_t Ac3Header::GetHeaderSize() const {
101  // Unlike ADTS, for AC3, the whole frame is included in the media sample, so
102  // return 0 header size.
103  return 0;
104 }
105 
106 size_t Ac3Header::GetFrameSize() const {
107  const size_t kNumFscode = arraysize(kAc3SampleRateTable);
108  DCHECK_LT(fscod_, kNumFscode);
109  DCHECK_LT(frmsizecod_, arraysize(kFrameSizeCodeTable));
110  // The order of frequencies are reversed in |kFrameSizeCodeTable| compared to
111  // |kAc3SampleRateTable|.
112  const int index = kNumFscode - 1 - fscod_;
113  return kFrameSizeCodeTable[frmsizecod_][index] * 2;
114 }
115 
116 void Ac3Header::GetAudioSpecificConfig(std::vector<uint8_t>* buffer) const {
117  DCHECK(buffer);
118  buffer->clear();
119  BitWriter config(buffer);
120  // Accoding to ETSI TS 102 366 V1.3.1 (2014-08) F.4 AC3SpecificBox.
121  config.WriteBits(fscod_, 2);
122  config.WriteBits(bsid_, 5);
123  config.WriteBits(bsmod_, 3);
124  config.WriteBits(acmod_, 3);
125  config.WriteBits(lfeon_, 1);
126  const uint8_t bit_rate_code = frmsizecod_ >> 1;
127  config.WriteBits(bit_rate_code, 5);
128  config.Flush();
129 }
130 
131 uint8_t Ac3Header::GetObjectType() const {
132  // Only useful for AAC. Return a dummy value instead.
133  return 0;
134 }
135 
137  DCHECK_LT(fscod_, arraysize(kAc3SampleRateTable));
138  return kAc3SampleRateTable[fscod_];
139 }
140 
141 uint8_t Ac3Header::GetNumChannels() const {
142  DCHECK_LT(acmod_, arraysize(kAc3NumChannelsTable));
143  return kAc3NumChannelsTable[acmod_] + (lfeon_ ? 1 : 0);
144 }
145 
146 } // namespace mp2t
147 } // namespace media
148 } // namespace shaka
bool ReadBits(size_t num_bits, T *out)
Definition: bit_reader.h:35
size_t GetHeaderSize() const override
Definition: ac3_header.cc:100
A class to read bit streams.
Definition: bit_reader.h:17
bool IsSyncWord(const uint8_t *buf) const override
Definition: ac3_header.cc:45
All the methods that are virtual are virtual for mocking.
size_t GetMinFrameSize() const override
Definition: ac3_header.cc:51
uint32_t GetSamplingFrequency() const override
Definition: ac3_header.cc:136
size_t GetFrameSize() const override
Definition: ac3_header.cc:106
bool SkipBits(size_t num_bits)
Definition: bit_reader.cc:24
uint8_t GetObjectType() const override
Definition: ac3_header.cc:131
bool Parse(const uint8_t *adts_frame, size_t adts_frame_size) override
Definition: ac3_header.cc:64
void WriteBits(uint32_t bits, size_t number_of_bits)
Definition: bit_writer.cc:15
size_t GetSamplesPerFrame() const override
Definition: ac3_header.cc:57
uint8_t GetNumChannels() const override
Definition: ac3_header.cc:141
void GetAudioSpecificConfig(std::vector< uint8_t > *buffer) const override
Definition: ac3_header.cc:116
void Flush()
Write pending bits, and align bitstream with extra zero bits.
Definition: bit_writer.cc:31