mirror of
https://github.com/Ralim/IronOS.git
synced 2025-02-26 07:53:55 +00:00
Allow more precise input voltage divider calibration. (#359)
Finer input voltage calibration Settings divisor is stored as uint16_t, not uint8_t. * Allow more precise input voltage divider calibration. The existing code changed the input voltage by multiple tenths of a volt per adjustment, which is way too coarse. This commit simply multiplies the ADC value (and its divisor) by 4, which allows for finer calibration adjustments. Unfortunately, for safety reasons this requires a settings version bump. While old stored divider values can be detected and multiplied by 4 on startup to update them, if the user downgrades firmware it will happily read the new higher value and cause all sorts of problems (which could be either reading higher *or* lower depending on how getInputVoltageX10's parameter wraps around in old firmware due to incorrect type.
This commit is contained in:
committed by
Ben V. Brown
parent
54ec20cd9f
commit
0c7be326e5
@@ -54,7 +54,7 @@ enum TipType {
|
||||
|
||||
uint16_t getHandleTemperature();
|
||||
uint16_t getTipRawTemp(uint8_t instant);
|
||||
uint16_t getInputVoltageX10(uint8_t divisor);
|
||||
uint16_t getInputVoltageX10(uint16_t divisor);
|
||||
uint16_t getTipInstantTemperature();
|
||||
uint8_t getTipPWM();
|
||||
void setTipPWM(uint8_t pulse);
|
||||
|
||||
@@ -83,7 +83,7 @@ void resetSettings() {
|
||||
systemSettings.detailedIDLE = 0;// Detailed idle screen (off for first time users)
|
||||
systemSettings.OrientationMode = 2; //Default to automatic
|
||||
systemSettings.sensitivity = 7; //Default high sensitivity
|
||||
systemSettings.voltageDiv = 117; //Default divider from schematic
|
||||
systemSettings.voltageDiv = 467; //Default divider from schematic
|
||||
systemSettings.ShutdownTime = 10;//How many minutes until the unit turns itself off
|
||||
systemSettings.boostModeEnabled = 1;//Default to safe, with no boost mode
|
||||
systemSettings.BoostTemp = 420; //default to 400C
|
||||
|
||||
@@ -839,10 +839,10 @@ static void settings_setCalibrateVIN(void) {
|
||||
osDelay(40);
|
||||
|
||||
// Cap to sensible values
|
||||
if (systemSettings.voltageDiv < 90) {
|
||||
systemSettings.voltageDiv = 90;
|
||||
} else if (systemSettings.voltageDiv > 130) {
|
||||
systemSettings.voltageDiv = 130;
|
||||
if (systemSettings.voltageDiv < 360) {
|
||||
systemSettings.voltageDiv = 360;
|
||||
} else if (systemSettings.voltageDiv > 520) {
|
||||
systemSettings.voltageDiv = 520;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -131,10 +131,11 @@ uint16_t __attribute__ ((long_call, section (".data.ramfuncs"))) getTipRawTemp(
|
||||
return filterFP >> 9;
|
||||
}
|
||||
}
|
||||
uint16_t getInputVoltageX10(uint8_t divisor) {
|
||||
//ADC maximum is 16384 == 3.3V at input == 28V at VIN
|
||||
uint16_t getInputVoltageX10(uint16_t divisor) {
|
||||
//ADC maximum is 32767 == 3.3V at input == 28.05V at VIN
|
||||
//Therefore we can divide down from there
|
||||
//Ideal term is 117
|
||||
//Multiplying ADC max by 4 for additional calibration options,
|
||||
//ideal term is 467
|
||||
#define BATTFILTERDEPTH 64
|
||||
static uint8_t preFillneeded = 1;
|
||||
static uint32_t samples[BATTFILTERDEPTH];
|
||||
@@ -154,7 +155,7 @@ uint16_t getInputVoltageX10(uint8_t divisor) {
|
||||
sum /= BATTFILTERDEPTH;
|
||||
if (sum < 50)
|
||||
preFillneeded = 1;
|
||||
return sum / divisor;
|
||||
return sum * 4 / divisor;
|
||||
}
|
||||
volatile uint32_t pendingPWM = 0;
|
||||
uint8_t getTipPWM() {
|
||||
|
||||
Reference in New Issue
Block a user