diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
commit | 2aa4a82499d4becd2284cdb482213d541b8804dd (patch) | |
tree | b80bf8bf13c3766139fbacc530efd0dd9d54394c /dom/media/webrtc/libwebrtcglue/WebrtcMediaCodecVP8VideoCodec.h | |
parent | Initial commit. (diff) | |
download | firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip |
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/media/webrtc/libwebrtcglue/WebrtcMediaCodecVP8VideoCodec.h')
-rw-r--r-- | dom/media/webrtc/libwebrtcglue/WebrtcMediaCodecVP8VideoCodec.h | 153 |
1 files changed, 153 insertions, 0 deletions
diff --git a/dom/media/webrtc/libwebrtcglue/WebrtcMediaCodecVP8VideoCodec.h b/dom/media/webrtc/libwebrtcglue/WebrtcMediaCodecVP8VideoCodec.h new file mode 100644 index 0000000000..ffe9388848 --- /dev/null +++ b/dom/media/webrtc/libwebrtcglue/WebrtcMediaCodecVP8VideoCodec.h @@ -0,0 +1,153 @@ +/* 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 WebrtcMediaCodecVP8VideoCodec_h__ +#define WebrtcMediaCodecVP8VideoCodec_h__ + +#include <jni.h> + +#include "mozilla/java/CodecProxyWrappers.h" +#include "mozilla/Mutex.h" +#include "nsThreadUtils.h" + +#include "MediaConduitInterface.h" +#include "AudioConduit.h" +#include "VideoConduit.h" + +#include "webrtc/modules/video_coding/include/video_codec_interface.h" + +namespace mozilla { + +struct EncodedFrame { + uint32_t width_; + uint32_t height_; + uint32_t timeStamp_; + uint64_t decode_timestamp_; +}; + +class WebrtcAndroidMediaCodec; + +class WebrtcMediaCodecVP8VideoEncoder : public WebrtcVideoEncoder { + public: + WebrtcMediaCodecVP8VideoEncoder(); + + virtual ~WebrtcMediaCodecVP8VideoEncoder() override; + + // Implement VideoEncoder interface. + virtual uint64_t PluginID() const override { return 0; } + + virtual int32_t InitEncode(const webrtc::VideoCodec* codecSettings, + int32_t numberOfCores, + size_t maxPayloadSize) override; + + virtual int32_t Encode( + const webrtc::VideoFrame& inputImage, + const webrtc::CodecSpecificInfo* codecSpecificInfo, + const std::vector<webrtc::FrameType>* frame_types) override; + + virtual int32_t RegisterEncodeCompleteCallback( + webrtc::EncodedImageCallback* callback) override; + + virtual int32_t Release() override; + + virtual int32_t SetChannelParameters(uint32_t packetLoss, + int64_t rtt) override; + + virtual int32_t SetRates(uint32_t newBitRate, uint32_t frameRate) override; + + private: + int32_t VerifyAndAllocate(const uint32_t minimumSize); + bool ResetInputBuffers(); + bool ResetOutputBuffers(); + + size_t mMaxPayloadSize; + webrtc::EncodedImage mEncodedImage; + webrtc::EncodedImageCallback* mCallback; + uint32_t mFrameWidth; + uint32_t mFrameHeight; + + WebrtcAndroidMediaCodec* mMediaCodecEncoder; + + jobjectArray mInputBuffers; + jobjectArray mOutputBuffers; +}; + +class WebrtcMediaCodecVP8VideoRemoteEncoder : public WebrtcVideoEncoder { + public: + WebrtcMediaCodecVP8VideoRemoteEncoder() + : mConvertBuf(nullptr), mConvertBufsize(0), mCallback(nullptr) {} + + ~WebrtcMediaCodecVP8VideoRemoteEncoder() override; + + // Implement VideoEncoder interface. + uint64_t PluginID() const override { return 0; } + + int32_t InitEncode(const webrtc::VideoCodec* codecSettings, + int32_t numberOfCores, size_t maxPayloadSize) override; + + int32_t Encode(const webrtc::VideoFrame& inputImage, + const webrtc::CodecSpecificInfo* codecSpecificInfo, + const std::vector<webrtc::FrameType>* frame_types) override; + + int32_t RegisterEncodeCompleteCallback( + webrtc::EncodedImageCallback* callback) override; + + int32_t Release() override; + + int32_t SetChannelParameters(uint32_t packetLoss, int64_t rtt) override { + return 0; + } + + int32_t SetRates(uint32_t newBitRate, uint32_t frameRate) override; + + private: + java::CodecProxy::GlobalRef mJavaEncoder; + java::CodecProxy::NativeCallbacks::GlobalRef mJavaCallbacks; + uint8_t* mConvertBuf; + uint8_t mConvertBufsize; + webrtc::EncodedImageCallback* mCallback; +}; + +class WebrtcMediaCodecVP8VideoDecoder : public WebrtcVideoDecoder { + public: + WebrtcMediaCodecVP8VideoDecoder(); + + virtual ~WebrtcMediaCodecVP8VideoDecoder() override; + + // Implement VideoDecoder interface. + virtual uint64_t PluginID() const override { return 0; } + + virtual int32_t InitDecode(const webrtc::VideoCodec* codecSettings, + int32_t numberOfCores) override; + + virtual int32_t Decode( + const webrtc::EncodedImage& inputImage, bool missingFrames, + const webrtc::RTPFragmentationHeader* fragmentation, + const webrtc::CodecSpecificInfo* codecSpecificInfo = NULL, + int64_t renderTimeMs = -1) override; + + virtual int32_t RegisterDecodeCompleteCallback( + webrtc::DecodedImageCallback* callback) override; + + virtual int32_t Release() override; + + private: + void DecodeFrame(EncodedFrame* frame); + void RunCallback(); + bool ResetInputBuffers(); + bool ResetOutputBuffers(); + + webrtc::DecodedImageCallback* mCallback; + + uint32_t mFrameWidth; + uint32_t mFrameHeight; + + WebrtcAndroidMediaCodec* mMediaCodecDecoder; + jobjectArray mInputBuffers; + jobjectArray mOutputBuffers; +}; + +} // namespace mozilla + +#endif // WebrtcMediaCodecVP8VideoCodec_h__ |