/*************************************************************************** * __________ __ ___. * Open \______ \ ____ ____ | | _\_ |__ _______ ___ * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ * \/ \/ \/ \/ \/ * $Id$ * * Copyright (C) 2002 by Linus Nielsen Feltzing * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY * KIND, either express or implied. * ****************************************************************************/ #include "config.h" #include #include "cpu.h" #include "kernel.h" #include "thread.h" #include "i2c.h" #include "debug.h" #include "rtc.h" #include "usb.h" #include "power.h" #include "system.h" #include "button.h" #include "timer.h" #include "backlight.h" #include "backlight-target.h" static int brightness = 1; /* 1 to 32 */ static int current_dim = 16; /* default after enabling the backlight dimmer */ static bool enabled = false; void _backlight_set_brightness(int val) { int oldlevel; if (current_dim < val) { do { oldlevel = disable_irq_save(); GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_VAL, 0x80); udelay(10); GPIO_SET_BITWISE(GPIOD_OUTPUT_VAL, 0x80); restore_irq(oldlevel); udelay(10); } while (++current_dim < val); } else if (current_dim > val) { do { oldlevel = disable_irq_save(); GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_VAL, 0x80); udelay(200); GPIO_SET_BITWISE(GPIOD_OUTPUT_VAL, 0x80); restore_irq(oldlevel); udelay(10); } while (--current_dim > val); } brightness = val; } void _backlight_hw_enable(bool on) { #ifdef HAVE_LCD_SLEEP if (on) /* If the fade-out is interrupted, enabled will be true, but lcd_awake() needs to be called anyways because the LCD may be sleeping. */ lcd_awake(); #endif if (on == enabled) return; if (on) { GPIO_SET_BITWISE(GPIOB_OUTPUT_VAL, 0x08); GPIO_SET_BITWISE(GPIOD_OUTPUT_VAL, 0x80); sleep(HZ/100); current_dim = 16; _backlight_set_brightness(brightness); } else { GPIO_CLEAR_BITWISE(GPIOD_OUTPUT_VAL, 0x80); GPIO_CLEAR_BITWISE(GPIOB_OUTPUT_VAL, 0x08); sleep(HZ/20); } enabled = on; } /* Switch the backlight on. Works only if the backlight circuit is enabled. * Called in ISR context for fading, so it must be fast. */ void _backlight_led_on(void) { GPIO_SET_BITWISE(GPIOL_OUTPUT_VAL, 0x80); } /* Switch the backlight off. Keeps the backlight circuit enabled. * Called in ISR context for fading, so it must be fast. */ void _backlight_led_off(void) { GPIO_CLEAR_BITWISE(GPIOL_OUTPUT_VAL, 0x80); } bool _backlight_init(void) { GPIO_SET_BITWISE(GPIOB_ENABLE, 0x08); GPIO_SET_BITWISE(GPIOB_OUTPUT_EN, 0x08); GPIO_SET_BITWISE(GPIOD_ENABLE, 0x80); GPIO_SET_BITWISE(GPIOD_OUTPUT_EN, 0x80); _backlight_hw_enable(true); GPIO_SET_BITWISE(GPIOL_ENABLE, 0x80); GPIO_SET_BITWISE(GPIOL_OUTPUT_EN, 0x80); GPIO_SET_BITWISE(GPIOL_OUTPUT_VAL, 0x80); return true; }