view src/g23m-fad/ppp/ppp_onaf.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 (ONA-statemachine)
+----------------------------------------------------------------------------- 
*/ 

#ifndef PPP_ONAF_C
#define PPP_ONAF_C
#endif /* !PPP_ONAF_C */

#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 */
#include "gsm.h"        /* to get a lot of macros */
#include "cnf_ppp.h"    /* to get cnf-definitions */
#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 */

/*==== CONST ================================================================*/

/*==== LOCAL VARS ===========================================================*/

/*==== PRIVATE FUNCTIONS ====================================================*/

/*==== PUBLIC FUNCTIONS =====================================================*/



/*
+------------------------------------------------------------------------------
| Function    : ona_init
+------------------------------------------------------------------------------
| Description : The function ona_init() initializes the option negotiation
|               automaton (ONA) 
|
| Parameters  : no parameters
|
+------------------------------------------------------------------------------
*/
GLOBAL void ona_init ()
{
  UBYTE i;

  TRACE_FUNCTION( "ona_init" );

  for (i = 0;i < ONA_NUM_INC;i++)
  {
    ppp_data->ona = & ppp_data->ona_base[i];

    /* counter for Configure-Request and Terminate-Request sent 	*/
    ppp_data->ona->restarts = 0;		
    /* counter for Configure-Nak and Configure-Reject sent		*/
    ppp_data->ona->failures = 0;		
    /*
     * counter for Configure-Ack received
     * this counter avoids endless loops where the PPP peer always answers with
     * a Configure-Ack, but it does not send a Configure-Req
     */
    ppp_data->ona->loops = 0;

    INIT_STATE( PPP_SERVICE_ONA , ONA_CLOSED );
  }
} /* ona_init() */


/*
+------------------------------------------------------------------------------
| Function    : ona_get_inst_index
+------------------------------------------------------------------------------
| Description : gets the index (0, 1) for the given ptype (DTI_PID_LCP, 
| DTI_PID_IPCP). This function is used when a calling service serves a key for 
| one of the 2 possible instances of services LCR and NCR.
|
| Parameters  : USHORT ptype, UBYTE* index
|
+------------------------------------------------------------------------------
*/
GLOBAL void ona_get_inst_index(USHORT ptype,
                                 UBYTE* index)
{
  TRACE_FUNCTION("ona_get_inst_index");

  if (ptype EQ DTI_PID_LCP) 
  {
    *index = 0;
  } 
  else if (ptype EQ DTI_PID_IPCP) 
  {
    *index = 1;
  } 
  else 
  {
    TRACE_ERROR( "ONA_GET_INST_INDEX unexpected ptype" );
    *index = 0;
  }
}