1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright (c) 2022 The WebRTC project authors. All Rights Reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker #ifndef VIDEO_FRAME_DECODE_SCHEDULER_H_ 12*d9f75844SAndroid Build Coastguard Worker #define VIDEO_FRAME_DECODE_SCHEDULER_H_ 13*d9f75844SAndroid Build Coastguard Worker 14*d9f75844SAndroid Build Coastguard Worker #include <stdint.h> 15*d9f75844SAndroid Build Coastguard Worker 16*d9f75844SAndroid Build Coastguard Worker #include "absl/functional/any_invocable.h" 17*d9f75844SAndroid Build Coastguard Worker #include "absl/types/optional.h" 18*d9f75844SAndroid Build Coastguard Worker #include "api/units/timestamp.h" 19*d9f75844SAndroid Build Coastguard Worker #include "video/frame_decode_timing.h" 20*d9f75844SAndroid Build Coastguard Worker 21*d9f75844SAndroid Build Coastguard Worker namespace webrtc { 22*d9f75844SAndroid Build Coastguard Worker 23*d9f75844SAndroid Build Coastguard Worker class FrameDecodeScheduler { 24*d9f75844SAndroid Build Coastguard Worker public: 25*d9f75844SAndroid Build Coastguard Worker // Invoked when a frame with `rtp_timestamp` is ready for decoding. 26*d9f75844SAndroid Build Coastguard Worker using FrameReleaseCallback = 27*d9f75844SAndroid Build Coastguard Worker absl::AnyInvocable<void(uint32_t rtp_timestamp, 28*d9f75844SAndroid Build Coastguard Worker Timestamp render_time) &&>; 29*d9f75844SAndroid Build Coastguard Worker 30*d9f75844SAndroid Build Coastguard Worker virtual ~FrameDecodeScheduler() = default; 31*d9f75844SAndroid Build Coastguard Worker 32*d9f75844SAndroid Build Coastguard Worker // Returns the rtp timestamp of the next frame scheduled for release, or 33*d9f75844SAndroid Build Coastguard Worker // `nullopt` if no frame is currently scheduled. 34*d9f75844SAndroid Build Coastguard Worker virtual absl::optional<uint32_t> ScheduledRtpTimestamp() = 0; 35*d9f75844SAndroid Build Coastguard Worker 36*d9f75844SAndroid Build Coastguard Worker // Schedules a frame for release based on `schedule`. When released, 37*d9f75844SAndroid Build Coastguard Worker // `callback` will be invoked with the `rtp` timestamp of the frame and the 38*d9f75844SAndroid Build Coastguard Worker // `render_time` 39*d9f75844SAndroid Build Coastguard Worker virtual void ScheduleFrame(uint32_t rtp, 40*d9f75844SAndroid Build Coastguard Worker FrameDecodeTiming::FrameSchedule schedule, 41*d9f75844SAndroid Build Coastguard Worker FrameReleaseCallback callback) = 0; 42*d9f75844SAndroid Build Coastguard Worker 43*d9f75844SAndroid Build Coastguard Worker // Cancels all scheduled frames. 44*d9f75844SAndroid Build Coastguard Worker virtual void CancelOutstanding() = 0; 45*d9f75844SAndroid Build Coastguard Worker 46*d9f75844SAndroid Build Coastguard Worker // Stop() Must be called before destruction. 47*d9f75844SAndroid Build Coastguard Worker virtual void Stop() = 0; 48*d9f75844SAndroid Build Coastguard Worker }; 49*d9f75844SAndroid Build Coastguard Worker 50*d9f75844SAndroid Build Coastguard Worker } // namespace webrtc 51*d9f75844SAndroid Build Coastguard Worker 52*d9f75844SAndroid Build Coastguard Worker #endif // VIDEO_FRAME_DECODE_SCHEDULER_H_ 53