ATSParser.cpp revision 82f7321b03eec1e40af9d681370f754ee0279582
1cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber/* 2cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * Copyright (C) 2010 The Android Open Source Project 3cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * 4cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * Licensed under the Apache License, Version 2.0 (the "License"); 5cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * you may not use this file except in compliance with the License. 6cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * You may obtain a copy of the License at 7cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * 8cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * http://www.apache.org/licenses/LICENSE-2.0 9cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * 10cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * Unless required by applicable law or agreed to in writing, software 11cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * distributed under the License is distributed on an "AS IS" BASIS, 12cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * See the License for the specific language governing permissions and 14cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber * limitations under the License. 15cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber */ 16cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 17cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include "ATSParser.h" 18cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 19cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include "AnotherPacketSource.h" 2085f12e9b9062402d6110df3f7099707912040edbAndreas Huber#include "include/avc_utils.h" 21cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 2285f12e9b9062402d6110df3f7099707912040edbAndreas Huber#include <media/stagefright/foundation/ABitReader.h> 23cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/ABuffer.h> 24cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/ADebug.h> 25cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/AMessage.h> 26cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/hexdump.h> 27cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/MediaDefs.h> 28cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/MediaErrors.h> 29cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/MetaData.h> 30cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <utils/KeyedVector.h> 31cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 32cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubernamespace android { 33cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 34cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic const size_t kTSPacketSize = 188; 35cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 36cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstruct ATSParser::Program : public RefBase { 37cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber Program(unsigned programMapPID); 38cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 39cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool parsePID( 40cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned pid, unsigned payload_unit_start_indicator, 41cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br); 42cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 43cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> getSource(SourceType type); 44cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 45cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberprivate: 46cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned mProgramMapPID; 47cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber KeyedVector<unsigned, sp<Stream> > mStreams; 48cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 49cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void parseProgramMap(ABitReader *br); 50cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 51cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DISALLOW_EVIL_CONSTRUCTORS(Program); 52cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber}; 53cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 54cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstruct ATSParser::Stream : public RefBase { 55cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber Stream(unsigned elementaryPID, unsigned streamType); 56cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 57cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void parse( 58cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator, 59cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br); 60cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 61cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> getSource(SourceType type); 62cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 63cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberprotected: 64cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber virtual ~Stream(); 65cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 66cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberprivate: 67cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned mElementaryPID; 68cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned mStreamType; 69cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 70cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> mBuffer; 71cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<AnotherPacketSource> mSource; 72cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool mPayloadStarted; 73cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 74cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void flush(); 75cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void parsePES(ABitReader *br); 76cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 77cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void onPayloadData( 78cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PTS_DTS_flags, uint64_t PTS, uint64_t DTS, 79cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data, size_t size); 80cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 8182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber void extractAACFrames(const sp<ABuffer> &buffer); 8282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 83cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DISALLOW_EVIL_CONSTRUCTORS(Stream); 84cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber}; 85cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 86cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber//////////////////////////////////////////////////////////////////////////////// 87cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 88cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::Program::Program(unsigned programMapPID) 89cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber : mProgramMapPID(programMapPID) { 90cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 91cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 92cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberbool ATSParser::Program::parsePID( 93cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned pid, unsigned payload_unit_start_indicator, 94cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br) { 95cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (pid == mProgramMapPID) { 96cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (payload_unit_start_indicator) { 97cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned skip = br->getBits(8); 98cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(skip * 8); 99cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 100cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 101cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseProgramMap(br); 102cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 103cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 104cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 105cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ssize_t index = mStreams.indexOfKey(pid); 106cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (index < 0) { 107cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return false; 108cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 109cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 110cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreams.editValueAt(index)->parse( 111cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber payload_unit_start_indicator, br); 112cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 113cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 114cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 115cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 116cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Program::parseProgramMap(ABitReader *br) { 117cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned table_id = br->getBits(8); 118cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " table_id = " << table_id; 119cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(table_id, 0x02u); 120cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 121cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned section_syntax_indictor = br->getBits(1); 122cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " section_syntax_indictor = " << section_syntax_indictor; 123cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(section_syntax_indictor, 1u); 124cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 125cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 0u); 126cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(2); 127cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 128cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned section_length = br->getBits(12); 129cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " section_length = " << section_length; 130cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((section_length & 0xc00) == 0); 131cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LE(section_length, 1021u); 132cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 133cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " program_number = " << br->getBits(16); 134cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(2); 135cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " version_number = " << br->getBits(5); 136cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " current_next_indicator = " << br->getBits(1); 137cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " section_number = " << br->getBits(8); 138cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " last_section_number = " << br->getBits(8); 139cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(3); 140cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 141cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " PCR_PID = " 142cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%04x", br->getBits(13)); 143cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 144cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(4); 145cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 146cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned program_info_length = br->getBits(12); 147cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " program_info_length = " << program_info_length; 148cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((program_info_length & 0xc00) == 0); 149cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 150cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(program_info_length * 8); // skip descriptors 151cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 152cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // infoBytesRemaining is the number of bytes that make up the 153cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // variable length section of ES_infos. It does not include the 154cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // final CRC. 155cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t infoBytesRemaining = section_length - 9 - program_info_length - 4; 156cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 157cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (infoBytesRemaining > 0) { 158cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(infoBytesRemaining, 5u); 159cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 160cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned streamType = br->getBits(8); 161cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " stream_type = " 162cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%02x", streamType); 163cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 164cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(3); 165cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 166cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned elementaryPID = br->getBits(13); 167cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " elementary_PID = " 168cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%04x", elementaryPID); 169cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 170cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(4); 171cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 172cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned ES_info_length = br->getBits(12); 173cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " ES_info_length = " << ES_info_length; 174cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((ES_info_length & 0xc00) == 0); 175cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 176cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(infoBytesRemaining - 5, ES_info_length); 177cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 178cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#if 0 179cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(ES_info_length * 8); // skip descriptors 180cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#else 181cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned info_bytes_remaining = ES_info_length; 182cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (info_bytes_remaining >= 2) { 183cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " tag = " << StringPrintf("0x%02x", br->getBits(8)); 184cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 185cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned descLength = br->getBits(8); 186cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " len = " << descLength; 187cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 188cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(info_bytes_remaining, 2 + descLength); 189cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 190cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(descLength * 8); 191cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 192cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber info_bytes_remaining -= descLength + 2; 193cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 194cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(info_bytes_remaining, 0u); 195cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#endif 196cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 197cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ssize_t index = mStreams.indexOfKey(elementaryPID); 198cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#if 0 // XXX revisit 199cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LT(index, 0); 200cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreams.add(elementaryPID, new Stream(elementaryPID, streamType)); 201cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#else 202cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (index < 0) { 203cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreams.add(elementaryPID, new Stream(elementaryPID, streamType)); 204cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 205cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#endif 206cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 207cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber infoBytesRemaining -= 5 + ES_info_length; 208cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 209cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 210cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(infoBytesRemaining, 0u); 211cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 212cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " CRC = " << StringPrintf("0x%08x", br->getBits(32)); 213cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 214cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 215cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<MediaSource> ATSParser::Program::getSource(SourceType type) { 216cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < mStreams.size(); ++i) { 217cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> source = mStreams.editValueAt(i)->getSource(type); 218cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (source != NULL) { 219cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return source; 220cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 221cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 222cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 223cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 224cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 225cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 226cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber//////////////////////////////////////////////////////////////////////////////// 227cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 228cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::Stream::Stream(unsigned elementaryPID, unsigned streamType) 229cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber : mElementaryPID(elementaryPID), 230cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreamType(streamType), 23182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber mBuffer(new ABuffer(128 * 1024)), 232cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mPayloadStarted(false) { 233cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mBuffer->setRange(0, 0); 234cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 235cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 236cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::Stream::~Stream() { 237cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 238cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 239cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::parse( 240cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator, ABitReader *br) { 241cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (payload_unit_start_indicator) { 242cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mPayloadStarted) { 243cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // Otherwise we run the danger of receiving the trailing bytes 244cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // of a PES packet that we never saw the start of and assuming 245cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // we have a a complete PES packet. 246cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 247cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber flush(); 248cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 249cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 250cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mPayloadStarted = true; 251cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 252cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 253cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (!mPayloadStarted) { 254cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 255cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 256cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 257cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t payloadSizeBits = br->numBitsLeft(); 258cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(payloadSizeBits % 8, 0u); 259cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 260cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LE(mBuffer->size() + payloadSizeBits / 8, mBuffer->capacity()); 261cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 262cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(mBuffer->data() + mBuffer->size(), br->data(), payloadSizeBits / 8); 263cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mBuffer->setRange(0, mBuffer->size() + payloadSizeBits / 8); 264cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 265cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 266cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::parsePES(ABitReader *br) { 267cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned packet_startcode_prefix = br->getBits(24); 268cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 269cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "packet_startcode_prefix = " 270cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%08x", packet_startcode_prefix); 271cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 272cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(packet_startcode_prefix, 0x000001u); 273cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 274cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned stream_id = br->getBits(8); 275cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "stream_id = " << StringPrintf("0x%02x", stream_id); 276cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 277cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PES_packet_length = br->getBits(16); 278cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PES_packet_length = " << PES_packet_length; 279cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 280cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (stream_id != 0xbc // program_stream_map 281cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xbe // padding_stream 282cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xbf // private_stream_2 283cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf0 // ECM 284cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf1 // EMM 285cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xff // program_stream_directory 286cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf2 // DSMCC 287cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf8) { // H.222.1 type E 288cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(2), 2u); 289cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 290cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PES_scrambling_control = " << br->getBits(2); 291cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PES_priority = " << br->getBits(1); 292cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "data_alignment_indicator = " << br->getBits(1); 293cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "copyright = " << br->getBits(1); 294cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "original_or_copy = " << br->getBits(1); 295cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 296cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PTS_DTS_flags = br->getBits(2); 297cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PTS_DTS_flags = " << PTS_DTS_flags; 298cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 299cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned ESCR_flag = br->getBits(1); 300cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "ESCR_flag = " << ESCR_flag; 301cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 302cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned ES_rate_flag = br->getBits(1); 303cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "ES_rate_flag = " << ES_rate_flag; 304cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 305cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned DSM_trick_mode_flag = br->getBits(1); 306cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "DSM_trick_mode_flag = " << DSM_trick_mode_flag; 307cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 308cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned additional_copy_info_flag = br->getBits(1); 309cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "additional_copy_info_flag = " 310cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << additional_copy_info_flag; 311cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 312cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PES_CRC_flag = " << br->getBits(1); 313cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PES_extension_flag = " << br->getBits(1); 314cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 315cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PES_header_data_length = br->getBits(8); 316cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PES_header_data_length = " << PES_header_data_length; 317cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 318cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned optional_bytes_remaining = PES_header_data_length; 319cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 320cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber uint64_t PTS = 0, DTS = 0; 321cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 322cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PTS_DTS_flags == 2 || PTS_DTS_flags == 3) { 323cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 5u); 324cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 325cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(4), PTS_DTS_flags); 326cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 327cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PTS = ((uint64_t)br->getBits(3)) << 30; 328cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 329cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PTS |= ((uint64_t)br->getBits(15)) << 15; 330cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 331cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PTS |= br->getBits(15); 332cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 333cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 334cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PTS = " << PTS; 335cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // LOG(INFO) << "PTS = " << PTS / 90000.0f << " secs"; 336cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 337cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 5; 338cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 339cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PTS_DTS_flags == 3) { 340cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 5u); 341cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 342cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(4), 1u); 343cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 344cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DTS = ((uint64_t)br->getBits(3)) << 30; 345cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 346cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DTS |= ((uint64_t)br->getBits(15)) << 15; 347cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 348cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DTS |= br->getBits(15); 349cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 350cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 351cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "DTS = " << DTS; 352cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 353cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 5; 354cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 355cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 356cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 357cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (ESCR_flag) { 358cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 6u); 359cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 360cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->getBits(2); 361cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 362cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber uint64_t ESCR = ((uint64_t)br->getBits(3)) << 30; 363cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 364cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ESCR |= ((uint64_t)br->getBits(15)) << 15; 365cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 366cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ESCR |= br->getBits(15); 367cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 368cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 369cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "ESCR = " << ESCR; 370cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "ESCR_extension = " << br->getBits(9); 371cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 372cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 373cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 374cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 6; 375cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 376cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 377cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (ES_rate_flag) { 378cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 3u); 379cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 380cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 381cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "ES_rate = " << br->getBits(22); 382cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 383cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 384cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 3; 385cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 386cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 387cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(optional_bytes_remaining * 8); 388cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 389cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // ES data follows. 390cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 391cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber onPayloadData( 392cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PTS_DTS_flags, PTS, DTS, 393cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->data(), br->numBitsLeft() / 8); 394cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 395cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PES_packet_length != 0) { 396cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(PES_packet_length, PES_header_data_length + 3); 397cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 398cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned dataLength = 399cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PES_packet_length - 3 - PES_header_data_length; 400cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 401cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->numBitsLeft(), dataLength * 8); 402cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 403cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(dataLength * 8); 404cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 405cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t payloadSizeBits = br->numBitsLeft(); 406cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((payloadSizeBits % 8) == 0); 407cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 408cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "There's " << (payloadSizeBits / 8) 409cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << " bytes of payload."; 410cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 411cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else if (stream_id == 0xbe) { // padding_stream 412cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(PES_packet_length, 0u); 413cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(PES_packet_length * 8); 414cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 415cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(PES_packet_length, 0u); 416cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(PES_packet_length * 8); 417cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 418cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 419cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 420cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::flush() { 421cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mBuffer->size() == 0) { 422cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 423cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 424cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 425cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "flushing stream " 426cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%04x", mElementaryPID) 427cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << " size = " << mBuffer->size(); 428cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 429cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader br(mBuffer->data(), mBuffer->size()); 430cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parsePES(&br); 431cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 432cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mBuffer->setRange(0, 0); 433cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 434cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 435cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic sp<ABuffer> FindNAL( 436cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data, size_t size, unsigned nalType, 437cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t *stopOffset) { 438cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool foundStart = false; 439cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t startOffset = 0; 440cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 441cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t offset = 0; 442cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (;;) { 443cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (offset + 3 < size 444cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && memcmp("\x00\x00\x00\x01", &data[offset], 4)) { 445cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 446cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 447cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 448cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (foundStart) { 449cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t nalSize; 450cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (offset + 3 >= size) { 451cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber nalSize = size - startOffset; 452cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 453cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber nalSize = offset - startOffset; 454cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 455cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 456cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> nal = new ABuffer(nalSize); 457cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(nal->data(), &data[startOffset], nalSize); 458cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 459cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (stopOffset != NULL) { 460cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *stopOffset = startOffset + nalSize; 461cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 462cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 463cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return nal; 464cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 465cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 466cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (offset + 4 >= size) { 467cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 468cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 469cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 470cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if ((data[offset + 4] & 0x1f) == nalType) { 471cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber foundStart = true; 472cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber startOffset = offset + 4; 473cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 474cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 475cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber offset += 4; 476cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 477cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 478cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 479cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic sp<ABuffer> MakeAVCCodecSpecificData( 480cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const sp<ABuffer> &buffer, int32_t *width, int32_t *height) { 481cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data = buffer->data(); 482cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t size = buffer->size(); 483cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 484cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> seqParamSet = FindNAL(data, size, 7, NULL); 485cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (seqParamSet == NULL) { 486cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 487cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 488cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 48985f12e9b9062402d6110df3f7099707912040edbAndreas Huber FindAVCDimensions(seqParamSet, width, height); 490cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 491cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t stopOffset; 492cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> picParamSet = FindNAL(data, size, 8, &stopOffset); 493cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK(picParamSet != NULL); 494cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 495cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer->setRange(stopOffset, size - stopOffset); 496cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(INFO) << "buffer has " << buffer->size() << " bytes left."; 497cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 498cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t csdSize = 499cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 1 + 3 + 1 + 1 500cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber + 2 * 1 + seqParamSet->size() 501cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber + 1 + 2 * 1 + picParamSet->size(); 502cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 503cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = new ABuffer(csdSize); 504cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber uint8_t *out = csd->data(); 505cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 506cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = 0x01; // configurationVersion 507cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(out, seqParamSet->data() + 1, 3); // profile/level... 508cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber out += 3; 509cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = (0x3f << 2) | 1; // lengthSize == 2 bytes 510cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = 0xe0 | 1; 511cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 512cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = seqParamSet->size() >> 8; 513cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = seqParamSet->size() & 0xff; 514cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(out, seqParamSet->data(), seqParamSet->size()); 515cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber out += seqParamSet->size(); 516cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 517cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = 1; 518cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 519cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = picParamSet->size() >> 8; 520cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = picParamSet->size() & 0xff; 521cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(out, picParamSet->data(), picParamSet->size()); 522cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 523cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return csd; 524cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 525cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 526cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic bool getNextNALUnit( 527cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t **_data, size_t *_size, 528cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t **nalStart, size_t *nalSize) { 529cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data = *_data; 530cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t size = *_size; 531cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 532cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalStart = NULL; 533cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalSize = 0; 534cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 535cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (size == 0) { 536cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return false; 537cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 538cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 539cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t offset = 0; 540cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (;;) { 541cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LT(offset + 2, size); 542cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 543cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (!memcmp("\x00\x00\x01", &data[offset], 3)) { 544cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber break; 545cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 546cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 547cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ((unsigned)data[offset], 0x00u); 548cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 549cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 550cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 551cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber offset += 3; 552cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t startOffset = offset; 553cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 554cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (offset + 2 < size 555cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && memcmp("\x00\x00\x00", &data[offset], 3) 556cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && memcmp("\x00\x00\x01", &data[offset], 3)) { 557cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 558cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 559cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 560cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (offset + 2 >= size) { 561cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalStart = &data[startOffset]; 562cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalSize = size - startOffset; 563cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 564cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *_data = NULL; 565cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *_size = 0; 566cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 567cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 568cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 569cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 570cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t endOffset = offset; 571cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 572cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (offset + 2 < size && memcmp("\x00\x00\x01", &data[offset], 3)) { 573cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ((unsigned)data[offset], 0x00u); 574cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 575cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 576cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 577cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LT(offset + 2, size); 578cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 579cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalStart = &data[startOffset]; 580cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalSize = endOffset - startOffset; 581cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 582cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *_data = &data[offset]; 583cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *_size = size - offset; 584cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 585cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 586cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 587cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 588cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<ABuffer> MakeCleanAVCData(const uint8_t *data, size_t size) { 589cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *tmpData = data; 590cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t tmpSize = size; 591cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 592cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t totalSize = 0; 593cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *nalStart; 594cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t nalSize; 595cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (getNextNALUnit(&tmpData, &tmpSize, &nalStart, &nalSize)) { 596cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber totalSize += 4 + nalSize; 597cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 598cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 599cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> buffer = new ABuffer(totalSize); 600cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t offset = 0; 601cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (getNextNALUnit(&data, &size, &nalStart, &nalSize)) { 602cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(buffer->data() + offset, "\x00\x00\x00\x01", 4); 603cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(buffer->data() + offset + 4, nalStart, nalSize); 604cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 605cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber offset += 4 + nalSize; 606cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 607cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 608cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return buffer; 609cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 610cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 611cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic sp<ABuffer> FindMPEG2ADTSConfig( 612cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const sp<ABuffer> &buffer, int32_t *sampleRate, int32_t *channelCount) { 613cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader br(buffer->data(), buffer->size()); 614cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 615cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br.getBits(12), 0xfffu); 616cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br.getBits(1), 0u); 617cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br.getBits(2), 0u); 618cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br.getBits(1); // protection_absent 619cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned profile = br.getBits(2); 620cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(INFO) << "profile = " << profile; 621cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(profile, 3u); 622cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned sampling_freq_index = br.getBits(4); 623cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br.getBits(1); // private_bit 624cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned channel_configuration = br.getBits(3); 625cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(channel_configuration, 0u); 626cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 627cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(INFO) << "sampling_freq_index = " << sampling_freq_index; 628cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(INFO) << "channel_configuration = " << channel_configuration; 629cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 630cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LE(sampling_freq_index, 11u); 631cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber static const int32_t kSamplingFreq[] = { 632cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 633cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 16000, 12000, 11025, 8000 634cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber }; 635cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *sampleRate = kSamplingFreq[sampling_freq_index]; 636cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 637cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *channelCount = channel_configuration; 638cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 639cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber static const uint8_t kStaticESDS[] = { 640cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x03, 22, 641cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, // ES_ID 642cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, // streamDependenceFlag, URL_Flag, OCRstreamFlag 643cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 644cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x04, 17, 645cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x40, // Audio ISO/IEC 14496-3 646cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, 0x00, 0x00, 647cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, 0x00, 0x00, 648cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, 0x00, 0x00, 649cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 650cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x05, 2, 651cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // AudioSpecificInfo follows 652cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 653cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // oooo offf fccc c000 654cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // o - audioObjectType 655cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // f - samplingFreqIndex 656cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // c - channelConfig 657cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber }; 658cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = new ABuffer(sizeof(kStaticESDS) + 2); 659cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(csd->data(), kStaticESDS, sizeof(kStaticESDS)); 660cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 661cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber csd->data()[sizeof(kStaticESDS)] = 662cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ((profile + 1) << 3) | (sampling_freq_index >> 1); 663cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 664cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber csd->data()[sizeof(kStaticESDS) + 1] = 665cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ((sampling_freq_index << 7) & 0x80) | (channel_configuration << 3); 666cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 66782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // hexdump(csd->data(), csd->size()); 668cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return csd; 669cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 670cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 671cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::onPayloadData( 672cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PTS_DTS_flags, uint64_t PTS, uint64_t DTS, 673cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data, size_t size) { 674cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "onPayloadData mStreamType=" 675cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%02x", mStreamType); 676cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 677cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> buffer; 678cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 679cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mStreamType == 0x1b) { 680cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer = MakeCleanAVCData(data, size); 681cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 682cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // hexdump(data, size); 683cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 684cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer = new ABuffer(size); 685cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(buffer->data(), data, size); 686cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 687cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 688cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mSource == NULL) { 689cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MetaData> meta = new MetaData; 690cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 691cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mStreamType == 0x1b) { 692cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setCString(kKeyMIMEType, MEDIA_MIMETYPE_VIDEO_AVC); 693cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 694cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber int32_t width, height; 695cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = MakeAVCCodecSpecificData(buffer, &width, &height); 696cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 697cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (csd == NULL) { 698cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 699cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 700cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 701cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setData(kKeyAVCC, 0, csd->data(), csd->size()); 702cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeyWidth, width); 703cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeyHeight, height); 704cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 705cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(mStreamType, 0x0fu); 706cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 707cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setCString(kKeyMIMEType, MEDIA_MIMETYPE_AUDIO_AAC); 708cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 709cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber int32_t sampleRate, channelCount; 710cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = 711cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber FindMPEG2ADTSConfig(buffer, &sampleRate, &channelCount); 712cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 713cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(INFO) << "sampleRate = " << sampleRate; 714cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(INFO) << "channelCount = " << channelCount; 715cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 716cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeySampleRate, sampleRate); 717cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeyChannelCount, channelCount); 718cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 719cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setData(kKeyESDS, 0, csd->data(), csd->size()); 720cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 721cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 722cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(INFO) << "created source!"; 723cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mSource = new AnotherPacketSource(meta); 724cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 725cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // fall through 726cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 727cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 728cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK(PTS_DTS_flags == 2 || PTS_DTS_flags == 3); 729cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer->meta()->setInt64("time", (PTS * 100) / 9); 730cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 731cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mStreamType == 0x0f) { 73282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber extractAACFrames(buffer); 733cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 734cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 735cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mSource->queueAccessUnit(buffer); 736cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 737cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 73882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber// Disassemble one or more ADTS frames into their constituent parts and 73982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber// leave only the concatenated raw_data_blocks in the buffer. 74082f7321b03eec1e40af9d681370f754ee0279582Andreas Hubervoid ATSParser::Stream::extractAACFrames(const sp<ABuffer> &buffer) { 74182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber size_t dstOffset = 0; 74282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 74382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber size_t offset = 0; 74482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber while (offset < buffer->size()) { 74582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_LE(offset + 7, buffer->size()); 74682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 74782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber ABitReader bits(buffer->data() + offset, buffer->size() - offset); 74882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 74982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // adts_fixed_header 75082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 75182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_EQ(bits.getBits(12), 0xfffu); 75282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(3); // ID, layer 75382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bool protection_absent = bits.getBits(1) != 0; 75482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 75582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // profile_ObjectType, sampling_frequency_index, private_bits, 75682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // channel_configuration, original_copy, home 75782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(12); 75882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 75982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // adts_variable_header 76082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 76182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // copyright_identification_bit, copyright_identification_start 76282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(2); 76382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 76482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber unsigned aac_frame_length = bits.getBits(13); 76582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 76682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(11); // adts_buffer_fullness 76782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 76882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber unsigned number_of_raw_data_blocks_in_frame = bits.getBits(2); 76982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 77082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber if (number_of_raw_data_blocks_in_frame == 0) { 77182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber size_t scan = offset + aac_frame_length; 77282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 77382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber offset += 7; 77482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber if (!protection_absent) { 77582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber offset += 2; 77682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } 77782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 77882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_LE(scan, buffer->size()); 77982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 78082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber LOG(VERBOSE) 78182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber << "found aac raw data block at [" 78282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber << StringPrintf("0x%08x", offset) 78382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber << " ; " 78482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber << StringPrintf("0x%08x", scan) 78582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber << ")"; 78682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 78782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber memmove(&buffer->data()[dstOffset], &buffer->data()[offset], 78882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber scan - offset); 78982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 79082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber dstOffset += scan - offset; 79182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber offset = scan; 79282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } else { 79382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // To be implemented. 79482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber TRESPASS(); 79582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } 79682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } 79782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_EQ(offset, buffer->size()); 79882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 79982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber buffer->setRange(buffer->offset(), dstOffset); 80082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber} 80182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 802cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<MediaSource> ATSParser::Stream::getSource(SourceType type) { 803cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if ((type == AVC_VIDEO && mStreamType == 0x1b) 804cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber || (type == MPEG2ADTS_AUDIO && mStreamType == 0x0f)) { 805cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return mSource; 806cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 807cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 808cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 809cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 810cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 811cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber//////////////////////////////////////////////////////////////////////////////// 812cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 813cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::ATSParser() { 814cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 815cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 816cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::~ATSParser() { 817cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 818cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 819cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::feedTSPacket(const void *data, size_t size) { 820cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(size, kTSPacketSize); 821cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 822cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader br((const uint8_t *)data, kTSPacketSize); 823cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseTS(&br); 824cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 825cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 826cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::parseProgramAssociationTable(ABitReader *br) { 827cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned table_id = br->getBits(8); 828cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " table_id = " << table_id; 829cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(table_id, 0x00u); 830cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 831cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned section_syntax_indictor = br->getBits(1); 832cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " section_syntax_indictor = " << section_syntax_indictor; 833cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(section_syntax_indictor, 1u); 834cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 835cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 0u); 836cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(2); 837cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 838cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned section_length = br->getBits(12); 839cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " section_length = " << section_length; 840cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((section_length & 0xc00) == 0); 841cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 842cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " transport_stream_id = " << br->getBits(16); 843cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(2); 844cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " version_number = " << br->getBits(5); 845cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " current_next_indicator = " << br->getBits(1); 846cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " section_number = " << br->getBits(8); 847cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " last_section_number = " << br->getBits(8); 848cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 849cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t numProgramBytes = (section_length - 5 /* header */ - 4 /* crc */); 850cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ((numProgramBytes % 4), 0u); 851cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 852cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < numProgramBytes / 4; ++i) { 853cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned program_number = br->getBits(16); 854cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " program_number = " << program_number; 855cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 856cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " reserved = " << br->getBits(3); 857cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 858cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (program_number == 0) { 859cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " network_PID = " 860cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%04x", br->getBits(13)); 861cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 862cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned programMapPID = br->getBits(13); 863cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 864cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " program_map_PID = " 865cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << StringPrintf("0x%04x", programMapPID); 866cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 867cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mPrograms.push(new Program(programMapPID)); 868cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 869cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 870cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 871cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << " CRC = " << StringPrintf("0x%08x", br->getBits(32)); 872cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 873cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 874cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::parsePID( 875cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br, unsigned PID, 876cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator) { 877cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PID == 0) { 878cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (payload_unit_start_indicator) { 879cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned skip = br->getBits(8); 880cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(skip * 8); 881cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 882cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseProgramAssociationTable(br); 883cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 884cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 885cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 886cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool handled = false; 887cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < mPrograms.size(); ++i) { 888cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mPrograms.editItemAt(i)->parsePID( 889cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PID, payload_unit_start_indicator, br)) { 890cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber handled = true; 891cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber break; 892cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 893cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 894cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 895cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (!handled) { 896cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(WARNING) << "PID " << StringPrintf("0x%04x", PID) 897cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << " not handled."; 898cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 899cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 900cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 901cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::parseAdaptationField(ABitReader *br) { 902cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned adaptation_field_length = br->getBits(8); 903cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (adaptation_field_length > 0) { 904cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(adaptation_field_length * 8); // XXX 905cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 906cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 907cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 908cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::parseTS(ABitReader *br) { 909cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "---"; 910cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 911cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned sync_byte = br->getBits(8); 912cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(sync_byte, 0x47u); 913cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 914cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "transport_error_indicator = " << br->getBits(1); 915cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 916cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator = br->getBits(1); 917cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "payload_unit_start_indicator = " 918cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber << payload_unit_start_indicator; 919cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 920cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "transport_priority = " << br->getBits(1); 921cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 922cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PID = br->getBits(13); 923cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "PID = " << StringPrintf("0x%04x", PID); 924cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 925cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "transport_scrambling_control = " << br->getBits(2); 926cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 927cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned adaptation_field_control = br->getBits(2); 928cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "adaptation_field_control = " << adaptation_field_control; 929cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 930cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber LOG(VERBOSE) << "continuity_counter = " << br->getBits(4); 931cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 932cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (adaptation_field_control == 2 || adaptation_field_control == 3) { 933cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseAdaptationField(br); 934cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 935cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 936cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (adaptation_field_control == 1 || adaptation_field_control == 3) { 937cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parsePID(br, PID, payload_unit_start_indicator); 938cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 939cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 940cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 941cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<MediaSource> ATSParser::getSource(SourceType type) { 942cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < mPrograms.size(); ++i) { 943cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> source = mPrograms.editItemAt(i)->getSource(type); 944cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 945cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (source != NULL) { 946cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return source; 947cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 948cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 949cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 950cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 951cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 952cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 953cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} // namespace android 954