FreeCalypso > hg > fc-magnetite
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 */
