FreeCalypso > hg > fc-tourmaline
view src/gpf/osl/os_drv.c @ 261:841a848ba762
SPI SWE: clear any pending boot-time interrupts in spi_init()
Charger plug/unplug hw logic in the Iota ABB has no built-in debouncing,
thus electrical contact bounce on the charging power connection interface
produces a lot of charger plug/unplug interrupts. When we boot in
charging mode (charging power present at boot time and is presumably
the cause of Switch-ON), some bounce may occur between the initial
Iota Switch-ON action and Calypso firmware booting. By clearing any
accumulated ITSTATREG interrupts on boot, we prevent these pre-boot
interrupts from generating charger plug/unplug events to FCHG, which
would upset smooth from-boot charging.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 14 May 2021 02:49:05 +0000 |
parents | 4e78acac3d88 |
children |
line wrap: on
line source
/* * This C module is a reconstruction based on the disassembly of * os_drv.obj in frame_na7_db_fl.lib from the Leonardo package. */ /* set of included headers from COFF symtab: */ #include "nucleus.h" #include "typedefs.h" #include "gdi.h" #include "os.h" typedef unsigned char u_char; extern OS_HANDLE os_ext_pool_handle; static u_char *HISR_Stack; static T_DRV_SIGNAL *SignalID; static void (*DrvCallback)(T_DRV_SIGNAL *); static NU_HISR CallBack_HISR; #define CB_HISR_STACK_SIZE 1024 GLOBAL LONG os_ExecuteCallback(OS_HANDLE Caller, void (*Callback)(T_DRV_SIGNAL *), T_DRV_SIGNAL *Signal) { DrvCallback = Callback; SignalID = Signal; NU_Activate_HISR(&CallBack_HISR); return(OS_OK); } static void CallbackFunc(void) { DrvCallback(SignalID); } GLOBAL LONG os_CreateCallback(void) { if (os_AllocateMemory(OS_NOTASK, (T_VOID_STRUCT **) &HISR_Stack, CB_HISR_STACK_SIZE, 0xFFFFFFFF, os_ext_pool_handle) == OS_ERROR) return(OS_ERROR); if (NU_Create_HISR(&CallBack_HISR, "CB_HISR", CallbackFunc, 2, HISR_Stack, CB_HISR_STACK_SIZE) == NU_SUCCESS) return(OS_OK); else return(OS_ERROR); }