summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Arigo <markarigo@gmail.com>2009-03-07 04:41:37 +0000
committerMark Arigo <markarigo@gmail.com>2009-03-07 04:41:37 +0000
commitda1ca5177fd1606fe494939e120c5731b4bb5d3f (patch)
tree63d77425f61fe05e12c52a3413dca2d0572bd485
parenta88d5f045f054347a33320a417177f71bb2c3a91 (diff)
downloadrockbox-da1ca5177fd1606fe494939e120c5731b4bb5d3f.tar.gz
rockbox-da1ca5177fd1606fe494939e120c5731b4bb5d3f.zip
Make Philips SA9200 build again
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@20226 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/SOURCES9
-rwxr-xr-xfirmware/export/config-sa9200.h10
-rw-r--r--firmware/target/arm/philips/sa9200/powermgmt-sa9200.c11
-rw-r--r--firmware/target/arm/philips/sa9200/powermgmt-target.h48
4 files changed, 61 insertions, 17 deletions
diff --git a/firmware/SOURCES b/firmware/SOURCES
index 0b6bb155b0..1ee2979f22 100644
--- a/firmware/SOURCES
+++ b/firmware/SOURCES
@@ -534,16 +534,17 @@ target/arm/sandisk/audio-c200_e200.c
534 534
535#ifdef PHILIPS_SA9200 535#ifdef PHILIPS_SA9200
536#ifndef SIMULATOR 536#ifndef SIMULATOR
537target/arm/ata-sd-pp.c
538target/arm/philips/sa9200/lcd-sa9200.c
539target/arm/adc-as3514.c 537target/arm/adc-as3514.c
540target/arm/ascodec-pp.c 538target/arm/ascodec-pp.c
541target/arm/philips/sa9200/backlight-sa9200.c 539target/arm/ata-sd-pp.c
540target/arm/i2s-pp.c
541target/arm/powermgmt-ascodec.c
542target/arm/usb-fw-pp502x.c 542target/arm/usb-fw-pp502x.c
543target/arm/philips/sa9200/backlight-sa9200.c
543target/arm/philips/sa9200/button-sa9200.c 544target/arm/philips/sa9200/button-sa9200.c
545target/arm/philips/sa9200/lcd-sa9200.c
544target/arm/philips/sa9200/power-sa9200.c 546target/arm/philips/sa9200/power-sa9200.c
545target/arm/philips/sa9200/powermgmt-sa9200.c 547target/arm/philips/sa9200/powermgmt-sa9200.c
546target/arm/i2s-pp.c
547#endif /* SIMULATOR */ 548#endif /* SIMULATOR */
548#endif /* PHILIPS_SA9200 */ 549#endif /* PHILIPS_SA9200 */
549 550
diff --git a/firmware/export/config-sa9200.h b/firmware/export/config-sa9200.h
index 3008360414..cbe92bb99c 100755
--- a/firmware/export/config-sa9200.h
+++ b/firmware/export/config-sa9200.h
@@ -105,8 +105,14 @@
105#define BATTERY_CAPACITY_INC 0 /* capacity increment */ 105#define BATTERY_CAPACITY_INC 0 /* capacity increment */
106#define BATTERY_TYPES_COUNT 1 /* only one type */ 106#define BATTERY_TYPES_COUNT 1 /* only one type */
107 107
108/* Hardware controlled charging? FIXME */ 108/* Charging implemented in a target-specific algorithm */
109#define CONFIG_CHARGING CHARGING_SIMPLE 109#define CONFIG_CHARGING CHARGING_TARGET
110#define HAVE_POWEROFF_WHILE_CHARGING
111
112/* define current usage levels (copied from the e200v1 )*/
113#define CURRENT_NORMAL 30 /* Toni's measurements in Nov 2008 */
114#define CURRENT_BACKLIGHT 40 /* Screen is about 20, blue LEDs are another 20, so 40 if both */
115#define CURRENT_RECORD 30 /* flash player, so this is just unboosted current*/
110 116
111/* define this if the unit can be powered or charged via USB */ 117/* define this if the unit can be powered or charged via USB */
112#define HAVE_USB_POWER 118#define HAVE_USB_POWER
diff --git a/firmware/target/arm/philips/sa9200/powermgmt-sa9200.c b/firmware/target/arm/philips/sa9200/powermgmt-sa9200.c
index 43f37463f8..144ca37ebf 100644
--- a/firmware/target/arm/philips/sa9200/powermgmt-sa9200.c
+++ b/firmware/target/arm/philips/sa9200/powermgmt-sa9200.c
@@ -47,14 +47,3 @@ const unsigned short percent_to_volt_charge[11] =
47 /* Sansa Li Ion 750mAH FIXME */ 47 /* Sansa Li Ion 750mAH FIXME */
48 3300, 3680, 3740, 3760, 3780, 3810, 3870, 3930, 3970, 4070, 4160 48 3300, 3680, 3740, 3760, 3780, 3810, 3870, 3930, 3970, 4070, 4160
49}; 49};
50
51/* ADC should read 0x3ff=5.12V */
52#define BATTERY_SCALE_FACTOR 5125
53/* full-scale ADC readout (2^10) in millivolt */
54
55/* Returns battery voltage from ADC [millivolts] */
56unsigned int battery_adc_voltage(void)
57{
58 return (adc_read(ADC_UNREG_POWER) * BATTERY_SCALE_FACTOR) >> 10;
59}
60
diff --git a/firmware/target/arm/philips/sa9200/powermgmt-target.h b/firmware/target/arm/philips/sa9200/powermgmt-target.h
new file mode 100644
index 0000000000..4400cda5d1
--- /dev/null
+++ b/firmware/target/arm/philips/sa9200/powermgmt-target.h
@@ -0,0 +1,48 @@
1/***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
9 *
10 * Copyright (C) 2009 by Michael Sevakis
11 * Copyright (C) 2008 by Bertrik Sikken
12 *
13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU General Public License
15 * as published by the Free Software Foundation; either version 2
16 * of the License, or (at your option) any later version.
17 *
18 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
19 * KIND, either express or implied.
20 *
21 ****************************************************************************/
22#ifndef POWERMGMT_TARGET_H
23#define POWERMGMT_TARGET_H
24
25/* NOTE: these values are copied from the Sansa e200v1 */
26
27/* PREFERRED - Check if topped-off and monitor voltage while plugged. */
28#define BATT_FULL_VOLTAGE 4160
29#define BATT_VAUTO_RECHARGE 4100
30#define BATT_CHG_V CHG_V_4_20V
31#define BATT_CHG_I CHG_I_300MA
32#define CHARGER_TOTAL_TIMER (4*3600*2) /* 4 hours enough? */
33/* On e200 ADC_RTCSUP seems to represent battery voltage better than
34 * ADC_BVDD during charging (ADC_BVDD is way too high) and appears the
35 * same in normal use.
36 */
37#define ADC_BATTERY ADC_RTCSUP
38
39void powermgmt_init_target(void);
40void charging_algorithm_step(void);
41void charging_algorithm_close(void);
42
43/* We want to be able to reset the averaging filter */
44#define HAVE_RESET_BATTERY_FILTER
45
46#define BATT_AVE_SAMPLES 32
47
48#endif /* POWERMGMT_TARGET_H */