diff options
author | Thomas Martitz <kugel@rockbox.org> | 2012-01-03 23:44:38 +0000 |
---|---|---|
committer | Thomas Martitz <kugel@rockbox.org> | 2012-01-03 23:44:38 +0000 |
commit | c1bd9b0361ba92c29ceef68d74093e70a1a3e481 (patch) | |
tree | 1a42acdf2099b7f5ac06eee11e1d488b388c6d9f /firmware/export/powermgmt.h | |
parent | 949e6398c89e3c277a4c542f67a5ee788c6f642d (diff) | |
download | rockbox-c1bd9b0361ba92c29ceef68d74093e70a1a3e481.tar.gz rockbox-c1bd9b0361ba92c29ceef68d74093e70a1a3e481.zip |
Rework powermgmt to enable code re-use on appliation and sims.
* Introduce CONFIG_BATTERY_MEASURE define, to allow targets (application)
to break powermgmt.c's assumption about the ability to read battery voltage.
There's now additionally percentage (android) and remaining time measure
(maemo). No measure at all also works (sdl app). If voltage can't be measured,
then battery_level() is king and it'll be used for power_history and runtime
estimation.
* Implement target's API in the simulator, i.e. _battery_voltage(), so it
doesn't need to implement it's own powermgmt.c and other stubs. Now
the sim behaves much more like a native target, although it still
changes the simulated battery voltage quickly,
* Other changes include include renaming battery_adc_voltage() to
_battery_voltage(), for consistency with the new target functions and
making some of the apps code aware that voltage and runtime estimation
is not always available.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@31548 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/export/powermgmt.h')
-rw-r--r-- | firmware/export/powermgmt.h | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/firmware/export/powermgmt.h b/firmware/export/powermgmt.h index 837767f56b..9e9d3d0fd8 100644 --- a/firmware/export/powermgmt.h +++ b/firmware/export/powermgmt.h | |||
@@ -78,8 +78,6 @@ extern unsigned int power_thread_inputs; | |||
78 | /* Start up power management thread */ | 78 | /* Start up power management thread */ |
79 | void powermgmt_init(void) INIT_ATTR; | 79 | void powermgmt_init(void) INIT_ATTR; |
80 | 80 | ||
81 | #if (CONFIG_PLATFORM & PLATFORM_NATIVE) || defined(SAMSUNG_YPR0) | ||
82 | |||
83 | /* Generic current values that are intentionally meaningless - config header | 81 | /* Generic current values that are intentionally meaningless - config header |
84 | * should define proper numbers.*/ | 82 | * should define proper numbers.*/ |
85 | 83 | ||
@@ -130,13 +128,18 @@ extern const unsigned short percent_to_volt_discharge[BATTERY_TYPES_COUNT][11]; | |||
130 | extern const unsigned short percent_to_volt_charge[11]; | 128 | extern const unsigned short percent_to_volt_charge[11]; |
131 | #endif | 129 | #endif |
132 | 130 | ||
133 | #endif /* PLATFORM_NATIVE */ | 131 | /* Returns battery status, filtered for runtime estimation */ |
134 | |||
135 | /* Returns battery statust */ | ||
136 | int battery_level(void); /* percent */ | 132 | int battery_level(void); /* percent */ |
137 | int battery_time(void); /* minutes */ | 133 | int battery_time(void); /* minutes */ |
138 | unsigned int battery_adc_voltage(void); /* voltage from ADC in millivolts */ | 134 | int battery_voltage(void); /* filtered batt. voltage in millivolts */ |
139 | unsigned int battery_voltage(void); /* filtered batt. voltage in millivolts */ | 135 | |
136 | /* Implemented by the target, unfiltered */ | ||
137 | int _battery_level(void); /* percent */ | ||
138 | int _battery_time(void); /* minutes */ | ||
139 | int _battery_voltage(void); /* voltage in millivolts */ | ||
140 | #if CONFIG_CHARGING >= CHARGING_TARGET | ||
141 | void powermgmt_init_target(void); | ||
142 | #endif | ||
140 | 143 | ||
141 | #ifdef HAVE_BATTERY_SWITCH | 144 | #ifdef HAVE_BATTERY_SWITCH |
142 | unsigned int input_millivolts(void); /* voltage that device is running from */ | 145 | unsigned int input_millivolts(void); /* voltage that device is running from */ |