diff options
author | BeYkeRYkt <beykerykt@gmail.com> | 2018-12-23 22:55:35 +0900 |
---|---|---|
committer | Michael Bestas <mkbestas@lineageos.org> | 2019-10-23 01:12:57 +0300 |
commit | 070a8e149fac0292eb49d1489a6876957b8d85b6 (patch) | |
tree | cdcf5e3a89745c2f85ae35df29e2c0934c7238af | |
parent | 584395ec9331f126d114593003cb249fb603f8dd (diff) | |
download | vendor_qcom_opensource_power-070a8e149fac0292eb49d1489a6876957b8d85b6.tar.gz vendor_qcom_opensource_power-070a8e149fac0292eb49d1489a6876957b8d85b6.tar.bz2 vendor_qcom_opensource_power-070a8e149fac0292eb49d1489a6876957b8d85b6.zip |
power: msm8937: Support power profiles
Author: BeYkeRYkt <beykerykt@gmail.com>
Date: Sun Dec 23 22:55:35 2018 +0900
power: Add specific powerhal for msm8937
* msm8937 is on the same CAF line along with msm8953 and msm8996 and also
supports the MPCTL_V3 commands, in contrast to msm8952. Separate it from
msm8952.
Change-Id: I58b0d7563cd3896ee4484ed0e0f38a6ef7eb01b2
Author: BeYkeRYkt <beykerykt@gmail.com>
Date: Sun Dec 23 23:21:50 2018 +0900
power: msm8937: Update power profile settings
* msm8937 supports the MPCTL_V3 commands.
Change-Id: Ibeaaf3d4577a8378f1d9a495b87ac58f75b1da73
Author: dianlujitao <dianlujitao@lineageos.org>
Date: Sat Feb 23 20:24:57 2019 +0800
power: Pass NULL parameter in powerHint if data is zero
* This restores the behavior in AOSP and CAF power HAL to avoid
confusion.
Change-Id: I72f5bb9286e2f57121e39eea82d2fe8854989393
Change-Id: Ibaaf9a8a4398dfac12c901835f2f7aae9eefec3b
-rw-r--r-- | power-8937.c | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/power-8937.c b/power-8937.c index 6887b78..3509665 100644 --- a/power-8937.c +++ b/power-8937.c @@ -1,5 +1,6 @@ /* * Copyright (c) 2015,2018 The Linux Foundation. All rights reserved. + * Copyright (C) 2018-2019 The LineageOS Project * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are @@ -59,6 +60,91 @@ const int kMinInteractiveDuration = 500; /* ms */ const int kMaxInteractiveDuration = 5000; /* ms */ const int kMaxLaunchDuration = 5000; /* ms */ +static int current_power_profile = PROFILE_BALANCED; + +// clang-format off +static int profile_high_performance[] = { + SCHED_BOOST_ON_V3, 0x1, + ALL_CPUS_PWR_CLPS_DIS_V3, 0x1, + CPUS_ONLINE_MIN_BIG, 0x4, + MIN_FREQ_BIG_CORE_0, 0xFFF, + MIN_FREQ_LITTLE_CORE_0, 0xFFF, + GPU_MIN_POWER_LEVEL, 0x1, + SCHED_PREFER_IDLE_DIS_V3, 0x1, + SCHED_SMALL_TASK, 0x1, + SCHED_MOSTLY_IDLE_NR_RUN, 0x1, + SCHED_MOSTLY_IDLE_LOAD, 0x1, +}; + +static int profile_power_save[] = { + CPUS_ONLINE_MAX_BIG, 0x1, + MAX_FREQ_BIG_CORE_0, 0x3bf, + MAX_FREQ_LITTLE_CORE_0, 0x300, +}; + +static int profile_bias_power[] = { + MAX_FREQ_BIG_CORE_0, 0x4B0, + MAX_FREQ_LITTLE_CORE_0, 0x300, +}; + +static int profile_bias_performance[] = { + CPUS_ONLINE_MAX_BIG, 0x4, + MIN_FREQ_BIG_CORE_0, 0x540, +}; +// clang-format on + +#ifdef INTERACTION_BOOST +int get_number_of_profiles() { + return 5; +} +#endif + +static int set_power_profile(void* data) { + int profile = data ? *((int*)data) : 0; + int ret = -EINVAL; + const char* profile_name = NULL; + + if (profile == current_power_profile) return 0; + + ALOGV("%s: Profile=%d", __func__, profile); + + if (current_power_profile != PROFILE_BALANCED) { + undo_hint_action(DEFAULT_PROFILE_HINT_ID); + ALOGV("%s: Hint undone", __func__); + current_power_profile = PROFILE_BALANCED; + } + + if (profile == PROFILE_POWER_SAVE) { + ret = perform_hint_action(DEFAULT_PROFILE_HINT_ID, profile_power_save, + ARRAY_SIZE(profile_power_save)); + profile_name = "powersave"; + + } else if (profile == PROFILE_HIGH_PERFORMANCE) { + ret = perform_hint_action(DEFAULT_PROFILE_HINT_ID, profile_high_performance, + ARRAY_SIZE(profile_high_performance)); + profile_name = "performance"; + + } else if (profile == PROFILE_BIAS_POWER) { + ret = perform_hint_action(DEFAULT_PROFILE_HINT_ID, profile_bias_power, + ARRAY_SIZE(profile_bias_power)); + profile_name = "bias power"; + + } else if (profile == PROFILE_BIAS_PERFORMANCE) { + ret = perform_hint_action(DEFAULT_PROFILE_HINT_ID, profile_bias_performance, + ARRAY_SIZE(profile_bias_performance)); + profile_name = "bias perf"; + } else if (profile == PROFILE_BALANCED) { + ret = 0; + profile_name = "balanced"; + } + + if (ret == 0) { + current_power_profile = profile; + ALOGD("%s: Set %s mode", __func__, profile_name); + } + return ret; +} + /** * Returns true if the target is SDM439/SDM429. */ @@ -218,6 +304,18 @@ static int process_activity_launch_hint(void* data) { int power_hint_override(power_hint_t hint, void* data) { int ret_val = HINT_NONE; + + if (hint == POWER_HINT_SET_PROFILE) { + if (set_power_profile(data) < 0) ALOGE("Setting power profile failed. perfd not started?"); + return HINT_HANDLED; + } + + // Skip other hints in high/low power modes + if (current_power_profile == PROFILE_POWER_SAVE || + current_power_profile == PROFILE_HIGH_PERFORMANCE) { + return HINT_HANDLED; + } + switch (hint) { case POWER_HINT_VIDEO_ENCODE: ret_val = process_video_encode_hint(data); |