FreeCalypso > hg > fc-tourmaline
view src/cs/drivers/drv_app/fchg/fchg_api.h @ 268:f2e52cab0a73
abb_inth.c: check all interrupt causes, not just one
The original code used if - else if - else if etc constructs, thus
the first detected interrupt was the only one handled. However,
Iota ITSTATREG is a clear-on-read register, thus if we only handle
the first detected interrupt and skip checking the others, then the
other interrupts will be lost, if more than one interrupt happened
to occur in one ABB interrupt handling cycle - a form of rare race
condition. Change the code to check all interrupts that were read
in this cycle.
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Sun, 13 Jun 2021 18:17:53 +0000 |
| parents | 09ea37852fd6 |
| children |
line wrap: on
line source
/* * This header file defines the external API of the FCHG SWE, * callable from other tasks such as UI or AT commands. */ #ifndef __FCHG_API_H #define __FCHG_API_H #include "rv/rv_general.h" #include "fchg/fchg_common.h" enum fchg_user_charge_ctrl { FCHG_CHARGE_STOP = 0, FCHG_CHARGE_START = 1 }; #define FCHG_BATT_BARS_CHARGING 0xFF struct fchg_user_state { enum fchg_state chg_state; UINT16 batt_mv; T_PWR_PERCENT batt_percent; UINT8 batt_bars; UINT16 ichg; }; T_RV_RET fchg_user_charge_control(enum fchg_user_charge_ctrl); T_RV_RET fchg_get_current_state(struct fchg_user_state *); T_RV_RET fchg_register_event_handler(T_FCHG_EVENT_HANDLER); UINT16 fchg_convert_ichg_to_mA(UINT16 ichg); #endif /* include guard */
