view src/cs/services/lls/lls_api.c @ 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 945cf7f506b2
children
line wrap: on
line source

/**
 * @file   lls_api.c
 *
 * Implementation of Functions.
 *
 * @author   Laurent Sollier (l-sollier@ti.com)
 * @version 0.1
 */

/*
 * History:
 *
 *   Date          Author       Modification
 *  ----------------------------------------
 *  03/12/2002     L Sollier    Create
 *
 *
 * (C) Copyright 2002 by Texas Instruments Incorporated, All Rights Reserved
 */

#ifndef _WINDOWS
   #include "l1sw.cfg"
   #include "chipset.cfg"
#endif

#include "lls/lls_api.h"
#include "lls/lls_env.h"
#include "lls/lls_i.h"


/** External declaration */
extern T_LLS_ENV_CTRL_BLK* lls_env_ctrl_blk;


/**
 * @name Functions implementation
 *
 */
/*@{*/


/**
 * function: lls_switch_on
 */
T_RV_RET lls_switch_on(T_LLS_EQUIPMENT equipment_sort)
{
#if (ANLG_FAM == 2)
   T_RV_RET ret = RV_OK;
   UINT8 equipment_index;

   /* Check if initialization has been correctly done */
   if ( (lls_env_ctrl_blk == 0) || (lls_env_ctrl_blk->swe_is_initialized == FALSE) )
   {
      LLS_SEND_TRACE("LLS: Initialization is not yet done or failed", RV_TRACE_LEVEL_ERROR);
      return RV_INTERNAL_ERR;
   }

   LLS_SEND_TRACE_PARAM("LLS: Switch ON request for equipment", equipment_sort, RV_TRACE_LEVEL_DEBUG_HIGH);

   /* Retrieve index of the equipment in the table */
   ret = lls_search_index(equipment_sort, &equipment_index);

   if (ret != RV_OK)
   {
      LLS_SEND_TRACE("LLS: Equipment is unknow", RV_TRACE_LEVEL_ERROR);
      return ret;
   }

   ret = lls_manage_equipment(equipment_index, SWITCH_ON);

   return ret;

#else
   return RV_NOT_SUPPORTED;
#endif
}

/**
 * function: lls_switch_off
 *
 */
T_RV_RET lls_switch_off(T_LLS_EQUIPMENT equipment_sort)
{
#if (ANLG_FAM == 2)
   T_RV_RET ret = RV_OK;
   UINT8 equipment_index;

   /* Check if initialization has been correctly done */
   if ( (lls_env_ctrl_blk == 0) || (lls_env_ctrl_blk->swe_is_initialized == FALSE) )
   {
      LLS_SEND_TRACE("LLS: Initialization is not yet done or failed", RV_TRACE_LEVEL_ERROR);
      return RV_INTERNAL_ERR;
   }

   LLS_SEND_TRACE_PARAM("LLS: Switch OFF request for equipment", equipment_sort, RV_TRACE_LEVEL_DEBUG_HIGH);

   /* Retrieve index of the equipment in the table */
   ret = lls_search_index(equipment_sort, &equipment_index);

   if (ret != RV_OK)
   {
      LLS_SEND_TRACE("LLS: Equipment is unknow", RV_TRACE_LEVEL_ERROR);
      return ret;
   }

   ret = lls_manage_equipment(equipment_index, SWITCH_OFF);
   
   return ret;

#else
   return RV_NOT_SUPPORTED;
#endif
}


/*@}*/