view src/g23m-aci/aci/wap_aci.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 53929b40109c
children
line wrap: on
line source

/*
+-----------------------------------------------------------------------------
|  Project :  GSM-F&D (8411)
|  Modul   :  WAP
+-----------------------------------------------------------------------------
|  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 the WAP module
+-----------------------------------------------------------------------------
*/

#ifndef WAP_ACI_H
#define WAP_ACI_H

/*==== TYPES ======================================================*/

typedef enum
{
  Wap_Not_Init = -1 ,
#ifdef FF_GPF_TCPIP
  TCPIP_Initialization,
  TCPIP_Initialized,
  TCPIP_Activation ,
  TCPIP_Activated ,
#endif /*FF_GPF_TCPIP*/
  UDPA_Activation ,
  UDPA_Activated ,
  IPA_Activation ,
  IPA_Activated ,
  IPA_Configuration ,
  IPA_Configurated ,
  UDPA_Configuration  ,
  UDPA_Configurated ,
#ifdef FF_GPF_TCPIP
  TCPIP_Configuration ,
  TCPIP_Configurated  ,
#endif /*FF_GPF_TCPIP*/
  IPA_Deconfiguration,
  IPA_Deconfigurated,
  UDPA_Deconfiguration,
  UPDA_Deconfigurated,
#ifdef FF_GPF_TCPIP
  TCPIP_Deconfiguration,
  TCPIP_Deconfigurated,
  TCPIP_Deactivation,
  TCPIP_Deactivated,
#endif /*FF_GPF_TCPIP*/
  UDPA_Deactivation,
  UDPA_Deactivated,
  IPA_Deactivation,
  IPA_Deactivated
} T_ACI_WAP_STATES;


/*
 *  Indicate is IP connected or disconnected
 */

typedef enum
{
  IPA_CONN,
  IPA_DSC
}
T_ACI_IPA_DIRC;


/*==== EXPORT =====================================================*/

/*
 *  Prototypes for IP and UDP.
 */

EXTERN void psaIPA_Config ( ULONG ip, USHORT max_trans_unit, T_ACI_IPA_DIRC dirc );
EXTERN void psaUDPA_Config ( UBYTE dirc );

EXTERN T_ACI_RETURN cmhIPA_Configurated ( void );
EXTERN T_ACI_RETURN cmhIPA_Deconfigurated ( void );

EXTERN T_ACI_RETURN cmhUDPA_Activate ( T_ACI_CMD_SRC srcId, SHORT cId );
EXTERN T_ACI_RETURN cmhUDPA_Configurated ( void );
EXTERN T_ACI_RETURN cmhUDPA_Deconfigurated ( void );
EXTERN T_ACI_RETURN cmhUDPA_Deactivate ( UBYTE src_id );

EXTERN T_ACI_RETURN cmhTCPIP_Activate ( T_ACI_CMD_SRC srcId, SHORT cId );
EXTERN T_ACI_RETURN cmhTCPIP_Configurated ( void );
EXTERN T_ACI_RETURN cmhTCPIP_Deconfigurated ( void );
EXTERN T_ACI_RETURN cmhTCPIP_Deactivate ( UBYTE src_id );

EXTERN void psaIPA_Dti_Req(ULONG dti_id, UBYTE peer_to_connect_to, UBYTE dti_conn);
EXTERN void psaUDPA_Dti_Req(ULONG dti_id, UBYTE peer_to_connect_to, UBYTE dti_conn);
EXTERN void psaWAP_Dti_Req(ULONG dti_id, UBYTE peer_to_connect_to, UBYTE dti_conn);


/*
 *  Variables for WAP, state, id and CALL
 */

#ifdef PSA_PPPP_C
GLOBAL T_ACI_WAP_STATES wap_state  = Wap_Not_Init;
GLOBAL SHORT            wapId      = NO_ENTRY;
GLOBAL BOOL             Wap_Call   = FALSE;
GLOBAL UBYTE            wap_dti_id = DTI_DTI_ID_NOTPRESENT;
GLOBAL ULONG            peer_link_id  = DTI_LINK_ID_NOTPRESENT;
GLOBAL ULONG            prot_link_id = DTI_LINK_ID_NOTPRESENT;
GLOBAL UBYTE            peer_entity_id = DTI_ENTITY_MAX;
GLOBAL UBYTE            prot_entity_id = DTI_ENTITY_MAX;

#else

EXTERN T_ACI_WAP_STATES wap_state;
EXTERN SHORT            wapId;
EXTERN BOOL             Wap_Call;
EXTERN UBYTE            wap_dti_id;
EXTERN ULONG            peer_link_id;
EXTERN ULONG            prot_link_id;
EXTERN UBYTE            peer_entity_id;
EXTERN UBYTE            prot_entity_id;

#endif /* of #ifdef CMH_UDPAS_C */


#endif /* of #ifndef WAP_ACI_H */