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