xref: /aosp_15_r20/frameworks/av/services/audioflinger/fastpath/FastCaptureDumpState.cpp (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1*ec779b8eSAndroid Build Coastguard Worker /*
2*ec779b8eSAndroid Build Coastguard Worker  * Copyright (C) 2014 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_TAG "FastCaptureDumpState"
18*ec779b8eSAndroid Build Coastguard Worker //define LOG_NDEBUG 0
19*ec779b8eSAndroid Build Coastguard Worker 
20*ec779b8eSAndroid Build Coastguard Worker #include "Configuration.h"
21*ec779b8eSAndroid Build Coastguard Worker #include <utils/Log.h>
22*ec779b8eSAndroid Build Coastguard Worker #include "FastCaptureDumpState.h"
23*ec779b8eSAndroid Build Coastguard Worker #include "FastCaptureState.h"
24*ec779b8eSAndroid Build Coastguard Worker 
25*ec779b8eSAndroid Build Coastguard Worker namespace android {
26*ec779b8eSAndroid Build Coastguard Worker 
dump(int fd) const27*ec779b8eSAndroid Build Coastguard Worker void FastCaptureDumpState::dump(int fd) const
28*ec779b8eSAndroid Build Coastguard Worker {
29*ec779b8eSAndroid Build Coastguard Worker     if (mCommand == FastCaptureState::INITIAL) {
30*ec779b8eSAndroid Build Coastguard Worker         dprintf(fd, "  FastCapture not initialized\n");
31*ec779b8eSAndroid Build Coastguard Worker         return;
32*ec779b8eSAndroid Build Coastguard Worker     }
33*ec779b8eSAndroid Build Coastguard Worker     const double measuredWarmupMs = (mMeasuredWarmupTs.tv_sec * 1000.0) +
34*ec779b8eSAndroid Build Coastguard Worker             (mMeasuredWarmupTs.tv_nsec / 1000000.0);
35*ec779b8eSAndroid Build Coastguard Worker     const double periodSec = (double) mFrameCount / mSampleRate;
36*ec779b8eSAndroid Build Coastguard Worker     dprintf(fd, "  FastCapture command=%s readSequence=%u framesRead=%u\n"
37*ec779b8eSAndroid Build Coastguard Worker                 "              readErrors=%u sampleRate=%u frameCount=%zu\n"
38*ec779b8eSAndroid Build Coastguard Worker                 "              measuredWarmup=%.3g ms, warmupCycles=%u period=%.2f ms\n"
39*ec779b8eSAndroid Build Coastguard Worker                 "              silenced: %s\n",
40*ec779b8eSAndroid Build Coastguard Worker                 FastCaptureState::commandToString(mCommand), mReadSequence, mFramesRead,
41*ec779b8eSAndroid Build Coastguard Worker                 mReadErrors, mSampleRate, mFrameCount, measuredWarmupMs, mWarmupCycles,
42*ec779b8eSAndroid Build Coastguard Worker                 periodSec * 1e3, mSilenced ? "true" : "false");
43*ec779b8eSAndroid Build Coastguard Worker }
44*ec779b8eSAndroid Build Coastguard Worker 
45*ec779b8eSAndroid Build Coastguard Worker }  // namespace android
46