summaryrefslogtreecommitdiffstats
path: root/power-8996.c
diff options
context:
space:
mode:
authorMichael Bestas <mkbestas@lineageos.org>2019-10-06 02:05:22 +0300
committerMichael Bestas <mkbestas@lineageos.org>2019-10-23 01:12:57 +0300
commit7af0fea40b41e90123908e0ea104f70dfc370edb (patch)
treef62a8881276a7e49a035b85ea4b0d25ecbfa7fc1 /power-8996.c
parent7075241133d606a11966eb9517bc727c4b7115ae (diff)
downloadvendor_qcom_opensource_power-7af0fea40b41e90123908e0ea104f70dfc370edb.tar.gz
vendor_qcom_opensource_power-7af0fea40b41e90123908e0ea104f70dfc370edb.tar.bz2
vendor_qcom_opensource_power-7af0fea40b41e90123908e0ea104f70dfc370edb.zip
power: Clean up and fix video encode/decode hint handling
* Unify code style for non legacy SoCs * Restore legacy SoC handling which used to live in power-common.c but was removed in commit 561cffcbfa66192e839e040d2da3bff2ecf8dcac Change-Id: Ieb84e6d6c8d762614e21267e81e6057aa64b36dd
Diffstat (limited to 'power-8996.c')
-rw-r--r--power-8996.c27
1 files changed, 13 insertions, 14 deletions
diff --git a/power-8996.c b/power-8996.c
index 9269149..49f5932 100644
--- a/power-8996.c
+++ b/power-8996.c
@@ -47,13 +47,16 @@
#include "power-common.h"
#include "utils.h"
+static int video_encode_hint_sent;
+
static int process_video_encode_hint(void* metadata) {
char governor[80];
struct video_encode_metadata_t video_encode_metadata;
+ if (!metadata) return HINT_NONE;
+
if (get_scaling_governor(governor, sizeof(governor)) == -1) {
ALOGE("Can't obtain scaling governor.");
-
return HINT_NONE;
}
@@ -62,12 +65,8 @@ static int process_video_encode_hint(void* metadata) {
video_encode_metadata.state = -1;
video_encode_metadata.hint_id = DEFAULT_VIDEO_ENCODE_HINT_ID;
- if (metadata) {
- if (parse_video_encode_metadata((char*)metadata, &video_encode_metadata) == -1) {
- ALOGE("Error occurred while parsing metadata.");
- return HINT_NONE;
- }
- } else {
+ if (parse_video_encode_metadata((char*)metadata, &video_encode_metadata) == -1) {
+ ALOGE("Error occurred while parsing metadata.");
return HINT_NONE;
}
@@ -94,17 +93,17 @@ static int process_video_encode_hint(void* metadata) {
0x41420000, 0x5A, 0x41400100, 0x4, 0x41410100, 0x5F,
0x41414100, 0x22C, 0x41420100, 0x5A, 0x41810000, 0x9C4,
0x41814000, 0x32, 0x4180C000, 0x0, 0x41820000, 0xA};
-
- perform_hint_action(video_encode_metadata.hint_id, resource_values,
- ARRAY_SIZE(resource_values));
- ALOGI("Video Encode hint start");
- return HINT_HANDLED;
+ if (!video_encode_hint_sent) {
+ perform_hint_action(video_encode_metadata.hint_id, resource_values,
+ ARRAY_SIZE(resource_values));
+ video_encode_hint_sent = 1;
+ return HINT_HANDLED;
+ }
}
} else if (video_encode_metadata.state == 0) {
if (is_interactive_governor(governor)) {
undo_hint_action(video_encode_metadata.hint_id);
-
- ALOGI("Video Encode hint stop");
+ video_encode_hint_sent = 0;
return HINT_HANDLED;
}
}