xref: /aosp_15_r20/hardware/interfaces/dumpstate/aidl/default/Dumpstate.cpp (revision 4d7e907c777eeecc4c5bd7cf640a754fac206ff7)
1*4d7e907cSAndroid Build Coastguard Worker /*
2*4d7e907cSAndroid Build Coastguard Worker  * Copyright (C) 2021 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 <log/log.h>
19*4d7e907cSAndroid Build Coastguard Worker #include "DumpstateUtil.h"
20*4d7e907cSAndroid Build Coastguard Worker 
21*4d7e907cSAndroid Build Coastguard Worker #include "Dumpstate.h"
22*4d7e907cSAndroid Build Coastguard Worker 
23*4d7e907cSAndroid Build Coastguard Worker using android::os::dumpstate::DumpFileToFd;
24*4d7e907cSAndroid Build Coastguard Worker 
25*4d7e907cSAndroid Build Coastguard Worker namespace aidl {
26*4d7e907cSAndroid Build Coastguard Worker namespace android {
27*4d7e907cSAndroid Build Coastguard Worker namespace hardware {
28*4d7e907cSAndroid Build Coastguard Worker namespace dumpstate {
29*4d7e907cSAndroid Build Coastguard Worker 
30*4d7e907cSAndroid Build Coastguard Worker const char kVerboseLoggingProperty[] = "persist.dumpstate.verbose_logging.enabled";
31*4d7e907cSAndroid Build Coastguard Worker 
dumpstateBoard(const std::vector<::ndk::ScopedFileDescriptor> & in_fds,IDumpstateDevice::DumpstateMode in_mode,int64_t in_timeoutMillis)32*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Dumpstate::dumpstateBoard(const std::vector<::ndk::ScopedFileDescriptor>& in_fds,
33*4d7e907cSAndroid Build Coastguard Worker                                              IDumpstateDevice::DumpstateMode in_mode,
34*4d7e907cSAndroid Build Coastguard Worker                                              int64_t in_timeoutMillis) {
35*4d7e907cSAndroid Build Coastguard Worker     (void)in_timeoutMillis;
36*4d7e907cSAndroid Build Coastguard Worker 
37*4d7e907cSAndroid Build Coastguard Worker     if (in_fds.size() < 1) {
38*4d7e907cSAndroid Build Coastguard Worker         return ndk::ScopedAStatus::fromExceptionCodeWithMessage(EX_ILLEGAL_ARGUMENT,
39*4d7e907cSAndroid Build Coastguard Worker                                                                 "No file descriptor");
40*4d7e907cSAndroid Build Coastguard Worker     }
41*4d7e907cSAndroid Build Coastguard Worker 
42*4d7e907cSAndroid Build Coastguard Worker     int fd = in_fds[0].get();
43*4d7e907cSAndroid Build Coastguard Worker     if (fd < 0) {
44*4d7e907cSAndroid Build Coastguard Worker         return ndk::ScopedAStatus::fromExceptionCodeWithMessage(EX_ILLEGAL_ARGUMENT,
45*4d7e907cSAndroid Build Coastguard Worker                                                                 "Invalid file descriptor");
46*4d7e907cSAndroid Build Coastguard Worker     }
47*4d7e907cSAndroid Build Coastguard Worker 
48*4d7e907cSAndroid Build Coastguard Worker     switch (in_mode) {
49*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::FULL:
50*4d7e907cSAndroid Build Coastguard Worker             return dumpstateBoardImpl(fd, true);
51*4d7e907cSAndroid Build Coastguard Worker 
52*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::DEFAULT:
53*4d7e907cSAndroid Build Coastguard Worker             return dumpstateBoardImpl(fd, false);
54*4d7e907cSAndroid Build Coastguard Worker 
55*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::INTERACTIVE:
56*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::REMOTE:
57*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::WEAR:
58*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::CONNECTIVITY:
59*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::WIFI:
60*4d7e907cSAndroid Build Coastguard Worker         case IDumpstateDevice::DumpstateMode::PROTO:
61*4d7e907cSAndroid Build Coastguard Worker             return ndk::ScopedAStatus::fromServiceSpecificErrorWithMessage(ERROR_UNSUPPORTED_MODE,
62*4d7e907cSAndroid Build Coastguard Worker                                                                            "Unsupported mode");
63*4d7e907cSAndroid Build Coastguard Worker 
64*4d7e907cSAndroid Build Coastguard Worker         default:
65*4d7e907cSAndroid Build Coastguard Worker             return ndk::ScopedAStatus::fromExceptionCodeWithMessage(EX_ILLEGAL_ARGUMENT,
66*4d7e907cSAndroid Build Coastguard Worker                                                                     "Invalid mode");
67*4d7e907cSAndroid Build Coastguard Worker     }
68*4d7e907cSAndroid Build Coastguard Worker 
69*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
70*4d7e907cSAndroid Build Coastguard Worker }
71*4d7e907cSAndroid Build Coastguard Worker 
getVerboseLoggingEnabled(bool * _aidl_return)72*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Dumpstate::getVerboseLoggingEnabled(bool* _aidl_return) {
73*4d7e907cSAndroid Build Coastguard Worker     *_aidl_return = getVerboseLoggingEnabledImpl();
74*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
75*4d7e907cSAndroid Build Coastguard Worker }
76*4d7e907cSAndroid Build Coastguard Worker 
setVerboseLoggingEnabled(bool in_enable)77*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Dumpstate::setVerboseLoggingEnabled(bool in_enable) {
78*4d7e907cSAndroid Build Coastguard Worker     ::android::base::SetProperty(kVerboseLoggingProperty, in_enable ? "true" : "false");
79*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
80*4d7e907cSAndroid Build Coastguard Worker }
81*4d7e907cSAndroid Build Coastguard Worker 
getVerboseLoggingEnabledImpl()82*4d7e907cSAndroid Build Coastguard Worker bool Dumpstate::getVerboseLoggingEnabledImpl() {
83*4d7e907cSAndroid Build Coastguard Worker     return ::android::base::GetBoolProperty(kVerboseLoggingProperty, false);
84*4d7e907cSAndroid Build Coastguard Worker }
85*4d7e907cSAndroid Build Coastguard Worker 
dumpstateBoardImpl(const int fd,const bool full)86*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Dumpstate::dumpstateBoardImpl(const int fd, const bool full) {
87*4d7e907cSAndroid Build Coastguard Worker     ALOGD("DumpstateDevice::dumpstateBoard() FD: %d\n", fd);
88*4d7e907cSAndroid Build Coastguard Worker 
89*4d7e907cSAndroid Build Coastguard Worker     dprintf(fd, "verbose logging: %s\n", getVerboseLoggingEnabledImpl() ? "enabled" : "disabled");
90*4d7e907cSAndroid Build Coastguard Worker     dprintf(fd, "[%s] %s\n", (full ? "full" : "default"), "Hello, world!");
91*4d7e907cSAndroid Build Coastguard Worker 
92*4d7e907cSAndroid Build Coastguard Worker     // Shows an example on how to use the libdumpstateutil API.
93*4d7e907cSAndroid Build Coastguard Worker     DumpFileToFd(fd, "cmdline", "/proc/self/cmdline");
94*4d7e907cSAndroid Build Coastguard Worker 
95*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
96*4d7e907cSAndroid Build Coastguard Worker }
97*4d7e907cSAndroid Build Coastguard Worker 
98*4d7e907cSAndroid Build Coastguard Worker }  // namespace dumpstate
99*4d7e907cSAndroid Build Coastguard Worker }  // namespace hardware
100*4d7e907cSAndroid Build Coastguard Worker }  // namespace android
101*4d7e907cSAndroid Build Coastguard Worker }  // namespace aidl
102