Update PD debug to be EPR aware
This commit is contained in:
@@ -42,7 +42,7 @@ void showWarnings();
|
|||||||
#define BUTTON_INACTIVITY_TIME (60 * configTICK_RATE_HZ)
|
#define BUTTON_INACTIVITY_TIME (60 * configTICK_RATE_HZ)
|
||||||
static TickType_t lastHallEffectSleepStart = 0;
|
static TickType_t lastHallEffectSleepStart = 0;
|
||||||
static uint16_t min(uint16_t a, uint16_t b) {
|
static uint16_t min(uint16_t a, uint16_t b) {
|
||||||
if (a > b)
|
if (a > b)
|
||||||
return b;
|
return b;
|
||||||
else
|
else
|
||||||
return a;
|
return a;
|
||||||
@@ -840,35 +840,50 @@ static void showPDDebug(void) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Print out the Proposed power options one by one
|
// Print out the Proposed power options one by one
|
||||||
auto lastCaps = USBPowerDelivery::getLastSeenCapabilities();
|
auto lastCaps = USBPowerDelivery::getLastSeenCapabilities();
|
||||||
uint8_t numobj = PD_NUMOBJ_GET(lastCaps);
|
if ((screen - 1) < 11) {
|
||||||
if ((screen - 1) < numobj) {
|
|
||||||
int voltage_mv = 0;
|
int voltage_mv = 0;
|
||||||
int min_voltage = 0;
|
int min_voltage = 0;
|
||||||
int current_a_x100 = 0;
|
int current_a_x100 = 0;
|
||||||
if ((lastCaps->obj[screen - 1] & PD_PDO_TYPE) == PD_PDO_TYPE_FIXED) {
|
int wattage = 0;
|
||||||
voltage_mv = PD_PDV2MV(PD_PDO_SRC_FIXED_VOLTAGE_GET(lastCaps->obj[screen - 1])); // voltage in mV units
|
|
||||||
current_a_x100 = PD_PDO_SRC_FIXED_CURRENT_GET(lastCaps->obj[screen - 1]); // current in 10mA units
|
|
||||||
} else {
|
|
||||||
voltage_mv = PD_PAV2MV(PD_APDO_PPS_MAX_VOLTAGE_GET(lastCaps->obj[screen - 1]));
|
|
||||||
min_voltage = PD_PAV2MV(PD_APDO_PPS_MIN_VOLTAGE_GET(lastCaps->obj[screen - 1]));
|
|
||||||
current_a_x100 = PD_PAI2CA(PD_APDO_PPS_CURRENT_GET(lastCaps->obj[screen - 1])); // max current in 10mA units
|
|
||||||
}
|
|
||||||
// print out this entry of the proposal
|
|
||||||
OLED::printNumber(screen, 1, FontStyle::SMALL, true); // print the entry number
|
|
||||||
OLED::print(SymbolSpace, FontStyle::SMALL);
|
|
||||||
if (min_voltage > 0) {
|
|
||||||
OLED::printNumber(min_voltage / 1000, 2, FontStyle::SMALL, true); // print the voltage
|
|
||||||
OLED::print(SymbolMinus, FontStyle::SMALL);
|
|
||||||
}
|
|
||||||
OLED::printNumber(voltage_mv / 1000, 2, FontStyle::SMALL, true); // print the voltage
|
|
||||||
OLED::print(SymbolVolts, FontStyle::SMALL);
|
|
||||||
OLED::print(SymbolSpace, FontStyle::SMALL);
|
|
||||||
OLED::printNumber(current_a_x100 / 100, 2, FontStyle::SMALL, true); // print the current in 0.1A res
|
|
||||||
OLED::print(SymbolDot, FontStyle::SMALL);
|
|
||||||
OLED::printNumber(current_a_x100 % 100, 2, FontStyle::SMALL, true); // print the current in 0.1A res
|
|
||||||
OLED::print(SymbolAmps, FontStyle::SMALL);
|
|
||||||
|
|
||||||
|
if ((lastCaps[screen - 1] & PD_PDO_TYPE) == PD_PDO_TYPE_FIXED) {
|
||||||
|
voltage_mv = PD_PDV2MV(PD_PDO_SRC_FIXED_VOLTAGE_GET(lastCaps[screen - 1])); // voltage in mV units
|
||||||
|
current_a_x100 = PD_PDO_SRC_FIXED_CURRENT_GET(lastCaps[screen - 1]); // current in 10mA units
|
||||||
|
} else if ((lastCaps[screen - 1] & PD_PDO_TYPE) == PD_PDO_TYPE_AUGMENTED) {
|
||||||
|
voltage_mv = PD_PAV2MV(PD_APDO_AVS_MAX_VOLTAGE_GET(lastCaps[screen - 1]));
|
||||||
|
min_voltage = PD_PAV2MV(PD_APDO_PPS_MIN_VOLTAGE_GET(lastCaps[screen - 1]));
|
||||||
|
// Last value is wattage
|
||||||
|
wattage = PD_APDO_AVS_MAX_POWER_GET(lastCaps[screen - 1]);
|
||||||
|
} else {
|
||||||
|
voltage_mv = PD_PAV2MV(PD_APDO_PPS_MAX_VOLTAGE_GET(lastCaps[screen - 1]));
|
||||||
|
min_voltage = PD_PAV2MV(PD_APDO_PPS_MIN_VOLTAGE_GET(lastCaps[screen - 1]));
|
||||||
|
current_a_x100 = PD_PAI2CA(PD_APDO_PPS_CURRENT_GET(lastCaps[screen - 1])); // max current in 10mA units
|
||||||
|
}
|
||||||
|
// Skip not used entries
|
||||||
|
if (voltage_mv == 0) {
|
||||||
|
screen++;
|
||||||
|
} else {
|
||||||
|
// print out this entry of the proposal
|
||||||
|
OLED::printNumber(screen, 2, FontStyle::SMALL, true); // print the entry number
|
||||||
|
OLED::print(SymbolSpace, FontStyle::SMALL);
|
||||||
|
if (min_voltage > 0) {
|
||||||
|
OLED::printNumber(min_voltage / 1000, 2, FontStyle::SMALL, true); // print the voltage
|
||||||
|
OLED::print(SymbolMinus, FontStyle::SMALL);
|
||||||
|
}
|
||||||
|
OLED::printNumber(voltage_mv / 1000, 2, FontStyle::SMALL, true); // print the voltage
|
||||||
|
OLED::print(SymbolVolts, FontStyle::SMALL);
|
||||||
|
OLED::print(SymbolSpace, FontStyle::SMALL);
|
||||||
|
if (wattage) {
|
||||||
|
OLED::printNumber(wattage, 3, FontStyle::SMALL, true); // print the current in 0.1A res
|
||||||
|
OLED::print(SymbolWatts, FontStyle::SMALL);
|
||||||
|
} else {
|
||||||
|
OLED::printNumber(current_a_x100 / 100, 2, FontStyle::SMALL, true); // print the current in 0.1A res
|
||||||
|
OLED::print(SymbolDot, FontStyle::SMALL);
|
||||||
|
OLED::printNumber(current_a_x100 % 100, 2, FontStyle::SMALL, true); // print the current in 0.1A res
|
||||||
|
OLED::print(SymbolAmps, FontStyle::SMALL);
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
screen = 0;
|
screen = 0;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user