blob: a34a65bbdd9cd540501994e994eb31dd2ac32b27 [file] [log] [blame]
Peng Xueb4d6282015-12-10 18:02:41 -08001/*
2 * Copyright (C) 2010 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ANDROID_SENSOR_REGISTRATION_INFO_H
18#define ANDROID_SENSOR_REGISTRATION_INFO_H
19
Mike Ma24743862020-01-29 00:36:55 -080020#include <ctime>
Peng Xu51224682017-03-10 16:57:27 -080021#include <iomanip>
22#include <sstream>
Mike Ma24743862020-01-29 00:36:55 -080023#include <utils/Thread.h>
24
25#include <android/util/ProtoOutputStream.h>
26#include <frameworks/base/core/proto/android/service/sensor_service.proto.h>
27#include "SensorServiceUtils.h"
Peng Xu51224682017-03-10 16:57:27 -080028
Peng Xueb4d6282015-12-10 18:02:41 -080029namespace android {
30
31class SensorService;
32
Peng Xu51224682017-03-10 16:57:27 -080033class SensorService::SensorRegistrationInfo : public SensorServiceUtil::Dumpable {
34public:
Peng Xueb4d6282015-12-10 18:02:41 -080035 SensorRegistrationInfo() : mPackageName() {
36 mSensorHandle = mSamplingRateUs = mMaxReportLatencyUs = INT32_MIN;
Mike Ma24743862020-01-29 00:36:55 -080037 mRealtimeSec = 0;
Peng Xueb4d6282015-12-10 18:02:41 -080038 mActivated = false;
39 }
40
Peng Xu51224682017-03-10 16:57:27 -080041 SensorRegistrationInfo(int32_t handle, const String8 &packageName,
Julius D'souzac35b8202017-12-11 17:33:04 -080042 int64_t samplingRateNs, int64_t maxReportLatencyNs, bool activate) {
Peng Xu51224682017-03-10 16:57:27 -080043 mSensorHandle = handle;
44 mPackageName = packageName;
45
Julius D'souzac35b8202017-12-11 17:33:04 -080046 mSamplingRateUs = static_cast<int64_t>(samplingRateNs/1000);
47 mMaxReportLatencyUs = static_cast<int64_t>(maxReportLatencyNs/1000);
Peng Xu51224682017-03-10 16:57:27 -080048 mActivated = activate;
49
50 IPCThreadState *thread = IPCThreadState::self();
51 mPid = (thread != nullptr) ? thread->getCallingPid() : -1;
52 mUid = (thread != nullptr) ? thread->getCallingUid() : -1;
53
Mike Ma24743862020-01-29 00:36:55 -080054 timespec curTime;
55 clock_gettime(CLOCK_REALTIME_COARSE, &curTime);
56 mRealtimeSec = curTime.tv_sec;
Peng Xueb4d6282015-12-10 18:02:41 -080057 }
Peng Xu51224682017-03-10 16:57:27 -080058
59 static bool isSentinel(const SensorRegistrationInfo& info) {
Mike Ma24743862020-01-29 00:36:55 -080060 return (info.mSensorHandle == INT32_MIN && info.mRealtimeSec == 0);
Peng Xu51224682017-03-10 16:57:27 -080061 }
62
63 // Dumpable interface
64 virtual std::string dump() const override {
Mike Ma24743862020-01-29 00:36:55 -080065 struct tm* timeinfo = localtime(&mRealtimeSec);
66 const int8_t hour = static_cast<int8_t>(timeinfo->tm_hour);
67 const int8_t min = static_cast<int8_t>(timeinfo->tm_min);
68 const int8_t sec = static_cast<int8_t>(timeinfo->tm_sec);
69
Peng Xu51224682017-03-10 16:57:27 -080070 std::ostringstream ss;
Mike Ma24743862020-01-29 00:36:55 -080071 ss << std::setfill('0') << std::setw(2) << static_cast<int>(hour) << ":"
72 << std::setw(2) << static_cast<int>(min) << ":"
73 << std::setw(2) << static_cast<int>(sec)
Peng Xu51224682017-03-10 16:57:27 -080074 << (mActivated ? " +" : " -")
75 << " 0x" << std::hex << std::setw(8) << mSensorHandle << std::dec
76 << std::setfill(' ') << " pid=" << std::setw(5) << mPid
77 << " uid=" << std::setw(5) << mUid << " package=" << mPackageName;
78 if (mActivated) {
79 ss << " samplingPeriod=" << mSamplingRateUs << "us"
80 << " batchingPeriod=" << mMaxReportLatencyUs << "us";
81 };
82 return ss.str();
83 }
84
Mike Ma24743862020-01-29 00:36:55 -080085 /**
86 * Dump debugging information as android.service.SensorRegistrationInfoProto protobuf message
87 * using ProtoOutputStream.
88 *
89 * See proto definition and some notes about ProtoOutputStream in
90 * frameworks/base/core/proto/android/service/sensor_service.proto
91 */
92 virtual void dump(util::ProtoOutputStream* proto) const override {
93 using namespace service::SensorRegistrationInfoProto;
94 proto->write(TIMESTAMP_SEC, int64_t(mRealtimeSec));
95 proto->write(SENSOR_HANDLE, mSensorHandle);
96 proto->write(PACKAGE_NAME, std::string(mPackageName.string()));
97 proto->write(PID, int32_t(mPid));
98 proto->write(UID, int32_t(mUid));
99 proto->write(SAMPLING_RATE_US, mSamplingRateUs);
100 proto->write(MAX_REPORT_LATENCY_US, mMaxReportLatencyUs);
101 proto->write(ACTIVATED, mActivated);
102 }
103
Peng Xu51224682017-03-10 16:57:27 -0800104private:
105 int32_t mSensorHandle;
106 String8 mPackageName;
107 pid_t mPid;
108 uid_t mUid;
Julius D'souzac35b8202017-12-11 17:33:04 -0800109 int64_t mSamplingRateUs;
110 int64_t mMaxReportLatencyUs;
Peng Xu51224682017-03-10 16:57:27 -0800111 bool mActivated;
Mike Ma24743862020-01-29 00:36:55 -0800112 time_t mRealtimeSec;
Peng Xueb4d6282015-12-10 18:02:41 -0800113};
114
115} // namespace android;
116
117#endif // ANDROID_SENSOR_REGISTRATION_INFO_H
118
119