1 /* 2 * Copyright (C) 2009 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #ifndef UTILS_H_ 18 19 #define UTILS_H_ 20 21 #include <media/stagefright/foundation/AString.h> 22 #include <stdint.h> 23 #include <utils/Errors.h> 24 #include <utils/RefBase.h> 25 #include <system/audio.h> 26 #include <media/BufferingSettings.h> 27 #include <media/MediaPlayerInterface.h> 28 29 namespace android { 30 31 struct AMessage; 32 status_t convertMetaDataToMessage( 33 const MetaDataBase *meta, sp<AMessage> *format); 34 status_t convertMetaDataToMessage( 35 const sp<MetaData> &meta, sp<AMessage> *format); 36 status_t convertMessageToMetaData( 37 const sp<AMessage> &format, sp<MetaData> &meta); 38 39 // Returns a pointer to the next NAL start code in buffer of size |length| starting at |data|, or 40 // a pointer to the end of the buffer if the start code is not found. 41 // TODO: combine this with avc_utils::getNextNALUnit 42 const uint8_t *findNextNalStartCode(const uint8_t *data, size_t length); 43 44 // Convert a MIME type to a AudioSystem::audio_format 45 status_t mapMimeToAudioFormat(audio_format_t& format, const char* mime); 46 47 // Convert a aac profile to a AudioSystem::audio_format 48 void mapAACProfileToAudioFormat(audio_format_t& format, uint64_t eAacProfile); 49 50 // Send information from MetaData to the HAL via AudioSink 51 status_t sendMetaDataToHal(sp<MediaPlayerBase::AudioSink>& sink, const sp<MetaData>& meta); 52 53 // Return |audio_offload_info_t| filled from given metadata 54 status_t getAudioOffloadInfo(const sp<MetaData>& meta, bool hasVideo, 55 bool isStreaming, audio_stream_type_t streamType, audio_offload_info_t *info); 56 57 // Check whether the stream defined by meta can be offloaded to hardware 58 bool canOffloadStream(const sp<MetaData>& meta, bool hasVideo, 59 bool isStreaming, audio_stream_type_t streamType); 60 61 struct HLSTime { 62 int32_t mSeq; 63 int64_t mTimeUs; 64 sp<AMessage> mMeta; 65 66 explicit HLSTime(const sp<AMessage> &meta = NULL); 67 int64_t getSegmentTimeUs() const; 68 }; 69 70 bool operator <(const HLSTime &t0, const HLSTime &t1); 71 72 // read and write various object to/from AMessage 73 74 void writeToAMessage(const sp<AMessage> &msg, const AudioPlaybackRate &rate); 75 void readFromAMessage(const sp<AMessage> &msg, AudioPlaybackRate *rate /* nonnull */); 76 77 void writeToAMessage(const sp<AMessage> &msg, const AVSyncSettings &sync, float videoFpsHint); 78 void readFromAMessage( 79 const sp<AMessage> &msg, AVSyncSettings *sync /* nonnull */, float *videoFps /* nonnull */); 80 81 void writeToAMessage(const sp<AMessage> &msg, const BufferingSettings &buffering); 82 void readFromAMessage(const sp<AMessage> &msg, BufferingSettings *buffering /* nonnull */); 83 84 } // namespace android 85 86 #endif // UTILS_H_ 87