FreeCalypso > hg > fc-magnetite
view src/gpf2/inc/nuc/os_const.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: os_const.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 : Constants for the Nucleus OS-Layer +----------------------------------------------------------------------------- */ #ifndef OS_CONST_H #define OS_CONST_H /*==== INCLUDES =============================================================*/ /*==== CONSTS ===============================================================*/ #define PTR_OVERHEAD 8 #ifdef MEMORY_SUPERVISION #define PPM_CHKOVERHEAD 4 #define PPM_OVERHEAD (4+PPM_CHKOVERHEAD) #define PPM_IDX_OFFSET 0 #else #define PPM_CHKOVERHEAD 0 #define PPM_OVERHEAD 0 #endif #ifdef NU_DEBUG #define PT_CHKOVERHEAD 4 #else #define PT_CHKOVERHEAD 0 #endif #define PT_OVERHEAD (PTR_OVERHEAD+PPM_OVERHEAD) #define POOL_OVERHEAD 0 #define PPM_OFFSET ((PPM_OVERHEAD-PPM_CHKOVERHEAD)/sizeof(ULONG)) #define SUSPEND_ONE_TICK 1 #define TDMA_FRAME_DURATION 4.615 #define WIN32_TIMER_TICK 50 #define NO_WAIT_CHECK 0 #define WAIT_CHECK 1 #define OS_SUSPEND 0xffffffffUL /*NU_SUSPEND*/ #define OS_NO_SUSPEND 0 /*NU_NO_SUSPEND*/ #define OS_FOREVER 0xffffffffUL /*NU_SUSPEND*/ #define TIME_TO_TICK_TDMA_FRAME_MULTIPLIER 14199 #define TICK_TO_TIME_TDMA_FRAME_MULTIPLIER 302483 #define TIME_TO_TICK_10MS_MULTIPLIER 6554 #define TICK_TO_TIME_10MS_MULTIPLIER 655319 #ifdef _TARGET_ #define TIME_TO_SYSTEM_TICKS(time) (((((time)&0xffff)*os_time_to_tick_multiplier+0x8000)>>16)\ +(((time)>>16)*os_time_to_tick_multiplier)) #define SYSTEM_TICKS_TO_TIME(ticks) (((((ticks)&0xfff)*os_tick_to_time_multiplier+0x8000)>>16)\ +((((ticks)>>12)*os_tick_to_time_multiplier)>>4)) #else #define TIME_TO_SYSTEM_TICKS(Time) ((Time)/WIN32_TIMER_TICK) #define SYSTEM_TICKS_TO_TIME(Ticks) ((Ticks)*WIN32_TIMER_TICK) #endif #define OS_QUEUE_ENTRY_SIZE(E) (((E)*(sizeof(OS_QDATA)+sizeof(void*)) + (OS_MAX_PRIORITY * (((E)+1)*sizeof(void*))))) #define POOL_SIZE(n,s) ((n*(s+PT_CHKOVERHEAD+PT_OVERHEAD))) /* to avoid changes in all xxxconst.h files even if they do not use events */ #ifndef MAX_EVENT_GROUPS #define MAX_EVENT_GROUPS 1 #endif /*==== TYPES =================================================================*/ /*==== EXPORTS ===============================================================*/ #endif /* OS_CONST_H */