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