xref: /aosp_15_r20/frameworks/av/media/module/bqhelper/FrameDropper.cpp (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1*ec779b8eSAndroid Build Coastguard Worker /*
2*ec779b8eSAndroid Build Coastguard Worker  * Copyright (C) 2015 The Android Open Source Project
3*ec779b8eSAndroid Build Coastguard Worker  *
4*ec779b8eSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*ec779b8eSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*ec779b8eSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*ec779b8eSAndroid Build Coastguard Worker  *
8*ec779b8eSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*ec779b8eSAndroid Build Coastguard Worker  *
10*ec779b8eSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*ec779b8eSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*ec779b8eSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*ec779b8eSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*ec779b8eSAndroid Build Coastguard Worker  * limitations under the License.
15*ec779b8eSAndroid Build Coastguard Worker  */
16*ec779b8eSAndroid Build Coastguard Worker 
17*ec779b8eSAndroid Build Coastguard Worker //#define LOG_NDEBUG 0
18*ec779b8eSAndroid Build Coastguard Worker #define LOG_TAG "FrameDropper"
19*ec779b8eSAndroid Build Coastguard Worker #include <utils/Log.h>
20*ec779b8eSAndroid Build Coastguard Worker 
21*ec779b8eSAndroid Build Coastguard Worker #include <media/stagefright/bqhelper/FrameDropper.h>
22*ec779b8eSAndroid Build Coastguard Worker #include <media/stagefright/foundation/ADebug.h>
23*ec779b8eSAndroid Build Coastguard Worker 
24*ec779b8eSAndroid Build Coastguard Worker namespace android {
25*ec779b8eSAndroid Build Coastguard Worker 
26*ec779b8eSAndroid Build Coastguard Worker static const int64_t kMaxJitterUs = 2000;
27*ec779b8eSAndroid Build Coastguard Worker 
FrameDropper()28*ec779b8eSAndroid Build Coastguard Worker FrameDropper::FrameDropper()
29*ec779b8eSAndroid Build Coastguard Worker     : mDesiredMinTimeUs(-1),
30*ec779b8eSAndroid Build Coastguard Worker       mMinIntervalUs(0) {
31*ec779b8eSAndroid Build Coastguard Worker }
32*ec779b8eSAndroid Build Coastguard Worker 
~FrameDropper()33*ec779b8eSAndroid Build Coastguard Worker FrameDropper::~FrameDropper() {
34*ec779b8eSAndroid Build Coastguard Worker }
35*ec779b8eSAndroid Build Coastguard Worker 
setMaxFrameRate(float maxFrameRate)36*ec779b8eSAndroid Build Coastguard Worker status_t FrameDropper::setMaxFrameRate(float maxFrameRate) {
37*ec779b8eSAndroid Build Coastguard Worker     if (maxFrameRate < 0) {
38*ec779b8eSAndroid Build Coastguard Worker         mMinIntervalUs = -1LL;
39*ec779b8eSAndroid Build Coastguard Worker         return OK;
40*ec779b8eSAndroid Build Coastguard Worker     }
41*ec779b8eSAndroid Build Coastguard Worker 
42*ec779b8eSAndroid Build Coastguard Worker     if (maxFrameRate == 0) {
43*ec779b8eSAndroid Build Coastguard Worker         ALOGE("framerate should be positive but got %f.", maxFrameRate);
44*ec779b8eSAndroid Build Coastguard Worker         return BAD_VALUE;
45*ec779b8eSAndroid Build Coastguard Worker     }
46*ec779b8eSAndroid Build Coastguard Worker     mMinIntervalUs = (int64_t) (1000000.0f / maxFrameRate);
47*ec779b8eSAndroid Build Coastguard Worker     return OK;
48*ec779b8eSAndroid Build Coastguard Worker }
49*ec779b8eSAndroid Build Coastguard Worker 
shouldDrop(int64_t timeUs)50*ec779b8eSAndroid Build Coastguard Worker bool FrameDropper::shouldDrop(int64_t timeUs) {
51*ec779b8eSAndroid Build Coastguard Worker     if (mMinIntervalUs <= 0) {
52*ec779b8eSAndroid Build Coastguard Worker         return false;
53*ec779b8eSAndroid Build Coastguard Worker     }
54*ec779b8eSAndroid Build Coastguard Worker 
55*ec779b8eSAndroid Build Coastguard Worker     if (mDesiredMinTimeUs < 0) {
56*ec779b8eSAndroid Build Coastguard Worker         mDesiredMinTimeUs = timeUs + mMinIntervalUs;
57*ec779b8eSAndroid Build Coastguard Worker         ALOGV("first frame %lld, next desired frame %lld",
58*ec779b8eSAndroid Build Coastguard Worker                 (long long)timeUs, (long long)mDesiredMinTimeUs);
59*ec779b8eSAndroid Build Coastguard Worker         return false;
60*ec779b8eSAndroid Build Coastguard Worker     }
61*ec779b8eSAndroid Build Coastguard Worker 
62*ec779b8eSAndroid Build Coastguard Worker     if (timeUs < (mDesiredMinTimeUs - kMaxJitterUs)) {
63*ec779b8eSAndroid Build Coastguard Worker         ALOGV("drop frame %lld, desired frame %lld, diff %lld",
64*ec779b8eSAndroid Build Coastguard Worker                 (long long)timeUs, (long long)mDesiredMinTimeUs,
65*ec779b8eSAndroid Build Coastguard Worker                 (long long)(mDesiredMinTimeUs - timeUs));
66*ec779b8eSAndroid Build Coastguard Worker         return true;
67*ec779b8eSAndroid Build Coastguard Worker     }
68*ec779b8eSAndroid Build Coastguard Worker 
69*ec779b8eSAndroid Build Coastguard Worker     int64_t n = (timeUs - mDesiredMinTimeUs + kMaxJitterUs) / mMinIntervalUs;
70*ec779b8eSAndroid Build Coastguard Worker     mDesiredMinTimeUs += (n + 1) * mMinIntervalUs;
71*ec779b8eSAndroid Build Coastguard Worker     ALOGV("keep frame %lld, next desired frame %lld, diff %lld",
72*ec779b8eSAndroid Build Coastguard Worker             (long long)timeUs, (long long)mDesiredMinTimeUs,
73*ec779b8eSAndroid Build Coastguard Worker             (long long)(mDesiredMinTimeUs - timeUs));
74*ec779b8eSAndroid Build Coastguard Worker     return false;
75*ec779b8eSAndroid Build Coastguard Worker }
76*ec779b8eSAndroid Build Coastguard Worker 
77*ec779b8eSAndroid Build Coastguard Worker }  // namespace android
78