view src/cs/drivers/drv_app/kpd/kpd_env.c @ 263:b5e8dfd114a7

Switch_ON(): go into charging boot mode on either CHGSTS or CHGPRES If someone were to plug and then unplug a charger into a switched-off phone in an extremely brief "glitch" manner, we should do an automatic power-off on boot in this condition. When we were checking only CHGPRES in Switch_ON(), we would go into Misc boot state instead, which is undesirable. Now if we have a CHGSTS but not CHGPRES condition, we will go into charging boot mode, and FCBM will then do the automatic power-off upon detecting absence of the charger in its periodic polling.
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 14 May 2021 05:50:36 +0000
parents 4e78acac3d88
children
line wrap: on
line source

/**
 * @file   kpd_env.c
 *
 * Coding of the Riviera Generic Functions 
 * (except handle message and handle timer).
 *
 * @author   Laurent Sollier (l-sollier@ti.com)
 * @version 0.1
 */

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



#include "kpd/kpd_env.h"
#include "kpd/kpd_i.h"

#include "rvm/rvm_priorities.h"
#include "rvm/rvm_use_id_list.h"

#include <string.h>


/* External declaration */
extern T_RV_RET kpd_core(void);


/**
 * Pointer on the structure gathering all the global variables
 * used by KPD instance.
 */
T_KPD_ENV_CTRL_BLK* kpd_env_ctrl_blk = NULL;


/**
 * @name Riviera generic functions implementation
 *
 */
/*@{*/

/**
 * function: kpd_get_info
 */
T_RVM_RETURN kpd_get_info(T_RVM_INFO_SWE* swe_info)
{
   /* SWE info */
   swe_info->swe_type = RVM_SWE_TYPE_4;
   swe_info->type_info.type4.swe_use_id = KPD_USE_ID;

   memcpy( swe_info->type_info.type4.swe_name, "KPD", sizeof("KPD") );

   swe_info->type_info.type4.stack_size = KPD_STACK_SIZE;
   swe_info->type_info.type4.priority   = RVM_KPD_TASK_PRIORITY;


   /* Set the return path */
   swe_info->type_info.type4.return_path.callback_func   = NULL;
   swe_info->type_info.type4.return_path.addr_id         = 0;


   /* memory bank info */
   swe_info->type_info.type4.nb_mem_bank = 1;

   memcpy ((UINT8 *)    swe_info->type_info.type4.mem_bank[0].bank_name, "KPD_PRIM", 9);
   swe_info->type_info.type4.mem_bank[0].initial_params.size          = KPD_MB_PRIM_SIZE;
   swe_info->type_info.type4.mem_bank[0].initial_params.watermark     = KPD_MB_PRIM_WATERMARK;

   /* linked SWE info */
   /* this SWE does not require any SWE to run */
   swe_info->type_info.type4.nb_linked_swe = 0;

   /* generic functions */
   swe_info->type_info.type4.set_info = kpd_set_info;
   swe_info->type_info.type4.init     = kpd_init;
   swe_info->type_info.type4.core     = kpd_core;
   swe_info->type_info.type4.stop     = kpd_stop;
   swe_info->type_info.type4.kill     = kpd_kill;

   return RVM_OK;

}


/**
 * function: kpd_set_info
 */
T_RVM_RETURN kpd_set_info (T_RVF_ADDR_ID   addr_id, 
                           T_RV_RETURN      return_path[], 
                           T_RVF_MB_ID      bk_id[],
                           T_RVM_RETURN   (*rvm_error_ft)(T_RVM_NAME       swe_name, 
                                                        T_RVM_RETURN       error_cause, 
                                                        T_RVM_ERROR_TYPE   error_type, 
                                                        T_RVM_STRING       error_msg))
{
   /* Create instance gathering all the variable used by EXPL instance */
   if (rvf_get_buf(bk_id[0], 
                  sizeof(T_KPD_ENV_CTRL_BLK),
                  (T_RVF_BUFFER**)&kpd_env_ctrl_blk) != RVF_GREEN)
   {
      /* The environemnt will cancel the EXPL instance creation. */
      return RVM_MEMORY_ERR;
   }

   /* Store the pointer to the error function */
   kpd_env_ctrl_blk->error_ft = rvm_error_ft ;
   /* Store the mem bank id. */
   kpd_env_ctrl_blk->prim_id = bk_id[0];
   /* Store the address id */
   kpd_env_ctrl_blk->addr_id = addr_id;
   kpd_env_ctrl_blk->swe_is_initialized = FALSE;


   /* return_path of linked SWE -> not used */

   return RVM_OK;
}


/**
 * function: kpd_init
 */
T_RVM_RETURN kpd_init(void)
{
   T_RV_RET ret = RV_OK;

   /* Initialise keypad driver */
   ret = kpd_initialize_keypad_driver();

   /* Note that the (kpd_env_ctrl_blk != 0) check is normally
      useless because if kpd_set_info fail, kpd_init will not
      be called */
   if ( (ret == RV_OK) && (kpd_env_ctrl_blk != 0))
   {
      kpd_env_ctrl_blk->swe_is_initialized = TRUE;
   }

   return ret;
}


/**
 * function: kpd_stop
 */
T_RVM_RETURN kpd_stop(void)
{
   /* NB: Other SWEs have not been killed yet, kpd can send messages to other SWEs. */

   return RVM_OK;
}


/**
 * function: kpd_kill
 */
T_RVM_RETURN kpd_kill (void)
{
   /*
    * DO NOT SEND MESSAGES
    */
   rvf_free_buf(kpd_env_ctrl_blk);

   kpd_kill_keypad_driver();

   return RVM_OK;
}


/*@}*/