The majority of this commit is by Steve Kondik for the D2, modified by Daniel Bateman and me. Change-Id: Id6c1a1f0c6b39d5d20a765545526c07ad0fc64f6tirimbino
parent
3c938a7e18
commit
5bff9aca16
@ -0,0 +1,27 @@ |
||||
# Copyright (C) 2012 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.
|
||||
|
||||
|
||||
LOCAL_PATH := $(call my-dir)
|
||||
|
||||
# HAL module implemenation stored in
|
||||
# hw/<POWERS_HARDWARE_MODULE_ID>.<ro.hardware>.so
|
||||
include $(CLEAR_VARS) |
||||
|
||||
LOCAL_MODULE_PATH := $(TARGET_OUT_SHARED_LIBRARIES)/hw
|
||||
LOCAL_SHARED_LIBRARIES := liblog libcutils
|
||||
LOCAL_SRC_FILES := power.c
|
||||
LOCAL_MODULE := power.$(TARGET_BOARD_PLATFORM)
|
||||
LOCAL_MODULE_TAGS := optional
|
||||
include $(BUILD_SHARED_LIBRARY) |
@ -0,0 +1,158 @@ |
||||
/*
|
||||
* Copyright (C) 2012 The Android Open Source Project |
||||
* Copyright (C) 2012 The CyanogenMod 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 <errno.h> |
||||
#include <string.h> |
||||
#include <sys/types.h> |
||||
#include <sys/stat.h> |
||||
#include <fcntl.h> |
||||
|
||||
#define LOG_TAG "PowerHAL" |
||||
#include <cutils/properties.h> |
||||
#include <utils/Log.h> |
||||
|
||||
#include <hardware/hardware.h> |
||||
#include <hardware/power.h> |
||||
|
||||
#define BOOSTPULSE_PATH "/sys/devices/system/cpu/cpufreq/ondemand/boostpulse" |
||||
#define SAMPLING_RATE_ONDEMAND "/sys/devices/system/cpu/cpufreq/ondemand/sampling_rate" |
||||
#define SAMPLING_RATE_SCREEN_ON "40000" |
||||
#define SAMPLING_RATE_SCREEN_OFF "400000" |
||||
|
||||
struct s5pc110_power_module { |
||||
struct power_module base; |
||||
pthread_mutex_t lock; |
||||
int boostpulse_fd; |
||||
int boostpulse_warned; |
||||
char sampling_rate_screen_on[PROPERTY_VALUE_MAX]; |
||||
char sampling_rate_screen_off[PROPERTY_VALUE_MAX]; |
||||
}; |
||||
|
||||
static void sysfs_write(char *path, char *s) |
||||
{ |
||||
char buf[80]; |
||||
int len; |
||||
int fd = open(path, O_WRONLY); |
||||
|
||||
if (fd < 0) { |
||||
strerror_r(errno, buf, sizeof(buf)); |
||||
ALOGE("Error opening %s: %s\n", path, buf); |
||||
return; |
||||
} |
||||
|
||||
len = write(fd, s, strlen(s)); |
||||
if (len < 0) { |
||||
strerror_r(errno, buf, sizeof(buf)); |
||||
ALOGE("Error writing to %s: %s\n", path, buf); |
||||
} |
||||
|
||||
close(fd); |
||||
} |
||||
|
||||
static int boostpulse_open(struct s5pc110_power_module *s5pc110) |
||||
{ |
||||
char buf[80]; |
||||
|
||||
pthread_mutex_lock(&s5pc110->lock); |
||||
|
||||
if (s5pc110->boostpulse_fd < 0) { |
||||
s5pc110->boostpulse_fd = open(BOOSTPULSE_PATH, O_WRONLY); |
||||
|
||||
if (s5pc110->boostpulse_fd < 0) { |
||||
if (!s5pc110->boostpulse_warned) { |
||||
strerror_r(errno, buf, sizeof(buf)); |
||||
ALOGE("Error opening %s: %s\n", BOOSTPULSE_PATH, buf); |
||||
s5pc110->boostpulse_warned = 1; |
||||
} |
||||
} |
||||
} |
||||
|
||||
pthread_mutex_unlock(&s5pc110->lock); |
||||
return s5pc110->boostpulse_fd; |
||||
} |
||||
|
||||
static void s5pc110_power_hint(struct power_module *module, power_hint_t hint, |
||||
void *data) |
||||
{ |
||||
struct s5pc110_power_module *s5pc110 = (struct s5pc110_power_module *) module; |
||||
char buf[80]; |
||||
int len; |
||||
int duration = 1; |
||||
|
||||
switch (hint) { |
||||
case POWER_HINT_INTERACTION: |
||||
case POWER_HINT_CPU_BOOST: |
||||
if (boostpulse_open(s5pc110) >= 0) { |
||||
if (data != NULL) |
||||
duration = (int) data; |
||||
|
||||
snprintf(buf, sizeof(buf), "%d", duration); |
||||
len = write(s5pc110->boostpulse_fd, buf, strlen(buf)); |
||||
|
||||
if (len < 0) { |
||||
strerror_r(errno, buf, sizeof(buf)); |
||||
ALOGE("Error writing to %s: %s\n", BOOSTPULSE_PATH, buf); |
||||
} |
||||
} |
||||
break; |
||||
|
||||
case POWER_HINT_VSYNC: |
||||
break; |
||||
|
||||
default: |
||||
break; |
||||
} |
||||
} |
||||
|
||||
static void s5pc110_power_set_interactive(struct power_module *module, int on) |
||||
{ |
||||
struct s5pc110_power_module *s5pc110 = (struct s5pc110_power_module *) module; |
||||
sysfs_write(SAMPLING_RATE_ONDEMAND, |
||||
on ? s5pc110->sampling_rate_screen_on : s5pc110->sampling_rate_screen_off); |
||||
} |
||||
|
||||
static void s5pc110_power_init(struct power_module *module) |
||||
{ |
||||
struct s5pc110_power_module *s5pc110 = (struct s5pc110_power_module *) module; |
||||
property_get("ro.sys.sampling_rate_on", s5pc110->sampling_rate_screen_on, SAMPLING_RATE_SCREEN_ON); |
||||
property_get("ro.sys.sampling_rate_off", s5pc110->sampling_rate_screen_off, SAMPLING_RATE_SCREEN_OFF); |
||||
sysfs_write(SAMPLING_RATE_ONDEMAND, s5pc110->sampling_rate_screen_on); |
||||
} |
||||
|
||||
static struct hw_module_methods_t power_module_methods = { |
||||
.open = NULL, |
||||
}; |
||||
|
||||
struct s5pc110_power_module HAL_MODULE_INFO_SYM = { |
||||
base: { |
||||
common: { |
||||
tag: HARDWARE_MODULE_TAG, |
||||
module_api_version: POWER_MODULE_API_VERSION_0_2, |
||||
hal_api_version: HARDWARE_HAL_API_VERSION, |
||||
id: POWER_HARDWARE_MODULE_ID, |
||||
name: "S5PC110 Power HAL", |
||||
author: "The Android Open Source Project", |
||||
methods: &power_module_methods, |
||||
}, |
||||
init: s5pc110_power_init, |
||||
setInteractive: s5pc110_power_set_interactive, |
||||
powerHint: s5pc110_power_hint, |
||||
}, |
||||
|
||||
lock: PTHREAD_MUTEX_INITIALIZER, |
||||
boostpulse_fd: -1, |
||||
boostpulse_warned: 0, |
||||
}; |
Loading…
Reference in new issue