FreeCalypso > hg > fc-magnetite
view src/g23m-fad/ppp/ppp_prxf.c @ 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 | 90eb61ecd093 |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : | Modul : +----------------------------------------------------------------------------- | 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 : This modul is part of the entity PPP and implements all | procedures and functions as described in the | SDL-documentation (PRX-statemachine) +----------------------------------------------------------------------------- */ #define ENTITY_PPP /*==== INCLUDES =============================================================*/ #include "typedefs.h" /* to get Condat data types */ #include "vsi.h" /* to get a lot of macros */ #include "macdef.h" /* to get a lot of macros */ #include "custom.h" /* to get a lot of macros */ /*lint -efile(766,gsm.h) */ #include "gsm.h" /* to get a lot of macros */ /*lint -efile(766,cnf_ppp.h) */ #include "cnf_ppp.h" /* to get cnf-definitions */ /*lint -efile(766,mon_ppp.h) */ #include "mon_ppp.h" /* to get mon-definitions */ #include "prim.h" /* to get the definitions of used SAP and directions */ #include "dti.h" /* to get the DTILIB definitions */ #include "ppp.h" /* to get the global entity definitions */ #ifdef FF_STATUS_TE #include "gdi.h" /* To include driver type-defines */ #include "ste.h" /* To include function interface for TE status driver */ #include "ppp_prxf.h" /* To include call-back function for TE status driver */ #endif /* FF_STATUS_TE */ /*==== CONST ================================================================*/ /*==== LOCAL VARS ===========================================================*/ /*==== PRIVATE FUNCTIONS ====================================================*/ /*==== PUBLIC FUNCTIONS =====================================================*/ /* +------------------------------------------------------------------------------ | Function : prx_init +------------------------------------------------------------------------------ | Description : The function prx_init() initializes Packet Receive (PRX) | | Parameters : no parameters | +------------------------------------------------------------------------------ */ GLOBAL void prx_init () { TRACE_FUNCTION( "prx_init" ); #if defined FF_STATUS_TE /* * Init of the TE status driver - the handle is unique inside PPP only, SMN * PPP handle-management are placed in the end of ppp.h */ if (DRV_OK NEQ STE_Init( STE_HANDLE, cb_status_TE )) { /* * Error during init of TE status driver - either it is already init or it has failed */ TRACE_ERROR( "STE driver init. error" ); } else { #ifdef _SIMULATION_ TRACE_EVENT( "Return DRV_OK from STE_Init()" ); #endif /* _SIMULATION_ */ /* * Setup of used signal-types for driver to trig a callback */ if (DRV_OK NEQ STE_SetSignal( DRV_SIGTYPE_READ )) { /* * Error during signal-set - either signal illegal, not available or internal fail */ TRACE_ERROR( "STE driver setup error" ); } #ifdef _SIMULATION_ else { TRACE_EVENT( "Return DRV_OK from STE_SetSignal()" ); } #endif /* _SIMULATION_ */ } /* * initialize variables */ ppp_data->prx.TE_data_buffer_desc_list_first = NULL; ppp_data->prx.TE_data_buffer_p_id = DTI_PID_UOS; ppp_data->prx.TE_data_buffered = FALSE; #endif /* FF_STATUS_TE */ INIT_STATE( PPP_SERVICE_PRX , PRX_DEAD ); } /* prx_init() */ #ifdef FF_STATUS_TE /* +------------------------------------------------------------------------------ | Function : cb_status_TE +------------------------------------------------------------------------------ | Description : Handles the call-back from the TE status driver and sends the | NEW_POWER_STATUS signal to the PS | | Parameters : None | +------------------------------------------------------------------------------ */ GLOBAL void cb_status_TE (T_DRV_SIGNAL * signal) { TRACE_FUNCTION( "cb_status_TE" ); if((signal->SignalType EQ DRV_SIGTYPE_READ) && (signal->DrvHandle EQ STE_HANDLE) && (*((USHORT*)signal->UserData) EQ STE_IDENTIFIER_POWER)) { PSIGNAL(hCommPPP, NEW_POWER_STATUS, NULL); } else { TRACE_ERROR( "STE driver: Signal not supported" ); } } /* cb_status_TE() */ #endif /* FF_STATUS_TE */