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