1*4d7e907cSAndroid Build Coastguard Worker /*
2*4d7e907cSAndroid Build Coastguard Worker * Copyright (C) 2020 The Android Open Source Project
3*4d7e907cSAndroid Build Coastguard Worker *
4*4d7e907cSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*4d7e907cSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*4d7e907cSAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*4d7e907cSAndroid Build Coastguard Worker *
8*4d7e907cSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
9*4d7e907cSAndroid Build Coastguard Worker *
10*4d7e907cSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*4d7e907cSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*4d7e907cSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4d7e907cSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*4d7e907cSAndroid Build Coastguard Worker * limitations under the License.
15*4d7e907cSAndroid Build Coastguard Worker */
16*4d7e907cSAndroid Build Coastguard Worker
17*4d7e907cSAndroid Build Coastguard Worker #include <android-base/properties.h>
18*4d7e907cSAndroid Build Coastguard Worker #include <android/hardware/dumpstate/1.1/IDumpstateDevice.h>
19*4d7e907cSAndroid Build Coastguard Worker #include <android/hardware/dumpstate/1.1/types.h>
20*4d7e907cSAndroid Build Coastguard Worker #include <hidl/HidlLazyUtils.h>
21*4d7e907cSAndroid Build Coastguard Worker #include <hidl/HidlSupport.h>
22*4d7e907cSAndroid Build Coastguard Worker #include <hidl/HidlTransportSupport.h>
23*4d7e907cSAndroid Build Coastguard Worker #include <log/log.h>
24*4d7e907cSAndroid Build Coastguard Worker
25*4d7e907cSAndroid Build Coastguard Worker #include "DumpstateUtil.h"
26*4d7e907cSAndroid Build Coastguard Worker
27*4d7e907cSAndroid Build Coastguard Worker namespace {
28*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::hidl_handle;
29*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::Return;
30*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::Void;
31*4d7e907cSAndroid Build Coastguard Worker
32*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::dumpstate::V1_1::DumpstateMode;
33*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::dumpstate::V1_1::DumpstateStatus;
34*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::dumpstate::V1_1::IDumpstateDevice;
35*4d7e907cSAndroid Build Coastguard Worker
36*4d7e907cSAndroid Build Coastguard Worker using ::android::os::dumpstate::DumpFileToFd;
37*4d7e907cSAndroid Build Coastguard Worker
38*4d7e907cSAndroid Build Coastguard Worker const char kVerboseLoggingProperty[] = "persist.dumpstate.verbose_logging.enabled";
39*4d7e907cSAndroid Build Coastguard Worker
40*4d7e907cSAndroid Build Coastguard Worker struct DumpstateDevice : public IDumpstateDevice {
41*4d7e907cSAndroid Build Coastguard Worker // 1.1
dumpstateBoard_1_1__anon63f082740111::DumpstateDevice42*4d7e907cSAndroid Build Coastguard Worker Return<DumpstateStatus> dumpstateBoard_1_1(const hidl_handle& handle, const DumpstateMode mode,
43*4d7e907cSAndroid Build Coastguard Worker uint64_t /*timeoutMillis*/) override {
44*4d7e907cSAndroid Build Coastguard Worker if (handle == nullptr || handle->numFds < 1) {
45*4d7e907cSAndroid Build Coastguard Worker ALOGE("no FDs\n");
46*4d7e907cSAndroid Build Coastguard Worker return DumpstateStatus::ILLEGAL_ARGUMENT;
47*4d7e907cSAndroid Build Coastguard Worker }
48*4d7e907cSAndroid Build Coastguard Worker
49*4d7e907cSAndroid Build Coastguard Worker int fd = handle->data[0];
50*4d7e907cSAndroid Build Coastguard Worker if (fd < 0) {
51*4d7e907cSAndroid Build Coastguard Worker ALOGE("invalid FD: %d\n", fd);
52*4d7e907cSAndroid Build Coastguard Worker return DumpstateStatus::ILLEGAL_ARGUMENT;
53*4d7e907cSAndroid Build Coastguard Worker }
54*4d7e907cSAndroid Build Coastguard Worker
55*4d7e907cSAndroid Build Coastguard Worker switch (mode) {
56*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::FULL:
57*4d7e907cSAndroid Build Coastguard Worker return dumpstateBoardImpl(fd, true);
58*4d7e907cSAndroid Build Coastguard Worker
59*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::DEFAULT:
60*4d7e907cSAndroid Build Coastguard Worker return dumpstateBoardImpl(fd, false);
61*4d7e907cSAndroid Build Coastguard Worker
62*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::INTERACTIVE:
63*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::REMOTE:
64*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::WEAR:
65*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::CONNECTIVITY:
66*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::WIFI:
67*4d7e907cSAndroid Build Coastguard Worker case DumpstateMode::PROTO:
68*4d7e907cSAndroid Build Coastguard Worker ALOGE("The requested mode is not supported: %s\n", toString(mode).c_str());
69*4d7e907cSAndroid Build Coastguard Worker return DumpstateStatus::UNSUPPORTED_MODE;
70*4d7e907cSAndroid Build Coastguard Worker
71*4d7e907cSAndroid Build Coastguard Worker default:
72*4d7e907cSAndroid Build Coastguard Worker ALOGE("The requested mode is invalid: %s\n", toString(mode).c_str());
73*4d7e907cSAndroid Build Coastguard Worker return DumpstateStatus::ILLEGAL_ARGUMENT;
74*4d7e907cSAndroid Build Coastguard Worker }
75*4d7e907cSAndroid Build Coastguard Worker }
76*4d7e907cSAndroid Build Coastguard Worker
setVerboseLoggingEnabled__anon63f082740111::DumpstateDevice77*4d7e907cSAndroid Build Coastguard Worker Return<void> setVerboseLoggingEnabled(bool enable) override {
78*4d7e907cSAndroid Build Coastguard Worker ::android::base::SetProperty(kVerboseLoggingProperty, enable ? "true" : "false");
79*4d7e907cSAndroid Build Coastguard Worker return Void();
80*4d7e907cSAndroid Build Coastguard Worker }
81*4d7e907cSAndroid Build Coastguard Worker
getVerboseLoggingEnabled__anon63f082740111::DumpstateDevice82*4d7e907cSAndroid Build Coastguard Worker Return<bool> getVerboseLoggingEnabled() override { return getVerboseLoggingEnabledImpl(); }
83*4d7e907cSAndroid Build Coastguard Worker
84*4d7e907cSAndroid Build Coastguard Worker // 1.0
dumpstateBoard__anon63f082740111::DumpstateDevice85*4d7e907cSAndroid Build Coastguard Worker Return<void> dumpstateBoard(const hidl_handle& h) override {
86*4d7e907cSAndroid Build Coastguard Worker dumpstateBoard_1_1(h, DumpstateMode::DEFAULT, 0);
87*4d7e907cSAndroid Build Coastguard Worker return Void();
88*4d7e907cSAndroid Build Coastguard Worker }
89*4d7e907cSAndroid Build Coastguard Worker
dumpstateBoardImpl__anon63f082740111::DumpstateDevice90*4d7e907cSAndroid Build Coastguard Worker DumpstateStatus dumpstateBoardImpl(const int fd, const bool full) {
91*4d7e907cSAndroid Build Coastguard Worker ALOGD("DumpstateDevice::dumpstateBoard() FD: %d\n", fd);
92*4d7e907cSAndroid Build Coastguard Worker ALOGI("Dumpstate HIDL not provided by device\n");
93*4d7e907cSAndroid Build Coastguard Worker
94*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, "verbose logging: %s\n",
95*4d7e907cSAndroid Build Coastguard Worker getVerboseLoggingEnabledImpl() ? "enabled" : "disabled");
96*4d7e907cSAndroid Build Coastguard Worker
97*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, "[%s] %s\n", (full ? "full" : "default"), "Hello, world!");
98*4d7e907cSAndroid Build Coastguard Worker
99*4d7e907cSAndroid Build Coastguard Worker // Shows an example on how to use the libdumpstateutil API.
100*4d7e907cSAndroid Build Coastguard Worker DumpFileToFd(fd, "cmdline", "/proc/self/cmdline");
101*4d7e907cSAndroid Build Coastguard Worker
102*4d7e907cSAndroid Build Coastguard Worker return DumpstateStatus::OK;
103*4d7e907cSAndroid Build Coastguard Worker }
104*4d7e907cSAndroid Build Coastguard Worker
getVerboseLoggingEnabledImpl__anon63f082740111::DumpstateDevice105*4d7e907cSAndroid Build Coastguard Worker static bool getVerboseLoggingEnabledImpl() {
106*4d7e907cSAndroid Build Coastguard Worker return ::android::base::GetBoolProperty(kVerboseLoggingProperty, false);
107*4d7e907cSAndroid Build Coastguard Worker }
108*4d7e907cSAndroid Build Coastguard Worker };
109*4d7e907cSAndroid Build Coastguard Worker } // namespace
110*4d7e907cSAndroid Build Coastguard Worker
main(int,char **)111*4d7e907cSAndroid Build Coastguard Worker int main(int, char**) {
112*4d7e907cSAndroid Build Coastguard Worker using ::android::sp;
113*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::configureRpcThreadpool;
114*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::joinRpcThreadpool;
115*4d7e907cSAndroid Build Coastguard Worker using ::android::hardware::LazyServiceRegistrar;
116*4d7e907cSAndroid Build Coastguard Worker
117*4d7e907cSAndroid Build Coastguard Worker configureRpcThreadpool(1, true);
118*4d7e907cSAndroid Build Coastguard Worker
119*4d7e907cSAndroid Build Coastguard Worker auto dumpstate = sp<DumpstateDevice>::make();
120*4d7e907cSAndroid Build Coastguard Worker auto serviceRegistrar = LazyServiceRegistrar::getInstance();
121*4d7e907cSAndroid Build Coastguard Worker
122*4d7e907cSAndroid Build Coastguard Worker if (serviceRegistrar.registerService(dumpstate) != ::android::OK) {
123*4d7e907cSAndroid Build Coastguard Worker ALOGE("Could not register service.");
124*4d7e907cSAndroid Build Coastguard Worker return 1;
125*4d7e907cSAndroid Build Coastguard Worker }
126*4d7e907cSAndroid Build Coastguard Worker
127*4d7e907cSAndroid Build Coastguard Worker joinRpcThreadpool();
128*4d7e907cSAndroid Build Coastguard Worker return 0;
129*4d7e907cSAndroid Build Coastguard Worker }
130