diff src/cs/drivers/drv_app/kpd/kpd_env.c @ 0:4e78acac3d88

src/{condat,cs,gpf,nucleus}: import from Selenite
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 16 Oct 2020 06:23:26 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/cs/drivers/drv_app/kpd/kpd_env.c	Fri Oct 16 06:23:26 2020 +0000
@@ -0,0 +1,177 @@
+/**
+ * @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;
+}
+
+
+/*@}*/