xref: /aosp_15_r20/frameworks/av/media/module/foundation/AHandler.cpp (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1*ec779b8eSAndroid Build Coastguard Worker /*
2*ec779b8eSAndroid Build Coastguard Worker  * Copyright (C) 2010 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 "AHandler"
19*ec779b8eSAndroid Build Coastguard Worker #include <utils/Log.h>
20*ec779b8eSAndroid Build Coastguard Worker 
21*ec779b8eSAndroid Build Coastguard Worker #include <media/stagefright/foundation/AHandler.h>
22*ec779b8eSAndroid Build Coastguard Worker #include <media/stagefright/foundation/AMessage.h>
23*ec779b8eSAndroid Build Coastguard Worker 
24*ec779b8eSAndroid Build Coastguard Worker namespace android {
25*ec779b8eSAndroid Build Coastguard Worker 
deliverMessage(const sp<AMessage> & msg)26*ec779b8eSAndroid Build Coastguard Worker void AHandler::deliverMessage(const sp<AMessage> &msg) {
27*ec779b8eSAndroid Build Coastguard Worker     setDeliveryStatus(true, msg->what(), ALooper::GetNowUs());
28*ec779b8eSAndroid Build Coastguard Worker     onMessageReceived(msg);
29*ec779b8eSAndroid Build Coastguard Worker     mMessageCounter++;
30*ec779b8eSAndroid Build Coastguard Worker     setDeliveryStatus(false, 0, 0);
31*ec779b8eSAndroid Build Coastguard Worker 
32*ec779b8eSAndroid Build Coastguard Worker     if (mVerboseStats) {
33*ec779b8eSAndroid Build Coastguard Worker         uint32_t what = msg->what();
34*ec779b8eSAndroid Build Coastguard Worker         ssize_t idx = mMessages.indexOfKey(what);
35*ec779b8eSAndroid Build Coastguard Worker         if (idx < 0) {
36*ec779b8eSAndroid Build Coastguard Worker             mMessages.add(what, 1);
37*ec779b8eSAndroid Build Coastguard Worker         } else {
38*ec779b8eSAndroid Build Coastguard Worker             mMessages.editValueAt(idx)++;
39*ec779b8eSAndroid Build Coastguard Worker         }
40*ec779b8eSAndroid Build Coastguard Worker     }
41*ec779b8eSAndroid Build Coastguard Worker }
42*ec779b8eSAndroid Build Coastguard Worker 
setDeliveryStatus(bool delivering,uint32_t what,int64_t startUs)43*ec779b8eSAndroid Build Coastguard Worker void AHandler::setDeliveryStatus(bool delivering, uint32_t what, int64_t startUs) {
44*ec779b8eSAndroid Build Coastguard Worker     AutoMutex autoLock(mLock);
45*ec779b8eSAndroid Build Coastguard Worker     mDeliveringMessage = delivering;
46*ec779b8eSAndroid Build Coastguard Worker     mCurrentMessageWhat = what;
47*ec779b8eSAndroid Build Coastguard Worker     mCurrentMessageStartTimeUs = startUs;
48*ec779b8eSAndroid Build Coastguard Worker }
49*ec779b8eSAndroid Build Coastguard Worker 
getDeliveryStatus(bool & delivering,uint32_t & what,int64_t & durationUs)50*ec779b8eSAndroid Build Coastguard Worker void AHandler::getDeliveryStatus(bool& delivering, uint32_t& what, int64_t& durationUs) {
51*ec779b8eSAndroid Build Coastguard Worker     AutoMutex autoLock(mLock);
52*ec779b8eSAndroid Build Coastguard Worker     delivering = mDeliveringMessage;
53*ec779b8eSAndroid Build Coastguard Worker     what = mCurrentMessageWhat;
54*ec779b8eSAndroid Build Coastguard Worker     durationUs = mCurrentMessageStartTimeUs == 0 ?
55*ec779b8eSAndroid Build Coastguard Worker             0 : ALooper::GetNowUs() - mCurrentMessageStartTimeUs;
56*ec779b8eSAndroid Build Coastguard Worker }
57*ec779b8eSAndroid Build Coastguard Worker 
58*ec779b8eSAndroid Build Coastguard Worker }  // namespace android
59