xref: /aosp_15_r20/hardware/interfaces/dumpstate/1.1/default/main.cpp (revision 4d7e907c777eeecc4c5bd7cf640a754fac206ff7)
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