From 86d0895f82ca01b07da6e0d1e5e37d26f5114333 Mon Sep 17 00:00:00 2001 From: XpLoDWilD Date: Sat, 7 Jul 2012 22:58:23 +0200 Subject: [PATCH] liblights: Fix reading of previous brightness value Change-Id: Ie175521033b3a8d96197794cff1a2dce89e516c3 --- exynos4/exynos4x12/liblights/lights.c | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/exynos4/exynos4x12/liblights/lights.c b/exynos4/exynos4x12/liblights/lights.c index e8336d2..2e5c029 100644 --- a/exynos4/exynos4x12/liblights/lights.c +++ b/exynos4/exynos4x12/liblights/lights.c @@ -89,6 +89,21 @@ static int write_int(char const *path, int value) } } +static int read_int(char const *path) +{ + int fd; + char buffer[2]; + + fd = open(path, O_RDONLY); + + if (fd >= 0) { + read(fd, buffer, 1); + } + close(fd); + + return atoi(buffer); +} + static int write_str(char const *path, const char* value) { int fd; @@ -126,14 +141,14 @@ static int set_light_backlight(struct light_device_t *dev, struct light_state_t const *state) { int err = 0; - static int s_previous_brightness = -1; int brightness = rgb_to_brightness(state); + int previous_brightness = read_int(PANEL_FILE); pthread_mutex_lock(&g_lock); + err = write_int(PANEL_FILE, brightness); - if (!s_previous_brightness && (brightness > 0)) { + if (!previous_brightness && (brightness > 0)) { err = write_int(BUTTON_FILE, brightness > 0 ? 1 : 2); - s_previous_brightness = brightness; } pthread_mutex_unlock(&g_lock); -- 2.20.1