summaryrefslogtreecommitdiff
path: root/firmware/powermgmt.c
diff options
context:
space:
mode:
authorThomas Jarosch <tomj@simonv.com>2011-03-08 19:33:30 +0000
committerThomas Jarosch <tomj@simonv.com>2011-03-08 19:33:30 +0000
commit5c73e34d2d81545f59c5c664da3475251a5ac3c6 (patch)
tree3fc1be9423deaaa5e6e97c54fd4eaf0ec878cc33 /firmware/powermgmt.c
parent2ebe370ca1e4b5297cc1240b3b11e15ff168a184 (diff)
Bring idle poweroff to RaaA and the sim
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29543 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/powermgmt.c')
-rw-r--r--firmware/powermgmt.c33
1 files changed, 16 insertions, 17 deletions
diff --git a/firmware/powermgmt.c b/firmware/powermgmt.c
index b1a08bff29..d9014dc047 100644
--- a/firmware/powermgmt.c
+++ b/firmware/powermgmt.c
@@ -81,9 +81,9 @@ enum charge_state_type charge_state = DISCHARGING;
static int shutdown_timeout = 0;
-static void handle_auto_poweroff(void);
+void handle_auto_poweroff(void);
static int poweroff_timeout = 0;
-static long last_event_tick;
+static long last_event_tick = 0;
#if (CONFIG_PLATFORM & PLATFORM_NATIVE)
/*
@@ -134,11 +134,6 @@ void battery_read_info(int *voltage, int *level)
*level = voltage_to_battery_level(millivolts);
}
-void reset_poweroff_timer(void)
-{
- last_event_tick = current_tick;
-}
-
#if BATTERY_TYPES_COUNT > 1
void set_battery_type(int type)
{
@@ -204,11 +199,6 @@ bool battery_level_safe(void)
#endif
}
-void set_poweroff_timeout(int timeout)
-{
- poweroff_timeout = timeout;
-}
-
/* look into the percent_to_volt_* table and get a realistic battery level */
static int voltage_to_percent(int voltage, const short* table)
{
@@ -712,6 +702,16 @@ void shutdown_hw(void)
}
#endif /* PLATFORM_NATIVE */
+void set_poweroff_timeout(int timeout)
+{
+ poweroff_timeout = timeout;
+}
+
+void reset_poweroff_timer(void)
+{
+ last_event_tick = current_tick;
+}
+
void sys_poweroff(void)
{
#ifndef BOOTLOADER
@@ -790,7 +790,7 @@ int get_sleep_timer(void)
return 0;
}
-void handle_sleep_timer(void)
+static void handle_sleep_timer(void)
{
if (!sleeptimer_active)
return;
@@ -817,7 +817,6 @@ void handle_sleep_timer(void)
}
}
-
/*
* We shut off in the following cases:
* 1) The unit is idle, not playing music
@@ -830,7 +829,7 @@ void handle_sleep_timer(void)
* 3) We are recording, or recording with pause
* 4) The radio is playing
*/
-static void handle_auto_poweroff(void)
+void handle_auto_poweroff(void)
{
long timeout = poweroff_timeout*60*HZ;
int audio_stat = audio_status();
@@ -846,7 +845,7 @@ static void handle_auto_poweroff(void)
}
#endif
-#ifndef APPLICATION
+#if !(CONFIG_PLATFORM & PLATFORM_HOSTED)
if (!shutdown_timeout && query_force_shutdown()) {
backlight_on();
sys_poweroff();
@@ -863,7 +862,7 @@ static void handle_auto_poweroff(void)
!sleeptimer_active))) {
if (TIME_AFTER(tick, last_event_tick + timeout)
-#ifndef APPLICATION
+#if !(CONFIG_PLATFORM & PLATFORM_HOSTED)
&& TIME_AFTER(tick, storage_last_disk_activity() + timeout)
#endif
) {