| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "media/formats/mpeg/adts_header_parser.h" | 5 #include "media/formats/mpeg/adts_header_parser.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <vector> | 8 #include <vector> |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "media/base/audio_codecs.h" | 10 #include "media/base/audio_codecs.h" |
| (...skipping 11 matching lines...) Expand all Loading... |
| 22 } | 22 } |
| 23 | 23 |
| 24 size_t ExtractAdtsChannelConfig(const uint8_t* adts_header) { | 24 size_t ExtractAdtsChannelConfig(const uint8_t* adts_header) { |
| 25 return (((adts_header[3] >> 6) & 0x3) | ((adts_header[2] & 0x1) << 2)); | 25 return (((adts_header[3] >> 6) & 0x3) | ((adts_header[2] & 0x1) << 2)); |
| 26 } | 26 } |
| 27 | 27 |
| 28 } // namespace (anonymous) | 28 } // namespace (anonymous) |
| 29 | 29 |
| 30 bool ParseAdtsHeader(const uint8_t* adts_header, | 30 bool ParseAdtsHeader(const uint8_t* adts_header, |
| 31 bool is_sbr, | 31 bool is_sbr, |
| 32 AudioDecoderConfig* config) { | 32 AudioDecoderConfig* config, |
| 33 size_t* orig_sample_freq) { |
| 33 DCHECK(adts_header); | 34 DCHECK(adts_header); |
| 35 DCHECK(orig_sample_freq); |
| 34 | 36 |
| 35 size_t frequency_index = ExtractAdtsFrequencyIndex(adts_header); | 37 size_t frequency_index = ExtractAdtsFrequencyIndex(adts_header); |
| 36 if (frequency_index >= kADTSFrequencyTableSize) { | 38 if (frequency_index >= kADTSFrequencyTableSize) { |
| 37 // Frequency index 13 & 14 are reserved | 39 // Frequency index 13 & 14 are reserved |
| 38 // while 15 means that the frequency is explicitly written | 40 // while 15 means that the frequency is explicitly written |
| 39 // (not supported). | 41 // (not supported). |
| 40 return false; | 42 return false; |
| 41 } | 43 } |
| 42 | 44 |
| 43 size_t channel_configuration = ExtractAdtsChannelConfig(adts_header); | 45 size_t channel_configuration = ExtractAdtsChannelConfig(adts_header); |
| 44 if (channel_configuration == 0 || | 46 if (channel_configuration == 0 || |
| 45 channel_configuration >= kADTSChannelLayoutTableSize) { | 47 channel_configuration >= kADTSChannelLayoutTableSize) { |
| 46 // TODO(damienv): Add support for inband channel configuration. | 48 // TODO(damienv): Add support for inband channel configuration. |
| 47 return false; | 49 return false; |
| 48 } | 50 } |
| 49 | 51 |
| 50 // TODO(damienv): support HE-AAC frequency doubling (SBR) | 52 // TODO(damienv): support HE-AAC frequency doubling (SBR) |
| 51 // based on the incoming ADTS profile. | 53 // based on the incoming ADTS profile. |
| 52 int samples_per_second = kADTSFrequencyTable[frequency_index]; | 54 int samples_per_second = kADTSFrequencyTable[frequency_index]; |
| 53 int adts_profile = (adts_header[2] >> 6) & 0x3; | 55 int adts_profile = (adts_header[2] >> 6) & 0x3; |
| 54 | 56 |
| 55 // The following code is written according to ISO 14496 Part 3 Table 1.11 and | 57 // The following code is written according to ISO 14496 Part 3 Table 1.11 and |
| 56 // Table 1.22. (Table 1.11 refers to the capping to 48000, Table 1.22 refers | 58 // Table 1.22. (Table 1.11 refers to the capping to 48000, Table 1.22 refers |
| 57 // to SBR doubling the AAC sample rate.) | 59 // to SBR doubling the AAC sample rate.) |
| 58 // TODO(damienv) : Extend sample rate cap to 96kHz for Level 5 content. | 60 // TODO(damienv) : Extend sample rate cap to 96kHz for Level 5 content. |
| 59 int extended_samples_per_second = | 61 int extended_samples_per_second = |
| 60 is_sbr ? std::min(2 * samples_per_second, 48000) : samples_per_second; | 62 is_sbr ? std::min(2 * samples_per_second, 48000) : samples_per_second; |
| 63 *orig_sample_freq = samples_per_second; |
| 61 | 64 |
| 62 // The following code is written according to ISO 14496 Part 3 Table 1.13 - | 65 // The following code is written according to ISO 14496 Part 3 Table 1.13 - |
| 63 // Syntax of AudioSpecificConfig. | 66 // Syntax of AudioSpecificConfig. |
| 64 uint16_t extra_data_int = static_cast<uint16_t>( | 67 uint16_t extra_data_int = static_cast<uint16_t>( |
| 65 // Note: adts_profile is in the range [0,3], since the ADTS header only | 68 // Note: adts_profile is in the range [0,3], since the ADTS header only |
| 66 // allows two bits for its value. | 69 // allows two bits for its value. |
| 67 ((adts_profile + 1) << 11) + | 70 ((adts_profile + 1) << 11) + |
| 68 // frequency_index is [0..13], per early out above. | 71 // frequency_index is [0..13], per early out above. |
| 69 (frequency_index << 7) + | 72 (frequency_index << 7) + |
| 70 // channel_configuration is [0..7], per early out above. | 73 // channel_configuration is [0..7], per early out above. |
| 71 (channel_configuration << 3)); | 74 (channel_configuration << 3)); |
| 72 std::vector<uint8_t> extra_data; | 75 std::vector<uint8_t> extra_data; |
| 73 extra_data.push_back(static_cast<uint8_t>(extra_data_int >> 8)); | 76 extra_data.push_back(static_cast<uint8_t>(extra_data_int >> 8)); |
| 74 extra_data.push_back(static_cast<uint8_t>(extra_data_int & 0xff)); | 77 extra_data.push_back(static_cast<uint8_t>(extra_data_int & 0xff)); |
| 75 | 78 |
| 76 DCHECK(config); | 79 DCHECK(config); |
| 77 *config = AudioDecoderConfig(kCodecAAC, kSampleFormatS16, | 80 *config = AudioDecoderConfig(kCodecAAC, kSampleFormatS16, |
| 78 kADTSChannelLayoutTable[channel_configuration], | 81 kADTSChannelLayoutTable[channel_configuration], |
| 79 extended_samples_per_second, extra_data, | 82 extended_samples_per_second, extra_data, |
| 80 Unencrypted()); | 83 Unencrypted()); |
| 81 | 84 |
| 82 return true; | 85 return true; |
| 83 } | 86 } |
| 84 | 87 |
| 85 } // namespace media | 88 } // namespace media |
| OLD | NEW |