FreeCalypso > hg > fc-magnetite
view src/aci2/aci/cmh_pps.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 | 93999a60b835 |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : GSM-PS (6147) | Modul : CMH_PPPS +----------------------------------------------------------------------------- | 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 module provides the set functions related to the | protocol stack adapter for the PPP module. +----------------------------------------------------------------------------- */ #ifdef DTI #if defined(FF_WAP) || defined(FF_TCP_IP) || defined(FF_GPF_TCPIP) || defined(FF_SAT_E) #ifndef CMH_PPPS_C #define CMH_PPPS_C #endif #include "aci_all.h" /*==== INCLUDES ===================================================*/ #include "aci_cmh.h" #include "ati_cmd.h" #include "aci_cmd.h" #ifdef FAX_AND_DATA #include "aci_fd.h" #endif #include "ksd.h" #include "dti.h" /* functionality of the dti library */ #include "dti_conn_mng.h" #include "psa.h" #include "psa_sim.h" #include "psa_sms.h" #include "wap_aci.h" #include "psa_ppp_w.h" #include "phb.h" #include "cmh.h" #include "cmh_phb.h" #include "cmh_sms.h" /*==== CONSTANTS ==================================================*/ /*==== TYPES ======================================================*/ /*==== EXPORT =====================================================*/ /*==== VARIABLES ==================================================*/ /*==== FUNCTIONS ==================================================*/ /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : CMH_PPPS | | STATE : code ROUTINE : sAT_PercentPPP | +-------------------------------------------------------------------+ PURPOSE : This command will be called from MMI to set the authentification protocol, the login name, and the password for the PPP entity. */ GLOBAL T_ACI_RETURN sAT_PercentPPP ( T_ACI_CMD_SRC srcId, T_ACI_PPP_PROT protocol, CHAR *login, CHAR *pwd, T_ACI_PPP_CON con_type ) { switch (protocol) { case(A_NO_AUTH): pppShrdPrm.auth_prot = PPP_AP_NO; break; case(A_PAP): pppShrdPrm.auth_prot = PPP_AP_PAP; break; case(A_CHAP): pppShrdPrm.auth_prot = PPP_AP_CHAP; break; case(A_AUTO_AUTH): pppShrdPrm.auth_prot = PPP_AP_AUTO; break; default: TRACE_EVENT("Wrong value for authentification protocol"); return AT_FAIL; } #ifdef FF_TCP_IP switch (con_type) { case(USE_NO_PPP_FOR_AAA): pppShrdPrm.is_PPP_CALL = FALSE; break; case(USE_PPP_FOR_AAA): pppShrdPrm.is_PPP_CALL = TRUE; break; default: TRACE_EVENT("Wrong value for connection type"); return AT_FAIL; } #endif if((login NEQ NULL) AND (pwd NEQ NULL)) { memcpy(pppShrdPrm.ppp_login,login, sizeof(pppShrdPrm.ppp_login)); memcpy(pppShrdPrm.ppp_password,pwd, sizeof(pppShrdPrm.ppp_password)); } else return AT_FAIL; return AT_CMPL; } #ifdef DTI /** Functional interface to the AT%PPP? command. The IP addresses are in host * byte order. * * @param srcId ID of command source (unused). * @param ipaddr_p Pointer to IP address variable of caller. * @param dns1_p Pointer to dns1 variable of caller. * @param dns2_p Pointer to dns2 variable of caller. * @return AT_CMPL */ GLOBAL T_ACI_RETURN qAT_PercentPPP(UBYTE srcId, ULONG *ipaddr_p, ULONG *dns1_p, ULONG *dns2_p) { if (ipaddr_p NEQ NULL) { *ipaddr_p = pppShrdPrm.ipaddr ; } if (dns1_p NEQ NULL) { *dns1_p = pppShrdPrm.dns1 ; } if (dns2_p NEQ NULL) { *dns2_p = pppShrdPrm.dns2 ; } return AT_CMPL ; } #endif /* DTI */ /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : CMH_PPPS | | STATE : code ROUTINE : cmhPPP_Terminate | +-------------------------------------------------------------------+ PURPOSE : */ GLOBAL T_ACI_RETURN cmhPPP_Terminate ( T_ACI_PPP_LOWER_LAYER ppp_lower_layer ) { TRACE_FUNCTION("cmhPPP_Terminate()"); psaPPP_Terminate(ppp_lower_layer); return (AT_CMPL); } #endif /* defined(WAP) || defined(FF_TCP_IP) || defined(FF_GPF_TCPIP) || defined (FF_SAT_E) */ #endif /* DTI */