FreeCalypso > hg > fc-magnetite
view src/cs/drivers/drv_core/timer/timer.h @ 673:62a5285e014a
Lorekeeping: allow tpudrv-leonardo.lib on Leonardo/Tango
Back in 2015 the Mother's idea was to produce a FreeCalypso development
board that would be a clone of TI Leonardo, including the original
quadband RFFE; one major additional stipulation was that this board
needed to be able to run original unmodified TCS211-20070608 firmware
with all blobs intact, with only minimal binary patches to main.lib
and tpudrv.lib. The necessary patched libs were produced at that time
in the tcs211-patches repository.
That plan was changed and we produced FCDEV3B instead, with Openmoko's
triband RFFE instead of Leonardo quadband, but when FC Magnetite started
in 2016, a TPUDRV_blob= provision was still made, allowing the possibility
of patching OM's tpudrv.lib for a restored Leonardo RFFE.
Now in 2020 we have FC Tango which is essentially a verbatim clone of
Leonardo core, including the original quadband RFFE. We have also
deblobbed our firmware so much that we have absolutely no real need
for a blob version of tpudrv.lib - but I thought it would be neat to put
the ancient TPUDRV_blob= mechanism (classic config) to its originally
intended use, just for the heck of it.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 29 May 2020 03:55:36 +0000 |
parents | 945cf7f506b2 |
children |
line wrap: on
line source
/******************************************************************************* TEXAS INSTRUMENTS INCORPORATED PROPRIETARY INFORMATION Property of Texas Instruments -- For Unrestricted Internal Use Only Unauthorized reproduction and/or distribution is strictly prohibited. This product is protected under copyright law and trade secret law as an unpublished work. Created 1987, (C) Copyright 1997 Texas Instruments. All rights reserved. Filename : timer.h Description : timer.c header Project : drivers Author : pmonteil@tif.ti.com Patrice Monteil. Version number : 1.3 Date and time : 07/23/98 16:25:53 Previous delta : 07/23/98 16:25:52 SCCS file : /db/gsm_asp/db_ht96/dsp_0/gsw/rel_0/mcu_l1/release1.5/mod/emu/EMU_MCMP/eva3_drivers/source/SCCS/s.timer.h Sccs Id (SID) : '@(#) timer.h 1.3 07/23/98 16:25:53 ' *****************************************************************************/ #include "l1sw.cfg" #if (OP_L1_STANDALONE == 0) #include "main/sys_types.h" #else #include "sys_types.h" #endif #define TIMER_CNTL_REG MEM_TIMER_ADDR /* watchdog Control Timer register */ #define TIMER_ST 0x0080 #define TIMER_AR 0x0100 #define TIMER_PTV 0x0e00 #define TIMER_CNTL_MASK 0x0f80 #define TIMER_MODE_MASK 0x80ff #define TIMER_LOAD_REG (MEM_TIMER_ADDR + 0x02) /* Timer load register */ #define TIMER_READ_REG (MEM_TIMER_ADDR + 0x02) /* Timer read register */ #define TIMER_MODE_REG (MEM_TIMER_ADDR + 0x04) /* Timer mode register */ #define TIMER_WDOG 0x8000 /* watch dog */ #define START_STOP 1 /*to start or stop a timer */ #define AR 0x0002 #define PTV 0x001c #define TIMER_CLK_EN 0x0020 #define TIMER1_CNTL (MEM_TIMER1 + 0x00) #define TIMER1_LOAD_TIM (MEM_TIMER1 + 0x02) #define TIMER1_READ_TIM (MEM_TIMER1 + 0x04) #define TIMER2_CNTL (MEM_TIMER2 + 0x00) #define TIMER2_LOAD_TIM (MEM_TIMER2 + 0x02) #define TIMER2_READ_TIM (MEM_TIMER2 + 0x04) /*-------------------------------------------------------------- * TIMER_START_STOP () *-------------------------------------------------------------- * Parameters : start or stop command * Return : none * Functionality : Start or Stop the timer *--------------------------------------------------------------*/ #define TIMER_START_STOP(startStop) ((startStop) ? ((* (volatile SYS_UWORD16 *) TIMER_CNTL_REG) |= TIMER_ST) : \ ((* (volatile SYS_UWORD16 *) TIMER_CNTL_REG) &= ~TIMER_ST)) /* Prototype of the functions */ void TM_ResetTimer (SYS_UWORD16 timerNum, SYS_UWORD16 countValue, SYS_UWORD16 autoReload, SYS_UWORD16 clockScale); void TM_StopTimer (int timerNum); void TM_StartTimer (int timerNum); SYS_UWORD16 TM_ReadTimer (int timerNum); void TM_DisableWatchdog(void); void TM_EnableWatchdog(void); void TM_ResetWatchdog(SYS_UWORD16 cnt); void TM_EnableTimer (int timerNum); void TM_DisableTimer (int timerNum); SYS_UWORD16 TIMER_Read (unsigned short); void TIMER_WriteValue (SYS_UWORD16); unsigned short TIMER_ReadValue (void);