FreeCalypso > hg > fc-magnetite
view src/gpf2/inc/frm_glob.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 | 864b8cc0cf63 |
children |
line wrap: on
line source
/* +------------------------------------------------------------------------------ | File: frm_glob.h +------------------------------------------------------------------------------ | 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 : Global frame tables +----------------------------------------------------------------------------- */ #ifndef FRM_GLOB_H #define FRM_GLOB_H /*==== INCLUDES =============================================================*/ #include "frm_types.h" /*==== CONSTANTS ============================================================*/ /*==== TYPES ================================================================*/ /*==== VARIABLES ================================================================*/ #ifndef CONFIG_MODULE extern USHORT MaxEntities; extern USHORT MaxCommunications; extern USHORT MaxSimultaneousTimer; extern USHORT MaxTimer; extern USHORT MaxSemaphores; extern USHORT NumberOfPPMPartitions; extern ULONG MaxPrimPartSize; extern USHORT TextTracePartitionSize; extern T_VOID_STRUCT *processed_prim[]; extern T_VOID_STRUCT *freed_prim[]; extern T_HANDLE e_running[]; extern T_FRM_TASK_TABLE_ENTRY pf_TaskTable[]; extern ULONG TraceMask[]; extern char TracesAborted[]; extern char PrimAborted[]; extern char route_desclist[]; extern T_HANDLE TimerHandleField[]; #if !defined _TARGET_ && !defined _TOOLS_ extern char pcheck_active[]; #endif #else /* CONFIG_MODULE */ /* -------------- S H A R E D - BEGIN ---------------- */ #ifdef _TOOLS_ #pragma data_seg("FRAME_SHARED") #endif #ifndef DATA_INT_RAM /* declare on pointer for each entity for ccd error handling */ struct ccd_task_table; struct ccd_task_table* ccd_task_list[MAX_ENTITIES+1]; USHORT MaxEntities = MAX_ENTITIES; USHORT MaxTimer = MAX_TIMER; #ifndef _TOOLS_ /* * This way of setting the TST and RCV stacksize is chosen to keep it backwardscompatible, * i.e. not change the behavior if the stacksizes are not define in the configuration * file xxxconst.h. */ #ifdef TSTSND_STACK_SIZE const USHORT TST_SndStacksize = TSTSND_STACK_SIZE; #else const USHORT TST_SndStacksize = 0; #endif #ifdef TSTRCV_STACK_SIZE const USHORT TST_RcvStacksize = TSTRCV_STACK_SIZE; #else const USHORT TST_RcvStacksize = 0; #endif #endif /* _TOOLS_ */ T_FRM_TASK_TABLE_ENTRY pf_TaskTable [ MAX_ENTITIES + 1 ]={0}; ULONG *Routing [ MAX_ENTITIES + 1 ]={0}; ULONG TraceMask [ MAX_ENTITIES + 1 ]={0}; char TracesAborted [ MAX_ENTITIES + 1 ]={0}; char PrimAborted [ MAX_ENTITIES + 1 ]={0}; #ifdef PRIM_AUTO_FREE T_VOID_STRUCT *processed_prim [ MAX_ENTITIES + 1 ]={0}; T_VOID_STRUCT *freed_prim [ MAX_ENTITIES + 1 ]={0}; #endif T_HANDLE e_running [ MAX_ENTITIES + 1 ]={0}; char route_desclist [ MAX_ENTITIES + 1 ]={0}; T_DRV_TABLE_ENTRY DrvTable [ MAX_TST_DRV + 1 ]={0}; T_HANDLE TimerHandleField [ MAX_TIMER + 1 ]={0}; #if !defined _TARGET_ && !defined _TOOLS_ char pcheck_active [ MAX_ENTITIES + 1 ]={0}; #endif #endif /* DATA_INT_RAM */ #ifdef _TOOLS_ #pragma data_seg() #endif /* -------------- S H A R E D - END ---------------- */ #endif /* CONFIG_MODULE */ #endif