view src/g23m-aci/bat/bat_ctrl.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   :  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.
+-----------------------------------------------------------------------------
|  Purpose :  This Modul holds the functions
|             for the binary AT command library at APPlication side
+-----------------------------------------------------------------------------
*/
#ifndef BAT_CTRL_H
#define BAT_CTRL_H



/*********************************************************************************
 *
 * enums
 *
 *********************************************************************************/

typedef enum
{
  BATC_MAX_CLIENTS = 0x8000,/*bit 15 is 1 */
  BATC_OPEN_CLIENT,
  BATC_CLOSE_CLIENT,
  BATC_ABORT_CMD
} T_BATC_ctrl_params;


typedef enum
{
  BATC_MAX_CLIENTS_CNF = 0x8000, /* bit 15 is 1 */
  BATC_MAX_CLIENTS_REJ,
  BATC_OPEN_CLIENT_CNF,
  BATC_OPEN_CLIENT_REJ,
  BATC_ABORT_COMMAND_CNF,
  BATC_ABORT_COMMAND_REJ
} T_BATC_rsp_param;


/*********************************************************************************
 *
 * structures
 *
 *********************************************************************************/

typedef struct
{
  U32  batc_dummy;
} T_BATC_no_parameter;  /* actually never used */

typedef struct
{
  U32  num_clients;
} T_BATC_max_clients;   /* max number of clients of an instance */

typedef struct
{
  U32  client_id;
} T_BATC_open_client;   /* client to open */

typedef struct
{
  U32  client_id;
} T_BATC_close_client;   /* client to close */

typedef struct
{
  U32  client_id;
} T_BATC_abort_cmd;   /* client which runs the cmd */

typedef union
{
  T_BATC_max_clients    *ptr_max_clients;
  T_BATC_open_client    *ptr_open_client;
  T_BATC_close_client   *ptr_close_client;
  T_BATC_abort_cmd      *ptr_abort_cmd;
} T_BATC_params;

typedef union
{
  T_BATC_open_client   *ptr_bat_open_client_cnf; /* confirmation from BAT to BAT Lib */
  T_BATC_abort_cmd     *ptr_bat_abort_command_cnf; /* confirmation from BAT to BAT Lib */
} T_BATC_rsp;

typedef struct
{
  T_BATC_ctrl_params   ctrl_params;
  T_BATC_params        params;
}T_BATC_signal;

typedef struct
{
  T_BATC_rsp_param     rsp_params;              
  T_BATC_rsp           rsp;                   
}T_BATC_confirm;



#endif  /* BAT_CTRL_H */