view src/cs/services/fcbm/fcbm_env.c @ 266:160a5b3a076c

new ABB_SLEEP_RESTRICTION definition in fc-target.h When we first introduced the mechanism to suppress ABB superdeep sleep on targets with LCDs powered from Iota VRIO, we made it conditional on CONFIG_TARGET_LUNA. This conditional is now being generalized: the feature in question is now conditionalized on the new ABB_SLEEP_RESTRICTION preprocessor symbol, to be defined in targets/*.h for those targets that need it. The new ABB_SLEEP_RESTRICTION definition is being added to targets/luna[12].h to keep the actual logic unchanged.
author Mychaela Falconia <falcon@freecalypso.org>
date Wed, 02 Jun 2021 02:12:14 +0000
parents baa738eeb842
children
line wrap: on
line source

/*
 * This module provides the glue to the RiViera environment
 * for our FCBM SWE.
 */

#include "fcbm/fcbm_env.h"
#include "rv/rv_general.h"
#include "rvf/rvf_api.h"
#include "rvm/rvm_priorities.h"
#include "rvm/rvm_api.h"
#include "rvm/rvm_use_id_list.h"
#include <string.h>

/* Global variables for FCBM addr_id and prim_id */
T_RVF_ADDR_ID fcbm_addr_id;
T_RVF_MB_ID fcbm_prim_id;

T_RVM_RETURN fcbm_get_info (T_RVM_INFO_SWE  *infoSWE)
{
   /* SWE info */

   infoSWE->swe_type = RVM_SWE_TYPE_4;
   infoSWE->type_info.type4.swe_use_id = FCBM_USE_ID;
   memcpy( infoSWE->type_info.type4.swe_name, "FCBM", 5 );

   infoSWE->type_info.type4.stack_size = FCBM_STACK_SIZE;
   infoSWE->type_info.type4.priority   = RVM_FCBM_TASK_PRIORITY;

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

   memcpy ((UINT8 *) infoSWE->type_info.type4.mem_bank[0].bank_name, "FCBM_PRIM", 10);
   infoSWE->type_info.type4.mem_bank[0].initial_params.size          = FCBM_MB_PRIM_SIZE;
   infoSWE->type_info.type4.mem_bank[0].initial_params.watermark     = FCBM_MB_PRIM_WATERMARK;

   /* linked SWE info: we depend on FCHG, R2D, KPD */
   infoSWE->type_info.type4.nb_linked_swe    = 3;
   infoSWE->type_info.type4.linked_swe_id[0] = FCHG_USE_ID;
   infoSWE->type_info.type4.linked_swe_id[1] = R2D_USE_ID;
   infoSWE->type_info.type4.linked_swe_id[2] = KPD_USE_ID;

   /* generic functions */
   infoSWE->type_info.type4.set_info = fcbm_set_info;
   infoSWE->type_info.type4.init     = fcbm_init;
   infoSWE->type_info.type4.core     = fcbm_core;
   infoSWE->type_info.type4.stop     = fcbm_stop;
   infoSWE->type_info.type4.kill     = fcbm_kill;

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

   return RV_OK;
}

T_RVM_RETURN fcbm_set_info(T_RVF_ADDR_ID   addr_id,
                           T_RV_RETURN     return_path[],
                           T_RVF_MB_ID     mbId[],
                           T_RVM_RETURN  (*callBackFct) (T_RVM_NAME SWEntName,
                                                         T_RVM_RETURN errorCause,
                                                         T_RVM_ERROR_TYPE errorType,
                                                         T_RVM_STRING errorMsg))
{
    /* Store the addr id */
    fcbm_addr_id = addr_id;

    /* Store the memory bank id */
    fcbm_prim_id = mbId[0];

    return RV_OK;
}

T_RVM_RETURN fcbm_init(void)
{
   return RV_OK;
}

T_RVM_RETURN fcbm_stop(void)
{
   return RV_OK;
}

T_RVM_RETURN fcbm_kill(void)
{
   return RV_OK;
}