FreeCalypso > hg > fc-tourmaline
view src/g23m-aci/uart/uart_kerf.h @ 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 | fa8dc04885d8 |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : | Modul : +----------------------------------------------------------------------------- | Copyright 2002 Texas Instruments Berlin, AG | All rights reserved. | | This file is confidential and a trade secret of Texas | Instruments Berlin, AG | The receipt of or possession of this file does not convey | any rights to reproduce or disclose its contents or to | manufacture, use, or sell anything it may describe, in | whole, or in part, without the specific written consent of | Texas Instruments Berlin, AG. +----------------------------------------------------------------------------- | Purpose : Definitions for uart_kerf.c +----------------------------------------------------------------------------- */ #ifndef UART_KERF_H #define UART_KERF_H EXTERN void ker_setupUart (void); EXTERN void ker_init (void); EXTERN void ker_analyze_frame_info_command (ULONG* forward, T_desc2* frame); EXTERN void ker_analyze_frame_info_response (ULONG* forward, T_desc2* frame); EXTERN void ker_mux_dlc_release (UBYTE dlc_instance); EXTERN void ker_mux_close_down (void); EXTERN void ker_mux_send_frame (T_desc2* frame); EXTERN void ker_mux_send_command_frame (UBYTE dlc_instance, T_desc2* frame); EXTERN void ker_mux_send_line_states(UBYTE dlc_instance); EXTERN void ker_mux_send_close_down(void); EXTERN void ker_send_disc_frame (UBYTE dlci); EXTERN void ker_receive_sabm_frame(ULONG* forward, T_desc2* frame); EXTERN void ker_receive_ua_frame(ULONG* forward, T_desc2* frame); EXTERN void ker_receive_dm_frame(ULONG* forward, T_desc2* frame); EXTERN void ker_receive_disc_frame(ULONG* forward, T_desc2* frame); EXTERN void ker_receive_uih_control_frame(ULONG* forward, T_desc2* frame); EXTERN void ker_receive_uih_data_frame(ULONG* forward, T_desc2* frame); #endif /* !UART_KERF_H */