blob: ca7d9b7db10719308df81ba31d1a9904ad12394e [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "guest/monitoring/dumpstate_ext/dumpstate_device.h"
#include <DumpstateUtil.h>
#include <android-base/properties.h>
#include <log/log.h>
#define DEVICE_LOGGING_PROPERTY "persist.vendor.logging_enabled"
using android::os::dumpstate::DumpFileToFd;
namespace android {
namespace hardware {
namespace dumpstate {
namespace V1_1 {
namespace implementation {
// Methods from ::android::hardware::dumpstate::V1_0::IDumpstateDevice follow.
Return<void> DumpstateDevice::dumpstateBoard(const hidl_handle& handle) {
// Ignore return value, just return an empty status.
dumpstateBoard_1_1(handle, DumpstateMode::DEFAULT, 30 * 1000 /* timeoutMillis */);
return Void();
}
// Methods from ::android::hardware::dumpstate::V1_1::IDumpstateDevice follow.
Return<DumpstateStatus> DumpstateDevice::dumpstateBoard_1_1(const hidl_handle& handle,
DumpstateMode mode,
uint64_t /* timeoutMillis */) {
if (handle == nullptr || handle->numFds < 1) {
ALOGE("No FDs\n");
return DumpstateStatus::ILLEGAL_ARGUMENT;
}
int fd = handle->data[0];
if (fd < 0) {
ALOGE("Invalid FD: %d\n", fd);
return DumpstateStatus::ILLEGAL_ARGUMENT;
}
bool isModeValid = false;
for (const auto dumpstateMode : hidl_enum_range<DumpstateMode>()) {
isModeValid |= (dumpstateMode == mode);
}
if (!isModeValid) {
ALOGE("Invalid mode: %d\n", mode);
return DumpstateStatus::ILLEGAL_ARGUMENT;
}
if (mode == DumpstateMode::WEAR) {
// We aren't a Wear device. Mostly just for variety in our return values for testing purposes.
ALOGE("Unsupported mode: %d\n", mode);
return DumpstateStatus::UNSUPPORTED_MODE;
}
if (mode == DumpstateMode::PROTO) {
// We don't support dumping a protobuf yet.
ALOGE("Unsupported mode: %d\n", mode);
return DumpstateStatus::UNSUPPORTED_MODE;
}
if (!::android::base::GetBoolProperty(DEVICE_LOGGING_PROPERTY, false)) {
return DumpstateStatus::DEVICE_LOGGING_NOT_ENABLED;
}
DumpFileToFd(fd, "GCE INITIAL METADATA", "/initial.metadata");
return DumpstateStatus::OK;
}
Return<void> DumpstateDevice::setDeviceLoggingEnabled(bool enable) {
::android::base::SetProperty(DEVICE_LOGGING_PROPERTY, enable ? "true" : "false");
return Void();
}
Return<bool> DumpstateDevice::getDeviceLoggingEnabled() {
return ::android::base::GetBoolProperty(DEVICE_LOGGING_PROPERTY, false);
}
} // namespace implementation
} // namespace V1_1
} // namespace dumpstate
} // namespace hardware
} // namespace android