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 void 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