sm8250-common: livedisplay: Say hello to IDisplayModes ^.^

This commit is contained in:
LuK1337
2020-06-25 10:06:37 +02:00
parent f03b5d364a
commit 6e2bca5af7
6 changed files with 79 additions and 30 deletions

View File

@@ -17,7 +17,10 @@
#define LOG_TAG "DisplayModesService"
#include "DisplayModes.h"
#include <android-base/logging.h>
#include <android-base/properties.h>
#include <fstream>
namespace vendor {
@@ -26,15 +29,15 @@ namespace livedisplay {
namespace V2_0 {
namespace implementation {
static constexpr const char* kModePath =
"/sys/devices/platform/soc/ae00000.qcom,mdss_mdp/main_display/display_mode";
static constexpr const char* kDefaultPath = "/data/misc/display/default_display_mode";
static constexpr const char* kDisplayModeProp = "sys.display.mode";
static const std::string kModeBasePath = "/sys/class/drm/card0-DSI-1/";
static const std::string kDefaultPath = "/data/misc/display/default_display_mode";
const std::map<int32_t, DisplayModes::ModeInfo> DisplayModes::kModeMap = {
{0, {"Standard", "default"}},
{1, {"sRGB", "srgb"}},
{2, {"DCI P3", "dci-p3"}},
{3, {"Wide Color", "widecolor"}},
{1, {"DCI P3", "native_display_p3_mode"}},
{2, {"Wide Color", "native_display_wide_color_mode"}},
{3, {"sRGB", "native_display_srgb_color_mode"}},
};
DisplayModes::DisplayModes() : mDefaultModeId(0) {
@@ -48,18 +51,19 @@ DisplayModes::DisplayModes() : mDefaultModeId(0) {
}
for (const auto& entry : kModeMap) {
if (value == entry.second.value) {
// Check if default mode is a valid mode
if (value == std::to_string(entry.first)) {
mDefaultModeId = entry.first;
android::base::SetProperty(kDisplayModeProp, entry.second.node);
break;
}
}
setDisplayMode(mDefaultModeId, false);
}
// Methods from ::vendor::lineage::livedisplay::V2_0::IDisplayModes follow.
Return<void> DisplayModes::getDisplayModes(getDisplayModes_cb resultCb) {
std::vector<DisplayMode> modes;
for (const auto& entry : kModeMap) {
modes.push_back({entry.first, entry.second.name});
}
@@ -69,13 +73,17 @@ Return<void> DisplayModes::getDisplayModes(getDisplayModes_cb resultCb) {
Return<void> DisplayModes::getCurrentDisplayMode(getCurrentDisplayMode_cb resultCb) {
int32_t currentModeId = mDefaultModeId;
std::ifstream modeFile(kModePath);
std::string value;
modeFile >> value;
if (!modeFile.fail()) {
for (const auto& entry : kModeMap) {
if (value == entry.second.value) {
for (const auto& entry : kModeMap) {
if (entry.first == 0) {
continue;
}
std::ifstream modeFile(kModeBasePath + entry.second.node);
if (!modeFile.fail()) {
modeFile >> value;
if (value == "1") {
currentModeId = entry.first;
break;
}
@@ -91,24 +99,39 @@ Return<void> DisplayModes::getDefaultDisplayMode(getDefaultDisplayMode_cb result
}
Return<bool> DisplayModes::setDisplayMode(int32_t modeID, bool makeDefault) {
// Disable all modes
for (const auto& entry : kModeMap) {
if (entry.first == 0) {
continue;
}
std::ofstream modeFile(kModeBasePath + entry.second.node);
if (!modeFile.fail()) {
modeFile << 0;
}
}
const auto iter = kModeMap.find(modeID);
if (iter == kModeMap.end()) {
return false;
}
std::ofstream modeFile(kModePath);
modeFile << iter->second.value;
if (modeFile.fail()) {
return false;
if (modeID != 0) {
std::ofstream modeFile(kModeBasePath + iter->second.node);
modeFile << 1;
if (modeFile.fail()) {
return false;
}
android::base::SetProperty(kDisplayModeProp, iter->second.node);
}
if (makeDefault) {
std::ofstream defaultFile(kDefaultPath);
defaultFile << iter->second.value;
defaultFile << iter->first;
if (defaultFile.fail()) {
return false;
}
mDefaultModeId = iter->first;
}
return true;
}