2017-03-20 17:41:48 -07:00
|
|
|
/*
|
|
|
|
|
* 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.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#define LOG_TAG "VrDevice"
|
|
|
|
|
|
2018-01-29 12:34:14 -08:00
|
|
|
#include <android-base/file.h>
|
2017-04-21 11:04:15 -07:00
|
|
|
#include <android-base/logging.h>
|
|
|
|
|
#include <android-base/properties.h>
|
2018-01-29 12:34:14 -08:00
|
|
|
#include <android-base/stringprintf.h>
|
|
|
|
|
|
2017-03-20 17:41:48 -07:00
|
|
|
#include "VrDevice.h"
|
|
|
|
|
|
|
|
|
|
namespace android {
|
|
|
|
|
namespace hardware {
|
|
|
|
|
namespace vr {
|
|
|
|
|
namespace V1_0 {
|
|
|
|
|
namespace implementation {
|
|
|
|
|
|
2018-01-29 12:34:14 -08:00
|
|
|
constexpr char kTouchVRModeSysfs[] = "/sys/devices/virtual/input/ftm4_touch/vrmode";
|
|
|
|
|
|
|
|
|
|
VrDevice::VrDevice() : mVRmode(false) {
|
|
|
|
|
std::string hardware = android::base::GetProperty("ro.hardware", "");
|
|
|
|
|
if (hardware == "taimen") {
|
|
|
|
|
mFtm4Touch = true;
|
|
|
|
|
} else {
|
|
|
|
|
mFtm4Touch = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
2017-03-20 17:41:48 -07:00
|
|
|
|
|
|
|
|
Return<void> VrDevice::init() {
|
|
|
|
|
// NOOP
|
|
|
|
|
return Void();
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-21 11:04:15 -07:00
|
|
|
Return<void> VrDevice::setVrMode(bool enabled) {
|
2018-01-29 12:34:14 -08:00
|
|
|
mVRmode = enabled;
|
2017-04-21 11:04:15 -07:00
|
|
|
if (enabled) {
|
2018-01-29 12:34:14 -08:00
|
|
|
if (!android::base::SetProperty("sys.qcom.thermalcfg",
|
|
|
|
|
"/vendor/etc/thermal-engine-vr.conf")) {
|
2017-04-21 11:04:15 -07:00
|
|
|
LOG(ERROR) << "Couldn't set thermal_engine enable property";
|
|
|
|
|
return Void();
|
|
|
|
|
}
|
|
|
|
|
} else {
|
2018-01-29 12:34:14 -08:00
|
|
|
if (!android::base::SetProperty("sys.qcom.thermalcfg",
|
|
|
|
|
"/vendor/etc/thermal-engine.conf")) {
|
2017-04-21 11:04:15 -07:00
|
|
|
LOG(ERROR) << "Couldn't set thermal_engine disable property";
|
|
|
|
|
return Void();
|
|
|
|
|
}
|
|
|
|
|
}
|
2017-09-14 16:07:36 +09:00
|
|
|
if (!android::base::SetProperty("ctl.restart", "vendor.thermal-engine")) {
|
2017-04-21 11:04:15 -07:00
|
|
|
LOG(ERROR) << "Couldn't set thermal_engine restart property";
|
|
|
|
|
}
|
2018-01-29 12:34:14 -08:00
|
|
|
|
|
|
|
|
if (mFtm4Touch &&
|
|
|
|
|
!android::base::WriteStringToFile((enabled ? "1" : "0"), kTouchVRModeSysfs)) {
|
|
|
|
|
PLOG(ERROR) << "Failed to write to vrmode sysfs node with :" << enabled;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return Void();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Return<void> VrDevice::debug(const hidl_handle& handle, const hidl_vec<hidl_string>&) {
|
|
|
|
|
if (handle != nullptr && handle->numFds >= 1) {
|
|
|
|
|
int fd = handle->data[0];
|
|
|
|
|
std::string buf(android::base::StringPrintf("VRMode: %s\n",
|
|
|
|
|
(mVRmode ? "true" : "false")));
|
|
|
|
|
if (!android::base::WriteStringToFd(buf, fd)) {
|
|
|
|
|
PLOG(ERROR) << "Failed to dump state to fd";
|
2017-08-02 01:43:06 -07:00
|
|
|
}
|
2018-01-29 12:34:14 -08:00
|
|
|
fsync(fd);
|
2017-08-02 01:43:06 -07:00
|
|
|
}
|
2017-03-20 17:41:48 -07:00
|
|
|
return Void();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace implementation
|
|
|
|
|
} // namespace V1_0
|
|
|
|
|
} // namespace vr
|
|
|
|
|
} // namespace hardware
|
|
|
|
|
} // namespace android
|