FreeCalypso > hg > fc-magnetite
view src/aci2/aci/dcm_state.h @ 635:baa0a02bc676
niq32.c DTR handling restored for targets that have it
TI's original TCS211 fw treated GPIO 3 as the DTR input (wired so on C-Sample
and D-Sample boards, also compatible with Leonardo and FCDEV3B which have a
fixed pull-down resistor on this GPIO line), and the code in niq32.c called
UAF_DTRInterruptHandler() (implemented in uartfax.c) from the
IQ_KeypadGPIOHandler() function. But on Openmoko's GTA02 with their official
fw this GPIO is a floating input, all of the DTR handling code in uartfax.c
including the interrupt logic is still there, but the hobbled TCS211-20070608
semi-src delivery which OM got from TI contained a change in niq32.c (which
had been kept in FC until now) that removed the call to
UAF_DTRInterruptHandler() as part of those not-quite-understood "CC test"
hacks.
The present change fixes this bug at a long last: if we are building fw for a
target that has TI's "classic" DTR & DCD GPIO arrangement (dsample, fcmodem and
gtm900), we bring back all of TI's original code in both uartfax.c and niq32.c,
whereas if we are building fw for a target that does not use this classic GPIO
arrangement, the code in niq32.c goes back to what we got from OM and all
DTR & DCD code in uartfax.c is conditioned out. This change also removes the
very last remaining bit of "CC test" bogosity from our FreeCalypso code base.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 19 Jan 2020 01:41:35 +0000 |
parents | 93999a60b835 |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : GSM-F&D (8411) | Modul : ACI +----------------------------------------------------------------------------- | 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. +----------------------------------------------------------------------------- | Description : DCM instance is a state machine with several possible states. | Based on the current state, DCM handle different kind of messages/events. | States are listed in the order they should normally be sequenced. +----------------------------------------------------------------------------- */ #ifndef __DCMSTATE_H__ #define __DCMSTATE_H__ /** * DCM states. * * DCM instance is a state machine with several possible states. * Based on the current state, DCM handle different kind of messages/events. * States are listed in the order they should normally be sequenced. * * See the Readme file for a description of the state machine. */ typedef enum { DCM_OFF, DCM_IDLE, DCM_ACTIVATING_CONN, DCM_CONN_ACTIVATED, DCM_CLOSING_CONN } T_DCM_INTERNAL_STATE; /** * DCM substates. * * DCM instance is a state machine with several possible states. * Substates are included in some states. */ typedef enum { DCM_SUB_NO_ACTION = 0, /* ALL */ DCM_SUB_WAIT_CGATT_CNF, /* DCM_ACTIVATING_CONN */ DCM_SUB_WAIT_CGACT_CNF, /* DCM_ACTIVATING_CONN */ DCM_SUB_WAIT_SATDN_CNF, /* DCM_ACTIVATING_CONN */ DCM_SUB_WAIT_SATH_CNF, /* DCM_CLOSING_CONN */ DCM_SUB_WAIT_CGDEATT_CNF, /* DCM_CLOSING_CONN */ DCM_SUB_WAIT_CGDEACT_CNF /* DCM_CLOSING_CONN */ } T_DCM_INTERNAL_SUBSTATE; T_DCM_RET dcm_idle (T_DCM_HDR * msg_p); T_DCM_RET dcm_activating_conn(T_DCM_HDR * msg_p); T_DCM_RET dcm_conn_activated(T_DCM_HDR * msg_p); T_DCM_RET dcm_closing_conn(T_DCM_HDR * msg_p ); T_DCM_RET dcm_new_state(U8 state, U8 substate); T_DCM_RET dcm_save_state(void); T_DCM_RET dcm_restore_state(void); void dcm_dispay_state(U8 state, U8 substate); void dcm_dispay_sub_state(U8 substate_1, U8 substate_2); #endif