diff src/cs/drivers/drv_app/fchg/fchg_api.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 75067af48bfd
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/cs/drivers/drv_app/fchg/fchg_api.c	Fri Oct 16 06:23:26 2020 +0000
@@ -0,0 +1,60 @@
+/*
+ * The implementation of our external API functions lives here.
+ */
+
+#include "fchg/fchg_api.h"
+#include "fchg/fchg_env.h"
+#include "fchg/fchg_messages.h"
+#include "rv/rv_general.h"
+#include "rvf/rvf_api.h"
+#include "rvm/rvm_use_id_list.h"
+
+T_RV_RET fchg_get_current_state(struct fchg_user_state *rstruct)
+{
+	if (!pwr_ctrl)
+		return RV_NOT_READY;
+	rstruct->chg_state = pwr_ctrl->state;
+	rstruct->batt_mv = pwr_ctrl->batt_mv;
+	rstruct->batt_percent =
+	    pwr_ctrl->batt_thresholds[pwr_ctrl->curr_disch_thresh].remain_capa;
+	return RV_OK;
+}
+
+T_RV_RET fchg_user_charge_control(enum fchg_user_charge_ctrl arg)
+{
+	enum pwr_msg_id msg_id;
+	struct pwr_req_s *msg;
+
+	if (!pwr_ctrl)
+		return RV_NOT_READY;
+	switch (arg) {
+	case FCHG_CHARGE_START:
+		if (!pwr_ctrl->config_present)
+			return RV_NOT_READY;
+		msg_id = USER_START_CHARGE_REQ;
+		break;
+	case FCHG_CHARGE_STOP:
+		msg_id = USER_STOP_CHARGE_REQ;
+		break;
+	default:
+		return RV_INVALID_PARAMETER;
+	}
+	if (rvf_get_buf(pwr_ctrl->prim_id, sizeof(struct pwr_req_s),
+			(T_RVF_BUFFER **)&msg) == RVF_RED) {
+		rvf_send_trace(
+			"rvf_get_buf() failed in fchg_user_charge_control()",
+			50, NULL_PARAM, RV_TRACE_LEVEL_ERROR, FCHG_USE_ID);
+		return RV_MEMORY_ERR;
+	}
+	msg->header.msg_id        = msg_id;
+	msg->header.src_addr_id   = pwr_ctrl->addr_id;
+	msg->header.dest_addr_id  = pwr_ctrl->addr_id;
+	msg->header.callback_func = NULL;
+	if (rvf_send_msg(pwr_ctrl->addr_id, msg) != RV_OK) {
+		rvf_send_trace("fchg_user_charge_control(): Send failed!", 40,
+				NULL_PARAM, RV_TRACE_LEVEL_ERROR, FCHG_USE_ID);
+		rvf_free_buf(msg);
+		return RV_INTERNAL_ERR;
+	}
+	return RV_OK;
+}