mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-07 14:00:57 +00:00
feat(core/prodtest): add pmic control commands
[no changelog]
This commit is contained in:
parent
d531b02ef6
commit
df2fcaab27
@ -220,7 +220,7 @@ program_elf = env.Command(
|
|||||||
target='prodtest.elf',
|
target='prodtest.elf',
|
||||||
source=obj_program,
|
source=obj_program,
|
||||||
action=
|
action=
|
||||||
'$LINK -o $TARGET $CCFLAGS $CFLAGS $LINKFLAGS $SOURCES -lc_nano -lgcc',
|
'$LINK -o $TARGET $CCFLAGS $CFLAGS $LINKFLAGS $SOURCES -lc_nano -lgcc -lm',
|
||||||
)
|
)
|
||||||
|
|
||||||
env.Depends(program_elf, linkerscript_gen)
|
env.Depends(program_elf, linkerscript_gen)
|
||||||
|
@ -77,6 +77,10 @@
|
|||||||
|
|
||||||
#include "memzero.h"
|
#include "memzero.h"
|
||||||
|
|
||||||
|
#ifdef USE_POWERCTL
|
||||||
|
#include "../../sys/powerctl/npm1300/npm1300.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef USE_STORAGE_HWKEY
|
#ifdef USE_STORAGE_HWKEY
|
||||||
#include <sec/secure_aes.h>
|
#include <sec/secure_aes.h>
|
||||||
#endif
|
#endif
|
||||||
@ -848,11 +852,105 @@ void cpuid_read(void) {
|
|||||||
vcp_println_hex((uint8_t *)cpuid, sizeof(cpuid));
|
vcp_println_hex((uint8_t *)cpuid, sizeof(cpuid));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef USE_POWERCTL
|
||||||
|
void test_pmic(const char *args) {
|
||||||
|
if (strcmp(args, "INIT") == 0) {
|
||||||
|
npm1300_deinit();
|
||||||
|
bool ok = npm1300_init();
|
||||||
|
if (ok) {
|
||||||
|
vcp_println("OK");
|
||||||
|
} else {
|
||||||
|
vcp_println("ERROR # I/O error");
|
||||||
|
}
|
||||||
|
} else if (strcmp(args, "CHGSTART") == 0) {
|
||||||
|
bool ok = npm1300_set_charging(true);
|
||||||
|
if (ok) {
|
||||||
|
vcp_println("OK # Charging started with %dmA current limit",
|
||||||
|
npm1300_get_charging_limit());
|
||||||
|
} else {
|
||||||
|
vcp_println("ERROR");
|
||||||
|
}
|
||||||
|
} else if (strcmp(args, "CHGSTOP") == 0) {
|
||||||
|
bool ok = npm1300_set_charging(false);
|
||||||
|
if (ok) {
|
||||||
|
vcp_println("OK # Charging stopped");
|
||||||
|
} else {
|
||||||
|
vcp_println("ERROR # I/O error");
|
||||||
|
}
|
||||||
|
} else if (strncmp(args, "CHGLIMIT", 8) == 0) {
|
||||||
|
int i_charge = atoi(&args[8]);
|
||||||
|
if (i_charge < NPM1300_CHARGING_LIMIT_MIN ||
|
||||||
|
i_charge > NPM1300_CHARGING_LIMIT_MAX) {
|
||||||
|
vcp_println("ERROR # Out of range");
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
bool ok = npm1300_set_charging_limit(i_charge);
|
||||||
|
if (ok) {
|
||||||
|
vcp_println("OK # %dmA current limit", npm1300_get_charging_limit());
|
||||||
|
} else {
|
||||||
|
vcp_println("ERROR # I/O error");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (strncmp(args, "MEASURE", 7) == 0) {
|
||||||
|
int seconds = atoi(&args[7]);
|
||||||
|
uint32_t ticks = hal_ticks_ms();
|
||||||
|
vcp_println(
|
||||||
|
"time; vbat; ibat; ntc_temp; vsys; die_temp; iba_meas_status; mode");
|
||||||
|
do {
|
||||||
|
npm1300_report_t report;
|
||||||
|
bool ok = npm1300_measure_sync(&report);
|
||||||
|
if (!ok) {
|
||||||
|
vcp_println("ERROR # I/O error");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
vcp_print("%09d; ", ticks);
|
||||||
|
vcp_print("%d.%03d; ", (int)report.vbat,
|
||||||
|
(int)(report.vbat * 1000) % 1000);
|
||||||
|
vcp_print("%d.%03d; ", (int)report.ibat,
|
||||||
|
(int)abs(report.ibat * 1000) % 1000);
|
||||||
|
vcp_print("%d.%03d; ", (int)report.ntc_temp,
|
||||||
|
(int)abs(report.ntc_temp * 1000) % 1000);
|
||||||
|
vcp_print("%d.%03d; ", (int)report.vsys,
|
||||||
|
(int)(report.vsys * 1000) % 1000);
|
||||||
|
vcp_print("%d.%03d; ", (int)report.die_temp,
|
||||||
|
(int)abs(report.die_temp * 1000) % 1000);
|
||||||
|
vcp_print("%02X; ", report.ibat_meas_status);
|
||||||
|
|
||||||
|
bool ibat_discharging = ((report.ibat_meas_status >> 2) & 0x03) == 1;
|
||||||
|
bool ibat_charging = ((report.ibat_meas_status >> 2) & 0x03) == 3;
|
||||||
|
|
||||||
|
if (ibat_discharging) {
|
||||||
|
vcp_print("DISCHARGING");
|
||||||
|
} else if (ibat_charging) {
|
||||||
|
vcp_print("CHARGING");
|
||||||
|
} else {
|
||||||
|
vcp_print("IDLE");
|
||||||
|
}
|
||||||
|
|
||||||
|
vcp_println("");
|
||||||
|
|
||||||
|
while (!ticks_expired(ticks + 1000)) {
|
||||||
|
};
|
||||||
|
|
||||||
|
ticks += 1000;
|
||||||
|
|
||||||
|
} while (seconds-- > 0);
|
||||||
|
|
||||||
|
vcp_println("OK # Measurement finished");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif // USE_POWERCTL
|
||||||
|
|
||||||
#define BACKLIGHT_NORMAL 150
|
#define BACKLIGHT_NORMAL 150
|
||||||
|
|
||||||
int main(void) {
|
int main(void) {
|
||||||
system_init(&rsod_panic_handler);
|
system_init(&rsod_panic_handler);
|
||||||
|
|
||||||
|
#ifdef USE_POWERCTL
|
||||||
|
npm1300_init();
|
||||||
|
#endif
|
||||||
|
|
||||||
display_init(DISPLAY_JUMP_BEHAVIOR);
|
display_init(DISPLAY_JUMP_BEHAVIOR);
|
||||||
|
|
||||||
#ifdef USE_STORAGE_HWKEY
|
#ifdef USE_STORAGE_HWKEY
|
||||||
@ -1010,6 +1108,10 @@ int main(void) {
|
|||||||
test_wipe();
|
test_wipe();
|
||||||
} else if (startswith(line, "REBOOT")) {
|
} else if (startswith(line, "REBOOT")) {
|
||||||
test_reboot();
|
test_reboot();
|
||||||
|
#ifdef USE_POWERCTL
|
||||||
|
} else if (startswith(line, "PMIC ")) {
|
||||||
|
test_pmic(line + 5);
|
||||||
|
#endif
|
||||||
} else {
|
} else {
|
||||||
vcp_println("UNKNOWN");
|
vcp_println("UNKNOWN");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user