FreeCalypso > hg > fc-magnetite
changeset 345:3a7810ca74e2
fchg_user_charge_control() API implemented
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 15 Dec 2017 21:05:00 +0000 |
parents | 562fa85c8963 |
children | 550cfa9e1ca7 |
files | src/cs/drivers/drv_app/fchg/fchg_api.c |
diffstat | 1 files changed, 41 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/src/cs/drivers/drv_app/fchg/fchg_api.c Fri Dec 15 19:58:18 2017 +0000 +++ b/src/cs/drivers/drv_app/fchg/fchg_api.c Fri Dec 15 21:05:00 2017 +0000 @@ -11,9 +11,50 @@ 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; +}