summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJens Arnold <amiconn@rockbox.org>2007-08-17 20:47:24 +0000
committerJens Arnold <amiconn@rockbox.org>2007-08-17 20:47:24 +0000
commitbfa1adcd06eca3b64f6d71b2231db88cd86ef902 (patch)
treeee53b3a672aed7305e39e72c151928a83bce4e13
parent98a3789071caac4b7e64f1cc0f5969ecd530cc5c (diff)
downloadrockbox-bfa1adcd06eca3b64f6d71b2231db88cd86ef902.tar.gz
rockbox-bfa1adcd06eca3b64f6d71b2231db88cd86ef902.zip
H300: Read battery voltage with 10bit precision.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@14379 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/target/coldfire/iriver/h300/adc-h300.c13
-rw-r--r--firmware/target/coldfire/iriver/h300/powermgmt-h300.c4
2 files changed, 10 insertions, 7 deletions
diff --git a/firmware/target/coldfire/iriver/h300/adc-h300.c b/firmware/target/coldfire/iriver/h300/adc-h300.c
index 77d7b4689f..b13d0c73cc 100644
--- a/firmware/target/coldfire/iriver/h300/adc-h300.c
+++ b/firmware/target/coldfire/iriver/h300/adc-h300.c
@@ -26,20 +26,23 @@
26 26
27static int adcc2_parms[] = 27static int adcc2_parms[] =
28{ 28{
29 [ADC_BUTTONS] = 0x80 | (5 << 1) | 1, /* ADCIN2 */ 29 [ADC_BUTTONS] = 0x80 | (5 << 1) | 1, /* 8b, ADCIN2 */
30 [ADC_REMOTE] = 0x80 | (6 << 1) | 1, /* ADCIN3 */ 30 [ADC_REMOTE] = 0x80 | (6 << 1) | 1, /* 8b, ADCIN3 */
31 [ADC_BATTERY] = 0x80 | (0 << 1) | 1, /* BATVOLT, resistive divider */ 31 [ADC_BATTERY] = 0x00 | (0 << 1) | 1, /* 10b, BATVOLT, resistive divider */
32 [ADC_REMOTEDETECT] = 0x80 | (2 << 1) | 1, /* ADCIN1, resistive divider */ 32 [ADC_REMOTEDETECT] = 0x80 | (2 << 1) | 1, /* 8b, ADCIN1, resistive divider */
33}; 33};
34 34
35unsigned short adc_scan(int channel) 35unsigned short adc_scan(int channel)
36{ 36{
37 int level = set_irq_level(HIGHEST_IRQ_LEVEL); 37 int level = set_irq_level(HIGHEST_IRQ_LEVEL);
38 unsigned char data; 38 unsigned data;
39 39
40 pcf50606_write(0x2f, adcc2_parms[channel]); 40 pcf50606_write(0x2f, adcc2_parms[channel]);
41 data = pcf50606_read(0x30); 41 data = pcf50606_read(0x30);
42 42
43 if (channel == ADC_BATTERY)
44 data = (data << 2) | (pcf50606_read(0x31) & 0x03);
45
43 set_irq_level(level); 46 set_irq_level(level);
44 return data; 47 return data;
45} 48}
diff --git a/firmware/target/coldfire/iriver/h300/powermgmt-h300.c b/firmware/target/coldfire/iriver/h300/powermgmt-h300.c
index b2d844075e..1bf1de59d9 100644
--- a/firmware/target/coldfire/iriver/h300/powermgmt-h300.c
+++ b/firmware/target/coldfire/iriver/h300/powermgmt-h300.c
@@ -48,11 +48,11 @@ const unsigned short percent_to_volt_charge[11] =
48 48
49/* FIX: this value is picked at random */ 49/* FIX: this value is picked at random */
50#define BATTERY_SCALE_FACTOR 6000 50#define BATTERY_SCALE_FACTOR 6000
51/* full-scale ADC readout (2^8) in millivolt */ 51/* full-scale ADC readout (2^10) in millivolt */
52 52
53/* Returns battery voltage from ADC [millivolts] */ 53/* Returns battery voltage from ADC [millivolts] */
54unsigned int battery_adc_voltage(void) 54unsigned int battery_adc_voltage(void)
55{ 55{
56 return (adc_read(ADC_UNREG_POWER) * BATTERY_SCALE_FACTOR) >> 8; 56 return (adc_read(ADC_UNREG_POWER) * BATTERY_SCALE_FACTOR) >> 10;
57} 57}
58 58