MediaPlayerService.h revision 9c47c97ecac581d66b6febafd156618247e86742
1/* 2** 3** Copyright 2008, The Android Open Source Project 4** 5** Licensed under the Apache License, Version 2.0 (the "License"); 6** you may not use this file except in compliance with the License. 7** You may obtain a copy of the License at 8** 9** http://www.apache.org/licenses/LICENSE-2.0 10** 11** Unless required by applicable law or agreed to in writing, software 12** distributed under the License is distributed on an "AS IS" BASIS, 13** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14** See the License for the specific language governing permissions and 15** limitations under the License. 16*/ 17 18#ifndef ANDROID_MEDIAPLAYERSERVICE_H 19#define ANDROID_MEDIAPLAYERSERVICE_H 20 21#include <arpa/inet.h> 22 23#include <utils/threads.h> 24#include <utils/Errors.h> 25#include <utils/KeyedVector.h> 26#include <utils/String8.h> 27#include <utils/Vector.h> 28 29#include <media/MediaPlayerInterface.h> 30#include <media/Metadata.h> 31#include <media/stagefright/foundation/ABase.h> 32 33#include <android/hardware/media/omx/1.0/IOmx.h> 34 35#include <system/audio.h> 36 37namespace android { 38 39struct AudioPlaybackRate; 40class AudioTrack; 41struct AVSyncSettings; 42class IDataSource; 43class IMediaRecorder; 44class IMediaMetadataRetriever; 45class IOMX; 46class IRemoteDisplay; 47class IRemoteDisplayClient; 48class MediaRecorderClient; 49 50#define CALLBACK_ANTAGONIZER 0 51#if CALLBACK_ANTAGONIZER 52class Antagonizer { 53public: 54 Antagonizer(notify_callback_f cb, void* client); 55 void start() { mActive = true; } 56 void stop() { mActive = false; } 57 void kill(); 58private: 59 static const int interval; 60 Antagonizer(); 61 static int callbackThread(void* cookie); 62 Mutex mLock; 63 Condition mCondition; 64 bool mExit; 65 bool mActive; 66 void* mClient; 67 notify_callback_f mCb; 68}; 69#endif 70 71class MediaPlayerService : public BnMediaPlayerService 72{ 73 class Client; 74 typedef ::android::hardware::media::omx::V1_0::IOmx IOmx; 75 76 class AudioOutput : public MediaPlayerBase::AudioSink 77 { 78 class CallbackData; 79 80 public: 81 AudioOutput(audio_session_t sessionId, uid_t uid, int pid, 82 const audio_attributes_t * attr); 83 virtual ~AudioOutput(); 84 85 virtual bool ready() const { return mTrack != 0; } 86 virtual ssize_t bufferSize() const; 87 virtual ssize_t frameCount() const; 88 virtual ssize_t channelCount() const; 89 virtual ssize_t frameSize() const; 90 virtual uint32_t latency() const; 91 virtual float msecsPerFrame() const; 92 virtual status_t getPosition(uint32_t *position) const; 93 virtual status_t getTimestamp(AudioTimestamp &ts) const; 94 virtual int64_t getPlayedOutDurationUs(int64_t nowUs) const; 95 virtual status_t getFramesWritten(uint32_t *frameswritten) const; 96 virtual audio_session_t getSessionId() const; 97 virtual uint32_t getSampleRate() const; 98 virtual int64_t getBufferDurationInUs() const; 99 100 virtual status_t open( 101 uint32_t sampleRate, int channelCount, audio_channel_mask_t channelMask, 102 audio_format_t format, int bufferCount, 103 AudioCallback cb, void *cookie, 104 audio_output_flags_t flags = AUDIO_OUTPUT_FLAG_NONE, 105 const audio_offload_info_t *offloadInfo = NULL, 106 bool doNotReconnect = false, 107 uint32_t suggestedFrameCount = 0); 108 109 virtual status_t start(); 110 virtual ssize_t write(const void* buffer, size_t size, bool blocking = true); 111 virtual void stop(); 112 virtual void flush(); 113 virtual void pause(); 114 virtual void close(); 115 void setAudioStreamType(audio_stream_type_t streamType); 116 virtual audio_stream_type_t getAudioStreamType() const { return mStreamType; } 117 void setAudioAttributes(const audio_attributes_t * attributes); 118 119 void setVolume(float left, float right); 120 virtual status_t setPlaybackRate(const AudioPlaybackRate& rate); 121 virtual status_t getPlaybackRate(AudioPlaybackRate* rate /* nonnull */); 122 123 status_t setAuxEffectSendLevel(float level); 124 status_t attachAuxEffect(int effectId); 125 virtual status_t dump(int fd, const Vector<String16>& args) const; 126 127 static bool isOnEmulator(); 128 static int getMinBufferCount(); 129 void setNextOutput(const sp<AudioOutput>& nextOutput); 130 void switchToNextOutput(); 131 virtual bool needsTrailingPadding() { return mNextOutput == NULL; } 132 virtual status_t setParameters(const String8& keyValuePairs); 133 virtual String8 getParameters(const String8& keys); 134 135 virtual VolumeShaper::Status applyVolumeShaper( 136 const sp<VolumeShaper::Configuration>& configuration, 137 const sp<VolumeShaper::Operation>& operation) override; 138 virtual sp<VolumeShaper::State> getVolumeShaperState(int id) override; 139 140 private: 141 static void setMinBufferCount(); 142 static void CallbackWrapper( 143 int event, void *me, void *info); 144 void deleteRecycledTrack_l(); 145 void close_l(); 146 status_t updateTrack(); 147 148 sp<AudioTrack> mTrack; 149 sp<AudioTrack> mRecycledTrack; 150 sp<AudioOutput> mNextOutput; 151 AudioCallback mCallback; 152 void * mCallbackCookie; 153 CallbackData * mCallbackData; 154 audio_stream_type_t mStreamType; 155 audio_attributes_t * mAttributes; 156 float mLeftVolume; 157 float mRightVolume; 158 AudioPlaybackRate mPlaybackRate; 159 uint32_t mSampleRateHz; // sample rate of the content, as set in open() 160 float mMsecsPerFrame; 161 size_t mFrameSize; 162 audio_session_t mSessionId; 163 uid_t mUid; 164 int mPid; 165 float mSendLevel; 166 int mAuxEffectId; 167 audio_output_flags_t mFlags; 168 mutable Mutex mLock; 169 170 // static variables below not protected by mutex 171 static bool mIsOnEmulator; 172 static int mMinBufferCount; // 12 for emulator; otherwise 4 173 174 // CallbackData is what is passed to the AudioTrack as the "user" data. 175 // We need to be able to target this to a different Output on the fly, 176 // so we can't use the Output itself for this. 177 class CallbackData { 178 friend AudioOutput; 179 public: 180 explicit CallbackData(AudioOutput *cookie) { 181 mData = cookie; 182 mSwitching = false; 183 } 184 AudioOutput * getOutput() const { return mData; } 185 void setOutput(AudioOutput* newcookie) { mData = newcookie; } 186 // lock/unlock are used by the callback before accessing the payload of this object 187 void lock() const { mLock.lock(); } 188 void unlock() const { mLock.unlock(); } 189 190 // tryBeginTrackSwitch/endTrackSwitch are used when the CallbackData is handed over 191 // to the next sink. 192 193 // tryBeginTrackSwitch() returns true only if it obtains the lock. 194 bool tryBeginTrackSwitch() { 195 LOG_ALWAYS_FATAL_IF(mSwitching, "tryBeginTrackSwitch() already called"); 196 if (mLock.tryLock() != OK) { 197 return false; 198 } 199 mSwitching = true; 200 return true; 201 } 202 void endTrackSwitch() { 203 if (mSwitching) { 204 mLock.unlock(); 205 } 206 mSwitching = false; 207 } 208 private: 209 AudioOutput * mData; 210 mutable Mutex mLock; // a recursive mutex might make this unnecessary. 211 bool mSwitching; 212 DISALLOW_EVIL_CONSTRUCTORS(CallbackData); 213 }; 214 215 }; // AudioOutput 216 217 218public: 219 static void instantiate(); 220 221 // IMediaPlayerService interface 222 virtual sp<IMediaRecorder> createMediaRecorder(const String16 &opPackageName); 223 void removeMediaRecorderClient(const wp<MediaRecorderClient>& client); 224 virtual sp<IMediaMetadataRetriever> createMetadataRetriever(); 225 226 virtual sp<IMediaPlayer> create(const sp<IMediaPlayerClient>& client, 227 audio_session_t audioSessionId); 228 229 virtual sp<IMediaCodecList> getCodecList() const; 230 virtual sp<IOMX> getOMX(); 231 virtual sp<IHDCP> makeHDCP(bool createEncryptionModule); 232 233 virtual sp<IRemoteDisplay> listenForRemoteDisplay(const String16 &opPackageName, 234 const sp<IRemoteDisplayClient>& client, const String8& iface); 235 virtual status_t dump(int fd, const Vector<String16>& args); 236 237 void removeClient(const wp<Client>& client); 238 bool hasClient(wp<Client> client); 239 240 enum { 241 MEDIASERVER_PROCESS_DEATH = 0, 242 MEDIAEXTRACTOR_PROCESS_DEATH = 1, 243 MEDIACODEC_PROCESS_DEATH = 2, 244 AUDIO_PROCESS_DEATH = 3, // currently no need to track this 245 CAMERA_PROCESS_DEATH = 4 246 }; 247 248 // For battery usage tracking purpose 249 struct BatteryUsageInfo { 250 // how many streams are being played by one UID 251 int refCount; 252 // a temp variable to store the duration(ms) of audio codecs 253 // when we start a audio codec, we minus the system time from audioLastTime 254 // when we pause it, we add the system time back to the audioLastTime 255 // so after the pause, audioLastTime = pause time - start time 256 // if multiple audio streams are played (or recorded), then audioLastTime 257 // = the total playing time of all the streams 258 int32_t audioLastTime; 259 // when all the audio streams are being paused, we assign audioLastTime to 260 // this variable, so this value could be provided to the battery app 261 // in the next pullBatteryData call 262 int32_t audioTotalTime; 263 264 int32_t videoLastTime; 265 int32_t videoTotalTime; 266 }; 267 KeyedVector<int, BatteryUsageInfo> mBatteryData; 268 269 enum { 270 SPEAKER, 271 OTHER_AUDIO_DEVICE, 272 SPEAKER_AND_OTHER, 273 NUM_AUDIO_DEVICES 274 }; 275 276 struct BatteryAudioFlingerUsageInfo { 277 int refCount; // how many audio streams are being played 278 int deviceOn[NUM_AUDIO_DEVICES]; // whether the device is currently used 279 int32_t lastTime[NUM_AUDIO_DEVICES]; // in ms 280 // totalTime[]: total time of audio output devices usage 281 int32_t totalTime[NUM_AUDIO_DEVICES]; // in ms 282 }; 283 284 // This varialble is used to record the usage of audio output device 285 // for battery app 286 BatteryAudioFlingerUsageInfo mBatteryAudio; 287 288 // Collect info of the codec usage from media player and media recorder 289 virtual void addBatteryData(uint32_t params); 290 // API for the Battery app to pull the data of codecs usage 291 virtual status_t pullBatteryData(Parcel* reply); 292private: 293 294 class Client : public BnMediaPlayer { 295 // IMediaPlayer interface 296 virtual void disconnect(); 297 virtual status_t setVideoSurfaceTexture( 298 const sp<IGraphicBufferProducer>& bufferProducer); 299 virtual status_t setBufferingSettings(const BufferingSettings& buffering) override; 300 virtual status_t getDefaultBufferingSettings( 301 BufferingSettings* buffering /* nonnull */) override; 302 virtual status_t prepareAsync(); 303 virtual status_t start(); 304 virtual status_t stop(); 305 virtual status_t pause(); 306 virtual status_t isPlaying(bool* state); 307 virtual status_t setPlaybackSettings(const AudioPlaybackRate& rate); 308 virtual status_t getPlaybackSettings(AudioPlaybackRate* rate /* nonnull */); 309 virtual status_t setSyncSettings(const AVSyncSettings& rate, float videoFpsHint); 310 virtual status_t getSyncSettings(AVSyncSettings* rate /* nonnull */, 311 float* videoFps /* nonnull */); 312 virtual status_t seekTo( 313 int msec, 314 MediaPlayerSeekMode mode = MediaPlayerSeekMode::SEEK_PREVIOUS_SYNC); 315 virtual status_t getCurrentPosition(int* msec); 316 virtual status_t getDuration(int* msec); 317 virtual status_t reset(); 318 virtual status_t setAudioStreamType(audio_stream_type_t type); 319 virtual status_t setLooping(int loop); 320 virtual status_t setVolume(float leftVolume, float rightVolume); 321 virtual status_t invoke(const Parcel& request, Parcel *reply); 322 virtual status_t setMetadataFilter(const Parcel& filter); 323 virtual status_t getMetadata(bool update_only, 324 bool apply_filter, 325 Parcel *reply); 326 virtual status_t setAuxEffectSendLevel(float level); 327 virtual status_t attachAuxEffect(int effectId); 328 virtual status_t setParameter(int key, const Parcel &request); 329 virtual status_t getParameter(int key, Parcel *reply); 330 virtual status_t setRetransmitEndpoint(const struct sockaddr_in* endpoint); 331 virtual status_t getRetransmitEndpoint(struct sockaddr_in* endpoint); 332 virtual status_t setNextPlayer(const sp<IMediaPlayer>& player); 333 334 virtual VolumeShaper::Status applyVolumeShaper( 335 const sp<VolumeShaper::Configuration>& configuration, 336 const sp<VolumeShaper::Operation>& operation) override; 337 virtual sp<VolumeShaper::State> getVolumeShaperState(int id) override; 338 339 sp<MediaPlayerBase> createPlayer(player_type playerType); 340 341 virtual status_t setDataSource( 342 const sp<IMediaHTTPService> &httpService, 343 const char *url, 344 const KeyedVector<String8, String8> *headers); 345 346 virtual status_t setDataSource(int fd, int64_t offset, int64_t length); 347 348 virtual status_t setDataSource(const sp<IStreamSource> &source); 349 virtual status_t setDataSource(const sp<IDataSource> &source); 350 351 352 sp<MediaPlayerBase> setDataSource_pre(player_type playerType); 353 void setDataSource_post(const sp<MediaPlayerBase>& p, 354 status_t status); 355 356 static void notify(void* cookie, int msg, 357 int ext1, int ext2, const Parcel *obj); 358 359 pid_t pid() const { return mPid; } 360 virtual status_t dump(int fd, const Vector<String16>& args); 361 362 audio_session_t getAudioSessionId() { return mAudioSessionId; } 363 // Modular DRM 364 virtual status_t prepareDrm(const uint8_t uuid[16], const Vector<uint8_t>& drmSessionId); 365 virtual status_t releaseDrm(); 366 367 private: 368 class ServiceDeathNotifier: 369 public IBinder::DeathRecipient, 370 public ::android::hardware::hidl_death_recipient 371 { 372 public: 373 ServiceDeathNotifier( 374 const sp<IBinder>& service, 375 const sp<MediaPlayerBase>& listener, 376 int which); 377 ServiceDeathNotifier( 378 const sp<IOmx>& omx, 379 const sp<MediaPlayerBase>& listener, 380 int which); 381 virtual ~ServiceDeathNotifier(); 382 virtual void binderDied(const wp<IBinder>& who); 383 virtual void serviceDied( 384 uint64_t cookie, 385 const wp<::android::hidl::base::V1_0::IBase>& who); 386 void unlinkToDeath(); 387 388 private: 389 int mWhich; 390 sp<IBinder> mService; 391 sp<IOmx> mOmx; 392 wp<MediaPlayerBase> mListener; 393 }; 394 395 void clearDeathNotifiers(); 396 397 friend class MediaPlayerService; 398 Client( const sp<MediaPlayerService>& service, 399 pid_t pid, 400 int32_t connId, 401 const sp<IMediaPlayerClient>& client, 402 audio_session_t audioSessionId, 403 uid_t uid); 404 Client(); 405 virtual ~Client(); 406 407 void deletePlayer(); 408 409 sp<MediaPlayerBase> getPlayer() const { Mutex::Autolock lock(mLock); return mPlayer; } 410 411 412 413 // @param type Of the metadata to be tested. 414 // @return true if the metadata should be dropped according to 415 // the filters. 416 bool shouldDropMetadata(media::Metadata::Type type) const; 417 418 // Add a new element to the set of metadata updated. Noop if 419 // the element exists already. 420 // @param type Of the metadata to be recorded. 421 void addNewMetadataUpdate(media::Metadata::Type type); 422 423 // Disconnect from the currently connected ANativeWindow. 424 void disconnectNativeWindow(); 425 426 status_t setAudioAttributes_l(const Parcel &request); 427 428 mutable Mutex mLock; 429 sp<MediaPlayerBase> mPlayer; 430 sp<MediaPlayerService> mService; 431 sp<IMediaPlayerClient> mClient; 432 sp<AudioOutput> mAudioOutput; 433 pid_t mPid; 434 status_t mStatus; 435 bool mLoop; 436 int32_t mConnId; 437 audio_session_t mAudioSessionId; 438 audio_attributes_t * mAudioAttributes; 439 uid_t mUid; 440 sp<ANativeWindow> mConnectedWindow; 441 sp<IBinder> mConnectedWindowBinder; 442 struct sockaddr_in mRetransmitEndpoint; 443 bool mRetransmitEndpointValid; 444 sp<Client> mNextClient; 445 446 // Metadata filters. 447 media::Metadata::Filter mMetadataAllow; // protected by mLock 448 media::Metadata::Filter mMetadataDrop; // protected by mLock 449 450 // Metadata updated. For each MEDIA_INFO_METADATA_UPDATE 451 // notification we try to update mMetadataUpdated which is a 452 // set: no duplicate. 453 // getMetadata clears this set. 454 media::Metadata::Filter mMetadataUpdated; // protected by mLock 455 456 sp<ServiceDeathNotifier> mExtractorDeathListener; 457 sp<ServiceDeathNotifier> mCodecDeathListener; 458#if CALLBACK_ANTAGONIZER 459 Antagonizer* mAntagonizer; 460#endif 461 }; // Client 462 463// ---------------------------------------------------------------------------- 464 465 MediaPlayerService(); 466 virtual ~MediaPlayerService(); 467 468 mutable Mutex mLock; 469 SortedVector< wp<Client> > mClients; 470 SortedVector< wp<MediaRecorderClient> > mMediaRecorderClients; 471 int32_t mNextConnId; 472 sp<IOMX> mOMX; 473}; 474 475// ---------------------------------------------------------------------------- 476 477}; // namespace android 478 479#endif // ANDROID_MEDIAPLAYERSERVICE_H 480