From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- dom/media/MediaDecoderReaderWrapper.h | 143 ++++++++++++++++++++++++++++++++++ 1 file changed, 143 insertions(+) create mode 100644 dom/media/MediaDecoderReaderWrapper.h (limited to 'dom/media/MediaDecoderReaderWrapper.h') diff --git a/dom/media/MediaDecoderReaderWrapper.h b/dom/media/MediaDecoderReaderWrapper.h new file mode 100644 index 000000000..92001ca33 --- /dev/null +++ b/dom/media/MediaDecoderReaderWrapper.h @@ -0,0 +1,143 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef MediaDecoderReaderWrapper_h_ +#define MediaDecoderReaderWrapper_h_ + +#include "mozilla/AbstractThread.h" +#include "mozilla/RefPtr.h" +#include "mozilla/Variant.h" +#include "nsISupportsImpl.h" + +#include "MediaDecoderReader.h" +#include "MediaEventSource.h" + +namespace mozilla { + +class StartTimeRendezvous; + +typedef MozPromise HaveStartTimePromise; + +typedef Variant AudioCallbackData; +typedef Variant, MediaResult> VideoCallbackData; +typedef Variant WaitCallbackData; + +/** + * A wrapper around MediaDecoderReader to offset the timestamps of Audio/Video + * samples by the start time to ensure MDSM can always assume zero start time. + * It also adjusts the seek target passed to Seek() to ensure correct seek time + * is passed to the underlying reader. + */ +class MediaDecoderReaderWrapper { + typedef MediaDecoderReader::MetadataPromise MetadataPromise; + typedef MediaDecoderReader::MediaDataPromise MediaDataPromise; + typedef MediaDecoderReader::SeekPromise SeekPromise; + typedef MediaDecoderReader::WaitForDataPromise WaitForDataPromise; + typedef MediaDecoderReader::BufferedUpdatePromise BufferedUpdatePromise; + typedef MediaDecoderReader::TrackSet TrackSet; + NS_INLINE_DECL_THREADSAFE_REFCOUNTING(MediaDecoderReaderWrapper); + +private: + MediaCallbackExc mAudioCallback; + MediaCallbackExc mVideoCallback; + MediaCallbackExc mAudioWaitCallback; + MediaCallbackExc mVideoWaitCallback; + +public: + MediaDecoderReaderWrapper(AbstractThread* aOwnerThread, + MediaDecoderReader* aReader); + + media::TimeUnit StartTime() const; + RefPtr ReadMetadata(); + RefPtr AwaitStartTime(); + + decltype(mAudioCallback)& AudioCallback() { return mAudioCallback; } + decltype(mVideoCallback)& VideoCallback() { return mVideoCallback; } + decltype(mAudioWaitCallback)& AudioWaitCallback() { return mAudioWaitCallback; } + decltype(mVideoWaitCallback)& VideoWaitCallback() { return mVideoWaitCallback; } + + // NOTE: please set callbacks before requesting audio/video data! + void RequestAudioData(); + void RequestVideoData(bool aSkipToNextKeyframe, media::TimeUnit aTimeThreshold); + + // NOTE: please set callbacks before invoking WaitForData()! + void WaitForData(MediaData::Type aType); + + bool IsRequestingAudioData() const; + bool IsRequestingVideoData() const; + bool IsWaitingAudioData() const; + bool IsWaitingVideoData() const; + + RefPtr Seek(SeekTarget aTarget, media::TimeUnit aEndTime); + RefPtr UpdateBufferedWithPromise(); + RefPtr Shutdown(); + + void ReleaseResources(); + void SetIdle(); + void ResetDecode(TrackSet aTracks); + + nsresult Init() { return mReader->Init(); } + bool IsWaitForDataSupported() const { return mReader->IsWaitForDataSupported(); } + bool IsAsync() const { return mReader->IsAsync(); } + bool UseBufferingHeuristics() const { return mReader->UseBufferingHeuristics(); } + bool ForceZeroStartTime() const { return mReader->ForceZeroStartTime(); } + + bool VideoIsHardwareAccelerated() const { + return mReader->VideoIsHardwareAccelerated(); + } + TimedMetadataEventSource& TimedMetadataEvent() { + return mReader->TimedMetadataEvent(); + } + MediaEventSource& OnMediaNotSeekable() { + return mReader->OnMediaNotSeekable(); + } + size_t SizeOfVideoQueueInBytes() const { + return mReader->SizeOfVideoQueueInBytes(); + } + size_t SizeOfAudioQueueInBytes() const { + return mReader->SizeOfAudioQueueInBytes(); + } + size_t SizeOfAudioQueueInFrames() const { + return mReader->SizeOfAudioQueueInFrames(); + } + size_t SizeOfVideoQueueInFrames() const { + return mReader->SizeOfVideoQueueInFrames(); + } + void ReadUpdatedMetadata(MediaInfo* aInfo) { + mReader->ReadUpdatedMetadata(aInfo); + } + AbstractCanonical* CanonicalBuffered() { + return mReader->CanonicalBuffered(); + } + + void SetCDMProxy(CDMProxy* aProxy) { mReader->SetCDMProxy(aProxy); } + + void SetVideoBlankDecode(bool aIsBlankDecode); + +private: + ~MediaDecoderReaderWrapper(); + + void OnMetadataRead(MetadataHolder* aMetadata); + void OnMetadataNotRead() {} + MediaCallbackExc& WaitCallbackRef(MediaData::Type aType); + MozPromiseRequestHolder& WaitRequestRef(MediaData::Type aType); + + const bool mForceZeroStartTime; + const RefPtr mOwnerThread; + const RefPtr mReader; + + bool mShutdown = false; + RefPtr mStartTimeRendezvous; + + MozPromiseRequestHolder mAudioDataRequest; + MozPromiseRequestHolder mVideoDataRequest; + MozPromiseRequestHolder mAudioWaitRequest; + MozPromiseRequestHolder mVideoWaitRequest; +}; + +} // namespace mozilla + +#endif // MediaDecoderReaderWrapper_h_ -- cgit v1.2.3