ATSParser.cpp revision 0da4dab0a45a2bc1d95cbc6ef6a4850ed2569584
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 176e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber//#define LOG_NDEBUG 0 186e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber#define LOG_TAG "ATSParser" 196e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber#include <utils/Log.h> 206e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber 21cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include "ATSParser.h" 22cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 23cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include "AnotherPacketSource.h" 2485f12e9b9062402d6110df3f7099707912040edbAndreas Huber#include "include/avc_utils.h" 25cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 2685f12e9b9062402d6110df3f7099707912040edbAndreas Huber#include <media/stagefright/foundation/ABitReader.h> 27cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/ABuffer.h> 28cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/ADebug.h> 29cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/AMessage.h> 30cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/foundation/hexdump.h> 31cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/MediaDefs.h> 32cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/MediaErrors.h> 33cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <media/stagefright/MetaData.h> 34cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#include <utils/KeyedVector.h> 35cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 36cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubernamespace android { 37cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 386e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber// I want the expression "y" evaluated even if verbose logging is off. 396e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber#define MY_LOGV(x, y) \ 406e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber do { unsigned tmp = y; LOGV(x, tmp); } while (0) 416e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber 42cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic const size_t kTSPacketSize = 188; 43cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 44cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstruct ATSParser::Program : public RefBase { 45cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber Program(unsigned programMapPID); 46cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 47cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool parsePID( 48cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned pid, unsigned payload_unit_start_indicator, 49cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br); 50cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 51cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> getSource(SourceType type); 52cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 53cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberprivate: 54cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned mProgramMapPID; 55cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber KeyedVector<unsigned, sp<Stream> > mStreams; 56cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 57cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void parseProgramMap(ABitReader *br); 58cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 59cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DISALLOW_EVIL_CONSTRUCTORS(Program); 60cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber}; 61cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 62cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstruct ATSParser::Stream : public RefBase { 63cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber Stream(unsigned elementaryPID, unsigned streamType); 64cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 65cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void parse( 66cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator, 67cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br); 68cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 69cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> getSource(SourceType type); 70cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 71cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberprotected: 72cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber virtual ~Stream(); 73cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 74cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberprivate: 75cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned mElementaryPID; 76cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned mStreamType; 77cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 78cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> mBuffer; 79cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<AnotherPacketSource> mSource; 80cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool mPayloadStarted; 81cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 82cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void flush(); 83cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void parsePES(ABitReader *br); 84cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 85cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber void onPayloadData( 86cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PTS_DTS_flags, uint64_t PTS, uint64_t DTS, 87cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data, size_t size); 88cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 8982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber void extractAACFrames(const sp<ABuffer> &buffer); 9082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 91cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DISALLOW_EVIL_CONSTRUCTORS(Stream); 92cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber}; 93cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 94cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber//////////////////////////////////////////////////////////////////////////////// 95cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 96cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::Program::Program(unsigned programMapPID) 97cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber : mProgramMapPID(programMapPID) { 98cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 99cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 100cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberbool ATSParser::Program::parsePID( 101cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned pid, unsigned payload_unit_start_indicator, 102cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br) { 103cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (pid == mProgramMapPID) { 104cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (payload_unit_start_indicator) { 105cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned skip = br->getBits(8); 106cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(skip * 8); 107cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 108cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 109cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseProgramMap(br); 110cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 111cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 112cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 113cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ssize_t index = mStreams.indexOfKey(pid); 114cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (index < 0) { 115cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return false; 116cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 117cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 118cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreams.editValueAt(index)->parse( 119cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber payload_unit_start_indicator, br); 120cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 121cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 122cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 123cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 124cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Program::parseProgramMap(ABitReader *br) { 125cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned table_id = br->getBits(8); 1266e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" table_id = %u", table_id); 127cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(table_id, 0x02u); 128cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 1296e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber unsigned section_syntax_indicator = br->getBits(1); 1306e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" section_syntax_indicator = %u", section_syntax_indicator); 1316e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber CHECK_EQ(section_syntax_indicator, 1u); 132cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 133cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 0u); 1346e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(2)); 135cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 136cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned section_length = br->getBits(12); 1376e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" section_length = %u", section_length); 138cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((section_length & 0xc00) == 0); 139cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LE(section_length, 1021u); 140cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 1416e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" program_number = %u", br->getBits(16)); 1426e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(2)); 1436e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" version_number = %u", br->getBits(5)); 1446e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" current_next_indicator = %u", br->getBits(1)); 1456e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" section_number = %u", br->getBits(8)); 1466e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" last_section_number = %u", br->getBits(8)); 1476e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(3)); 1486e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" PCR_PID = 0x%04x", br->getBits(13)); 1496e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(4)); 150cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 151cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned program_info_length = br->getBits(12); 1526e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" program_info_length = %u", program_info_length); 153cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((program_info_length & 0xc00) == 0); 154cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 155cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(program_info_length * 8); // skip descriptors 156cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 157cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // infoBytesRemaining is the number of bytes that make up the 158cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // variable length section of ES_infos. It does not include the 159cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // final CRC. 160cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t infoBytesRemaining = section_length - 9 - program_info_length - 4; 161cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 162cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (infoBytesRemaining > 0) { 163cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(infoBytesRemaining, 5u); 164cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 165cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned streamType = br->getBits(8); 1666e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" stream_type = 0x%02x", streamType); 167cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 1686e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(3)); 169cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 170cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned elementaryPID = br->getBits(13); 1716e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" elementary_PID = 0x%04x", elementaryPID); 172cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 1736e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(4)); 174cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 175cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned ES_info_length = br->getBits(12); 1766e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" ES_info_length = %u", ES_info_length); 177cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((ES_info_length & 0xc00) == 0); 178cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 179cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(infoBytesRemaining - 5, ES_info_length); 180cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 181cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#if 0 182cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(ES_info_length * 8); // skip descriptors 183cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#else 184cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned info_bytes_remaining = ES_info_length; 185cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (info_bytes_remaining >= 2) { 1866e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" tag = 0x%02x", br->getBits(8)); 187cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 188cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned descLength = br->getBits(8); 1896e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" len = %u", descLength); 190cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 191cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(info_bytes_remaining, 2 + descLength); 192cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 193cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(descLength * 8); 194cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 195cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber info_bytes_remaining -= descLength + 2; 196cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 197cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(info_bytes_remaining, 0u); 198cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#endif 199cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 200cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ssize_t index = mStreams.indexOfKey(elementaryPID); 201cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#if 0 // XXX revisit 202cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LT(index, 0); 203cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreams.add(elementaryPID, new Stream(elementaryPID, streamType)); 204cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#else 205cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (index < 0) { 206cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreams.add(elementaryPID, new Stream(elementaryPID, streamType)); 207cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 208cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber#endif 209cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 210cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber infoBytesRemaining -= 5 + ES_info_length; 211cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 212cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 213cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(infoBytesRemaining, 0u); 214cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 2156e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" CRC = 0x%08x", br->getBits(32)); 216cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 217cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 218cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<MediaSource> ATSParser::Program::getSource(SourceType type) { 219cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < mStreams.size(); ++i) { 220cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> source = mStreams.editValueAt(i)->getSource(type); 221cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (source != NULL) { 222cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return source; 223cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 224cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 225cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 226cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 227cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 228cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 229cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber//////////////////////////////////////////////////////////////////////////////// 230cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 231cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::Stream::Stream(unsigned elementaryPID, unsigned streamType) 232cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber : mElementaryPID(elementaryPID), 233cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mStreamType(streamType), 23482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber mBuffer(new ABuffer(128 * 1024)), 235cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mPayloadStarted(false) { 236cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mBuffer->setRange(0, 0); 237cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 238cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 239cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::Stream::~Stream() { 240cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 241cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 242cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::parse( 243cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator, ABitReader *br) { 244cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (payload_unit_start_indicator) { 245cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mPayloadStarted) { 246cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // Otherwise we run the danger of receiving the trailing bytes 247cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // of a PES packet that we never saw the start of and assuming 248cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // we have a a complete PES packet. 249cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 250cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber flush(); 251cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 252cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 253cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mPayloadStarted = true; 254cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 255cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 256cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (!mPayloadStarted) { 257cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 258cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 259cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 260cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t payloadSizeBits = br->numBitsLeft(); 2616e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber CHECK((payloadSizeBits % 8) == 0); 262cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 263cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LE(mBuffer->size() + payloadSizeBits / 8, mBuffer->capacity()); 264cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 265cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(mBuffer->data() + mBuffer->size(), br->data(), payloadSizeBits / 8); 266cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mBuffer->setRange(0, mBuffer->size() + payloadSizeBits / 8); 267cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 268cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 269cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::parsePES(ABitReader *br) { 270cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned packet_startcode_prefix = br->getBits(24); 271cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 2726e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("packet_startcode_prefix = 0x%08x", packet_startcode_prefix); 273cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 274cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(packet_startcode_prefix, 0x000001u); 275cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 276cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned stream_id = br->getBits(8); 2776e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("stream_id = 0x%02x", stream_id); 278cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 279cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PES_packet_length = br->getBits(16); 2806e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("PES_packet_length = %u", PES_packet_length); 281cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 282cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (stream_id != 0xbc // program_stream_map 283cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xbe // padding_stream 284cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xbf // private_stream_2 285cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf0 // ECM 286cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf1 // EMM 287cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xff // program_stream_directory 288cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf2 // DSMCC 289cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && stream_id != 0xf8) { // H.222.1 type E 290cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(2), 2u); 291cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 2926e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("PES_scrambling_control = %u", br->getBits(2)); 2936e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("PES_priority = %u", br->getBits(1)); 2946e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("data_alignment_indicator = %u", br->getBits(1)); 2956e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("copyright = %u", br->getBits(1)); 2966e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("original_or_copy = %u", br->getBits(1)); 297cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 298cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PTS_DTS_flags = br->getBits(2); 2996e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("PTS_DTS_flags = %u", PTS_DTS_flags); 300cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 301cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned ESCR_flag = br->getBits(1); 3026e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("ESCR_flag = %u", ESCR_flag); 303cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 304cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned ES_rate_flag = br->getBits(1); 3056e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("ES_rate_flag = %u", ES_rate_flag); 306cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 307cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned DSM_trick_mode_flag = br->getBits(1); 3086e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("DSM_trick_mode_flag = %u", DSM_trick_mode_flag); 309cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 310cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned additional_copy_info_flag = br->getBits(1); 3116e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("additional_copy_info_flag = %u", additional_copy_info_flag); 312cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 3136e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("PES_CRC_flag = %u", br->getBits(1)); 3146e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("PES_extension_flag = %u", br->getBits(1)); 315cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 316cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PES_header_data_length = br->getBits(8); 3176e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("PES_header_data_length = %u", PES_header_data_length); 318cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 319cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned optional_bytes_remaining = PES_header_data_length; 320cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 321cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber uint64_t PTS = 0, DTS = 0; 322cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 323cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PTS_DTS_flags == 2 || PTS_DTS_flags == 3) { 324cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 5u); 325cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 326cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(4), PTS_DTS_flags); 327cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 328cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PTS = ((uint64_t)br->getBits(3)) << 30; 329cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 330cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PTS |= ((uint64_t)br->getBits(15)) << 15; 331cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 332cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PTS |= br->getBits(15); 333cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 334cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 3356e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("PTS = %llu", PTS); 3366e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber // LOGI("PTS = %.2f secs", PTS / 90000.0f); 337cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 338cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 5; 339cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 340cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PTS_DTS_flags == 3) { 341cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 5u); 342cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 343cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(4), 1u); 344cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 345cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DTS = ((uint64_t)br->getBits(3)) << 30; 346cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 347cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DTS |= ((uint64_t)br->getBits(15)) << 15; 348cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 349cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber DTS |= br->getBits(15); 350cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 351cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 3526e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("DTS = %llu", DTS); 353cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 354cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 5; 355cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 356cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 357cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 358cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (ESCR_flag) { 359cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 6u); 360cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 361cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->getBits(2); 362cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 363cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber uint64_t ESCR = ((uint64_t)br->getBits(3)) << 30; 364cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 365cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ESCR |= ((uint64_t)br->getBits(15)) << 15; 366cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 367cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ESCR |= br->getBits(15); 368cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 369cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 3706e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("ESCR = %llu", ESCR); 3716e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("ESCR_extension = %u", br->getBits(9)); 372cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 373cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 374cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 375cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 6; 376cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 377cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 378cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (ES_rate_flag) { 379cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(optional_bytes_remaining, 3u); 380cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 381cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 3826e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("ES_rate = %u", br->getBits(22)); 383cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 1u); 384cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 385cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber optional_bytes_remaining -= 3; 386cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 387cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 388cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(optional_bytes_remaining * 8); 389cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 390cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // ES data follows. 391cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 392cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PES_packet_length != 0) { 393cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_GE(PES_packet_length, PES_header_data_length + 3); 394cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 395cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned dataLength = 396cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PES_packet_length - 3 - PES_header_data_length; 397cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 3980da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber CHECK_GE(br->numBitsLeft(), dataLength * 8); 3990da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber 4000da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber onPayloadData( 4010da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber PTS_DTS_flags, PTS, DTS, br->data(), dataLength); 402cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 403cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(dataLength * 8); 404cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 4050da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber onPayloadData( 4060da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber PTS_DTS_flags, PTS, DTS, 4070da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber br->data(), br->numBitsLeft() / 8); 4080da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber 409cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t payloadSizeBits = br->numBitsLeft(); 410cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((payloadSizeBits % 8) == 0); 411cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 4126e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("There's %d bytes of payload.", payloadSizeBits / 8); 413cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 414cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else if (stream_id == 0xbe) { // padding_stream 415cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(PES_packet_length, 0u); 416cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(PES_packet_length * 8); 417cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 418cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(PES_packet_length, 0u); 419cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(PES_packet_length * 8); 420cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 421cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 422cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 423cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::flush() { 424cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mBuffer->size() == 0) { 425cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 426cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 427cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 4286e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("flushing stream 0x%04x size = %d", mElementaryPID, mBuffer->size()); 429cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 430cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader br(mBuffer->data(), mBuffer->size()); 431cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parsePES(&br); 432cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 433cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mBuffer->setRange(0, 0); 434cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 435cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 436cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic sp<ABuffer> FindNAL( 437cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data, size_t size, unsigned nalType, 438cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t *stopOffset) { 439cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool foundStart = false; 440cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t startOffset = 0; 441cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 442cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t offset = 0; 443cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (;;) { 444cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (offset + 3 < size 445cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && memcmp("\x00\x00\x00\x01", &data[offset], 4)) { 446cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 447cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 448cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 449cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (foundStart) { 450cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t nalSize; 451cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (offset + 3 >= size) { 452cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber nalSize = size - startOffset; 453cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 454cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber nalSize = offset - startOffset; 455cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 456cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 457cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> nal = new ABuffer(nalSize); 458cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(nal->data(), &data[startOffset], nalSize); 459cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 460cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (stopOffset != NULL) { 461cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *stopOffset = startOffset + nalSize; 462cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 463cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 464cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return nal; 465cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 466cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 467cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (offset + 4 >= size) { 468cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 469cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 470cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 471cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if ((data[offset + 4] & 0x1f) == nalType) { 472cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber foundStart = true; 473cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber startOffset = offset + 4; 474cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 475cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 476cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber offset += 4; 477cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 478cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 479cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 480cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic sp<ABuffer> MakeAVCCodecSpecificData( 481cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const sp<ABuffer> &buffer, int32_t *width, int32_t *height) { 482cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data = buffer->data(); 483cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t size = buffer->size(); 484cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 485cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> seqParamSet = FindNAL(data, size, 7, NULL); 486cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (seqParamSet == NULL) { 487cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 488cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 489cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 49085f12e9b9062402d6110df3f7099707912040edbAndreas Huber FindAVCDimensions(seqParamSet, width, height); 491cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 492cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t stopOffset; 493cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> picParamSet = FindNAL(data, size, 8, &stopOffset); 494cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK(picParamSet != NULL); 495cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 496cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer->setRange(stopOffset, size - stopOffset); 4970da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("buffer has %d bytes left.", buffer->size()); 498cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 499cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t csdSize = 500cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 1 + 3 + 1 + 1 501cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber + 2 * 1 + seqParamSet->size() 502cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber + 1 + 2 * 1 + picParamSet->size(); 503cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 504cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = new ABuffer(csdSize); 505cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber uint8_t *out = csd->data(); 506cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 507cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = 0x01; // configurationVersion 508cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(out, seqParamSet->data() + 1, 3); // profile/level... 509cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber out += 3; 510cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = (0x3f << 2) | 1; // lengthSize == 2 bytes 511cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = 0xe0 | 1; 512cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 513cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = seqParamSet->size() >> 8; 514cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = seqParamSet->size() & 0xff; 515cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(out, seqParamSet->data(), seqParamSet->size()); 516cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber out += seqParamSet->size(); 517cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 518cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = 1; 519cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 520cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = picParamSet->size() >> 8; 521cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *out++ = picParamSet->size() & 0xff; 522cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(out, picParamSet->data(), picParamSet->size()); 523cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 524cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return csd; 525cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 526cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 527cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic bool getNextNALUnit( 528cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t **_data, size_t *_size, 529cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t **nalStart, size_t *nalSize) { 530cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data = *_data; 531cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t size = *_size; 532cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 5330da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber // hexdump(data, size); 5340da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber 535cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalStart = NULL; 536cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalSize = 0; 537cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 538cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (size == 0) { 539cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return false; 540cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 541cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 542cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t offset = 0; 543cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (;;) { 544cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LT(offset + 2, size); 545cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 546cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (!memcmp("\x00\x00\x01", &data[offset], 3)) { 547cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber break; 548cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 549cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 550cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ((unsigned)data[offset], 0x00u); 551cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 552cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 553cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 554cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber offset += 3; 555cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t startOffset = offset; 556cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 557cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (offset + 2 < size 558cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && memcmp("\x00\x00\x00", &data[offset], 3) 559cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber && memcmp("\x00\x00\x01", &data[offset], 3)) { 560cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 561cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 562cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 563cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (offset + 2 >= size) { 564cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalStart = &data[startOffset]; 565cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalSize = size - startOffset; 566cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 567cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *_data = NULL; 568cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *_size = 0; 569cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 570cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 571cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 572cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 573cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t endOffset = offset; 574cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 575cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (offset + 2 < size && memcmp("\x00\x00\x01", &data[offset], 3)) { 576cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ((unsigned)data[offset], 0x00u); 577cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ++offset; 578cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 579cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 580cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalStart = &data[startOffset]; 581cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *nalSize = endOffset - startOffset; 582cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 5830da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber if (offset + 2 < size) { 5840da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber *_data = &data[offset]; 5850da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber *_size = size - offset; 5860da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber } else { 5870da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber *_data = NULL; 5880da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber *_size = 0; 5890da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber } 590cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 591cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return true; 592cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 593cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 594cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<ABuffer> MakeCleanAVCData(const uint8_t *data, size_t size) { 5950da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber // hexdump(data, size); 5960da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber 597cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *tmpData = data; 598cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t tmpSize = size; 599cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 600cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t totalSize = 0; 601cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *nalStart; 602cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t nalSize; 603cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (getNextNALUnit(&tmpData, &tmpSize, &nalStart, &nalSize)) { 6040da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber // hexdump(nalStart, nalSize); 605cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber totalSize += 4 + nalSize; 606cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 607cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 608cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> buffer = new ABuffer(totalSize); 609cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t offset = 0; 610cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber while (getNextNALUnit(&data, &size, &nalStart, &nalSize)) { 611cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(buffer->data() + offset, "\x00\x00\x00\x01", 4); 612cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(buffer->data() + offset + 4, nalStart, nalSize); 613cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 614cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber offset += 4 + nalSize; 615cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 616cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 617cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return buffer; 618cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 619cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 620cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huberstatic sp<ABuffer> FindMPEG2ADTSConfig( 621cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const sp<ABuffer> &buffer, int32_t *sampleRate, int32_t *channelCount) { 622cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader br(buffer->data(), buffer->size()); 623cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 624cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br.getBits(12), 0xfffu); 625cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br.getBits(1), 0u); 626cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br.getBits(2), 0u); 627cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br.getBits(1); // protection_absent 628cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned profile = br.getBits(2); 6290da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("profile = %u", profile); 630cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(profile, 3u); 631cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned sampling_freq_index = br.getBits(4); 632cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br.getBits(1); // private_bit 633cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned channel_configuration = br.getBits(3); 634cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_NE(channel_configuration, 0u); 635cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 6360da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("sampling_freq_index = %u", sampling_freq_index); 6370da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("channel_configuration = %u", channel_configuration); 638cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 639cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_LE(sampling_freq_index, 11u); 640cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber static const int32_t kSamplingFreq[] = { 641cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 642cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 16000, 12000, 11025, 8000 643cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber }; 644cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *sampleRate = kSamplingFreq[sampling_freq_index]; 645cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 646cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber *channelCount = channel_configuration; 647cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 648cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber static const uint8_t kStaticESDS[] = { 649cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x03, 22, 650cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, // ES_ID 651cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, // streamDependenceFlag, URL_Flag, OCRstreamFlag 652cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 653cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x04, 17, 654cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x40, // Audio ISO/IEC 14496-3 655cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, 0x00, 0x00, 656cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, 0x00, 0x00, 657cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x00, 0x00, 0x00, 0x00, 658cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 659cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 0x05, 2, 660cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // AudioSpecificInfo follows 661cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 662cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // oooo offf fccc c000 663cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // o - audioObjectType 664cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // f - samplingFreqIndex 665cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // c - channelConfig 666cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber }; 667cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = new ABuffer(sizeof(kStaticESDS) + 2); 668cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(csd->data(), kStaticESDS, sizeof(kStaticESDS)); 669cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 670cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber csd->data()[sizeof(kStaticESDS)] = 671cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ((profile + 1) << 3) | (sampling_freq_index >> 1); 672cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 673cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber csd->data()[sizeof(kStaticESDS) + 1] = 674cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ((sampling_freq_index << 7) & 0x80) | (channel_configuration << 3); 675cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 67682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // hexdump(csd->data(), csd->size()); 677cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return csd; 678cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 679cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 680cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::Stream::onPayloadData( 681cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PTS_DTS_flags, uint64_t PTS, uint64_t DTS, 682cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber const uint8_t *data, size_t size) { 6836e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("onPayloadData mStreamType=0x%02x", mStreamType); 684cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 685cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> buffer; 686cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 687cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mStreamType == 0x1b) { 688cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer = MakeCleanAVCData(data, size); 689cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 690cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // hexdump(data, size); 691cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 692cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer = new ABuffer(size); 693cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber memcpy(buffer->data(), data, size); 694cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 695cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 696cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mSource == NULL) { 697cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MetaData> meta = new MetaData; 698cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 699cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mStreamType == 0x1b) { 700cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setCString(kKeyMIMEType, MEDIA_MIMETYPE_VIDEO_AVC); 701cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 702cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber int32_t width, height; 703cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = MakeAVCCodecSpecificData(buffer, &width, &height); 704cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 705cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (csd == NULL) { 706cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 707cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 708cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 709cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setData(kKeyAVCC, 0, csd->data(), csd->size()); 710cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeyWidth, width); 711cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeyHeight, height); 712cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 713cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(mStreamType, 0x0fu); 714cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 715cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setCString(kKeyMIMEType, MEDIA_MIMETYPE_AUDIO_AAC); 716cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 717cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber int32_t sampleRate, channelCount; 718cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<ABuffer> csd = 719cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber FindMPEG2ADTSConfig(buffer, &sampleRate, &channelCount); 720cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 7210da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("sampleRate = %d", sampleRate); 7220da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("channelCount = %d", channelCount); 723cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 724cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeySampleRate, sampleRate); 725cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setInt32(kKeyChannelCount, channelCount); 726cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 727cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber meta->setData(kKeyESDS, 0, csd->data(), csd->size()); 728cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 729cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 7300da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("created source!"); 731cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mSource = new AnotherPacketSource(meta); 732cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 733cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber // fall through 734cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 735cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 736cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK(PTS_DTS_flags == 2 || PTS_DTS_flags == 3); 737cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber buffer->meta()->setInt64("time", (PTS * 100) / 9); 738cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 739cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mStreamType == 0x0f) { 74082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber extractAACFrames(buffer); 741cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 742cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 743cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mSource->queueAccessUnit(buffer); 744cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 745cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 74682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber// Disassemble one or more ADTS frames into their constituent parts and 74782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber// leave only the concatenated raw_data_blocks in the buffer. 74882f7321b03eec1e40af9d681370f754ee0279582Andreas Hubervoid ATSParser::Stream::extractAACFrames(const sp<ABuffer> &buffer) { 74982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber size_t dstOffset = 0; 75082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 75182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber size_t offset = 0; 75282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber while (offset < buffer->size()) { 75382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_LE(offset + 7, buffer->size()); 75482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 75582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber ABitReader bits(buffer->data() + offset, buffer->size() - offset); 75682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 75782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // adts_fixed_header 75882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 75982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_EQ(bits.getBits(12), 0xfffu); 76082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(3); // ID, layer 76182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bool protection_absent = bits.getBits(1) != 0; 76282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 76382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // profile_ObjectType, sampling_frequency_index, private_bits, 76482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // channel_configuration, original_copy, home 76582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(12); 76682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 76782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // adts_variable_header 76882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 76982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // copyright_identification_bit, copyright_identification_start 77082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(2); 77182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 77282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber unsigned aac_frame_length = bits.getBits(13); 77382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 77482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber bits.skipBits(11); // adts_buffer_fullness 77582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 77682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber unsigned number_of_raw_data_blocks_in_frame = bits.getBits(2); 77782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 77882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber if (number_of_raw_data_blocks_in_frame == 0) { 77982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber size_t scan = offset + aac_frame_length; 78082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 78182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber offset += 7; 78282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber if (!protection_absent) { 78382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber offset += 2; 78482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } 78582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 78682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_LE(scan, buffer->size()); 78782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 7886e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("found aac raw data block at [0x%08x ; 0x%08x)", offset, scan); 78982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 79082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber memmove(&buffer->data()[dstOffset], &buffer->data()[offset], 79182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber scan - offset); 79282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 79382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber dstOffset += scan - offset; 79482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber offset = scan; 79582f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } else { 79682f7321b03eec1e40af9d681370f754ee0279582Andreas Huber // To be implemented. 79782f7321b03eec1e40af9d681370f754ee0279582Andreas Huber TRESPASS(); 79882f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } 79982f7321b03eec1e40af9d681370f754ee0279582Andreas Huber } 80082f7321b03eec1e40af9d681370f754ee0279582Andreas Huber CHECK_EQ(offset, buffer->size()); 80182f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 80282f7321b03eec1e40af9d681370f754ee0279582Andreas Huber buffer->setRange(buffer->offset(), dstOffset); 80382f7321b03eec1e40af9d681370f754ee0279582Andreas Huber} 80482f7321b03eec1e40af9d681370f754ee0279582Andreas Huber 805cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<MediaSource> ATSParser::Stream::getSource(SourceType type) { 806cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if ((type == AVC_VIDEO && mStreamType == 0x1b) 807cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber || (type == MPEG2ADTS_AUDIO && mStreamType == 0x0f)) { 808cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return mSource; 809cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 810cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 811cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 812cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 813cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 814cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber//////////////////////////////////////////////////////////////////////////////// 815cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 816cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::ATSParser() { 817cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 818cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 819cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas HuberATSParser::~ATSParser() { 820cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 821cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 822cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::feedTSPacket(const void *data, size_t size) { 823cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(size, kTSPacketSize); 824cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 825cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader br((const uint8_t *)data, kTSPacketSize); 826cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseTS(&br); 827cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 828cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 829cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::parseProgramAssociationTable(ABitReader *br) { 830cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned table_id = br->getBits(8); 8316e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" table_id = %u", table_id); 832cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(table_id, 0x00u); 833cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 834cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned section_syntax_indictor = br->getBits(1); 8356e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" section_syntax_indictor = %u", section_syntax_indictor); 836cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(section_syntax_indictor, 1u); 837cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 838cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(br->getBits(1), 0u); 8396e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(2)); 840cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 841cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned section_length = br->getBits(12); 8426e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" section_length = %u", section_length); 843cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK((section_length & 0xc00) == 0); 844cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 8456e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" transport_stream_id = %u", br->getBits(16)); 8466e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(2)); 8476e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" version_number = %u", br->getBits(5)); 8486e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" current_next_indicator = %u", br->getBits(1)); 8496e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" section_number = %u", br->getBits(8)); 8506e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" last_section_number = %u", br->getBits(8)); 851cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 852cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber size_t numProgramBytes = (section_length - 5 /* header */ - 4 /* crc */); 853cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ((numProgramBytes % 4), 0u); 854cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 855cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < numProgramBytes / 4; ++i) { 856cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned program_number = br->getBits(16); 8576e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" program_number = %u", program_number); 858cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 8596e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" reserved = %u", br->getBits(3)); 860cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 861cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (program_number == 0) { 8626e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" network_PID = 0x%04x", br->getBits(13)); 863cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } else { 864cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned programMapPID = br->getBits(13); 865cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 8666e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV(" program_map_PID = 0x%04x", programMapPID); 867cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 868cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber mPrograms.push(new Program(programMapPID)); 869cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 870cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 871cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 8726e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV(" CRC = 0x%08x", br->getBits(32)); 873cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 874cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 875cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubervoid ATSParser::parsePID( 876cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber ABitReader *br, unsigned PID, 877cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator) { 878cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (PID == 0) { 879cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (payload_unit_start_indicator) { 880cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned skip = br->getBits(8); 881cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber br->skipBits(skip * 8); 882cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 883cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseProgramAssociationTable(br); 884cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return; 885cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 886cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 887cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber bool handled = false; 888cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < mPrograms.size(); ++i) { 889cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (mPrograms.editItemAt(i)->parsePID( 890cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber PID, payload_unit_start_indicator, br)) { 891cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber handled = true; 892cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber break; 893cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 894cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 895cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 896cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (!handled) { 8976e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("PID 0x%04x not handled.", PID); 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) { 9096e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("---"); 910cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 911cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned sync_byte = br->getBits(8); 912cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber CHECK_EQ(sync_byte, 0x47u); 913cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 9146e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("transport_error_indicator = %u", br->getBits(1)); 915cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 916cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned payload_unit_start_indicator = br->getBits(1); 9176e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("payload_unit_start_indicator = %u", payload_unit_start_indicator); 918cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 9196e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("transport_priority = %u", br->getBits(1)); 920cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 921cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned PID = br->getBits(13); 9226e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("PID = 0x%04x", PID); 923cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 9246e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber MY_LOGV("transport_scrambling_control = %u", br->getBits(2)); 925cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 926cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber unsigned adaptation_field_control = br->getBits(2); 9276e4c5c499999c04c2477b987f9e64f3ff2bf1a06Andreas Huber LOGV("adaptation_field_control = %u", adaptation_field_control); 928cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 9290da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber unsigned continuity_counter = br->getBits(4); 9300da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber LOGV("continuity_counter = %u", continuity_counter); 9310da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber 9320da4dab0a45a2bc1d95cbc6ef6a4850ed2569584Andreas Huber // LOGI("PID = 0x%04x, continuity_counter = %u", PID, continuity_counter); 933cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 934cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (adaptation_field_control == 2 || adaptation_field_control == 3) { 935cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parseAdaptationField(br); 936cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 937cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 938cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (adaptation_field_control == 1 || adaptation_field_control == 3) { 939cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber parsePID(br, PID, payload_unit_start_indicator); 940cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 941cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 942cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 943cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Hubersp<MediaSource> ATSParser::getSource(SourceType type) { 944cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber for (size_t i = 0; i < mPrograms.size(); ++i) { 945cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber sp<MediaSource> source = mPrograms.editItemAt(i)->getSource(type); 946cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 947cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber if (source != NULL) { 948cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return source; 949cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 950cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber } 951cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 952cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber return NULL; 953cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} 954cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber 955cda17c606b0fe3ccda4dc68a6d43882410ea2462Andreas Huber} // namespace android 956