view src/condat3/com/include/cl_ribu.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 c8bd5a927942
children
line wrap: on
line source

/*
+-----------------------------------------------------------------------------
|  Project :  COMLIB
|  Modul   :  cl_ribu
+-----------------------------------------------------------------------------
|  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 of global types used by common library functions
|             and the prototypes of those functions.
+-----------------------------------------------------------------------------
*/
/*
 *  Version 1.0
 */

/**********************************************************************************/

#ifndef CL_RIBU_H
#define CL_RIBU_H

/**********************************************************************************/

typedef struct
{
  U8 ri;        /* ring buffer read index */
  U8 wi;        /* ring buffer write index */
  U8 depth;     /* ring buffer depth */
  U8 filled;    /* ring buffer filled flag */
} T_RIBU;

typedef struct
{
  U8 type;
  U8 status;
  U8 len;   /* buffer length */
  U8 *buf;  /* buffer start address */
} T_FD;     /* frame descriptor */

typedef struct
{
  T_RIBU idx;
  T_FD **pFDv;  /* frame descriptor vector */
} T_RIBU_FD;

/**********************************************************************************/

EXTERN void cl_ribu_create(T_RIBU_FD **ribu, const U8 buflen, const U8 depth);
EXTERN void cl_ribu_release(T_RIBU_FD **ribu);

EXTERN void cl_ribu_put(const T_FD fd, T_RIBU_FD *ribu);
EXTERN T_FD *cl_ribu_get(T_RIBU_FD *ribu);
EXTERN T_FD *cl_ribu_get_new_frame_desc(T_RIBU_FD *ribu);

EXTERN void cl_ribu_init(T_RIBU *ribu, const U8 depth);
EXTERN U8   cl_ribu_read_index(T_RIBU *ribu);
EXTERN U8   cl_ribu_write_index(T_RIBU *ribu);
EXTERN BOOL cl_ribu_data_avail(const T_RIBU_FD *ribu);

EXTERN  void cl_set_frame_desc(T_FRAME_DESC *frame_desc, U8 *A0, U16 L0, U8 *A1, U16 L1);
EXTERN  void cl_set_frame_desc_0(T_FRAME_DESC *frame_desc, U8 *A0, U16 L0);

#endif /* CL_RIBU_H */