diff options
author | tmk <nobody@nowhere> | 2014-09-20 06:12:49 +0900 |
---|---|---|
committer | tmk <nobody@nowhere> | 2014-09-20 06:12:49 +0900 |
commit | 2015027da325e9f9b602af1f36ceeeebbcd6c78d (patch) | |
tree | 65e9f6606bf256ce260475aff1ea4eb0c3ba901b /keyboard/hhkb_rn42/rn42 | |
parent | d8dd18b4217ce56ee3248e3b09598196e0b6731c (diff) | |
download | qmk_firmware-2015027da325e9f9b602af1f36ceeeebbcd6c78d.tar.gz qmk_firmware-2015027da325e9f9b602af1f36ceeeebbcd6c78d.zip |
Add FET swtich for battery ADC
Diffstat (limited to 'keyboard/hhkb_rn42/rn42')
-rw-r--r-- | keyboard/hhkb_rn42/rn42/battery.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/keyboard/hhkb_rn42/rn42/battery.c b/keyboard/hhkb_rn42/rn42/battery.c index c6988fe336..0320e1baf1 100644 --- a/keyboard/hhkb_rn42/rn42/battery.c +++ b/keyboard/hhkb_rn42/rn42/battery.c @@ -21,6 +21,10 @@ void battery_init(void) ADMUX = (1<<REFS1) | (1<<REFS0); ADCSRA = (1<<ADPS2) | (1<<ADPS1) | (1<<ADPS0); ADCSRA |= (1<<ADEN); + + // ADC disable voltate divider(PF4) + DDRF |= (1<<4); + PORTF &= ~(1<<4); } // Indicator for battery @@ -79,6 +83,10 @@ bool battery_charging(void) // Returns voltage in mV uint16_t battery_voltage(void) { + // ADC disable voltate divider(PF4) + DDRF |= (1<<4); + PORTF |= (1<<4); + volatile uint16_t bat; //ADCSRA |= (1<<ADEN); @@ -98,6 +106,10 @@ uint16_t battery_voltage(void) //ADCSRA &= ~(1<<ADEN); + // ADC disable voltate divider(PF4) + DDRF |= (1<<4); + PORTF &= ~(1<<4); + return (bat - BATTERY_ADC_OFFSET) * BATTERY_ADC_RESOLUTION; } |