diff src/cs/drivers/drv_app/fchg/fchg_struct.h @ 0:b6a5e36de839

src/cs: initial import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 15 Jul 2018 04:39: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/fchg/fchg_struct.h	Sun Jul 15 04:39:26 2018 +0000
@@ -0,0 +1,72 @@
+/*
+ * Internal structure definitions for the FCHG SWE reside here.
+ * abb_inth.c will also need to include this header in order to
+ * get our T_PWR_CTRL_BLOCK definition.
+ */
+
+#ifndef __FCHG_STRUCT_H
+#define __FCHG_STRUCT_H
+
+#include "rv/rv_general.h"
+#include "rvf/rvf_api.h"
+#include "fchg/fchg_common.h"
+
+struct charging_config {
+	UINT16	start_delay;
+	UINT16	start_thresh;
+	UINT16	restart_thresh;
+	UINT16	ci2cv_thresh;
+	UINT16	cv_init_set;
+	UINT16	cv_ctrl_loop_high;
+	UINT16	cv_ctrl_loop_low;
+	UINT16	cv_dac_max_incr;
+	UINT16	cv_dac_max_decr;
+	UINT16	cv_samples_needed;
+	UINT16	overvoltage;
+	UINT16	ci_current;
+	UINT16	end_current;
+	UINT16	ichg_max_spike;
+	UINT16	ichg_samples_needed;
+	UINT16	charge_time_limit;
+	UINT16	recharge_delay;
+	UINT16	bciconf;
+};
+
+/* from original PWR SWE */
+typedef struct {
+	UINT16		bat_voltage;
+	T_PWR_PERCENT	remain_capa;
+} T_PWR_THRESHOLDS;
+
+#define	MAX_THRESHOLDS	101
+
+#define	ICHG_AVG_WINDOW	6
+
+typedef struct {
+	/* RiViera boilerplate */
+	T_RVF_ADDR_ID		addr_id;
+	T_RVF_MB_ID		prim_id;
+	/* configuration */
+	struct charging_config	config;
+	BOOL			config_present;
+	T_PWR_THRESHOLDS	batt_thresholds[MAX_THRESHOLDS];
+	UINT16			nb_thresholds;
+	/* state */
+	enum fchg_state		state;
+	UINT16			batt_mv;
+	UINT16			curr_disch_thresh;
+	/* valid only during a charging cycle */
+	UINT16			i2v_offset;
+	UINT16			cv_dac_init;
+	UINT16			cv_dac_curr;
+	UINT16			cv_high_vbat_count;
+	UINT16			cv_low_vbat_count;
+	UINT16			ichg_avg_buf[ICHG_AVG_WINDOW];
+	UINT16			ichg_fill_level;
+	UINT16			ichg_ring_ptr;
+	UINT16			ichg_average;
+	UINT16			ichg_low_count;
+	UINT32			start_time;
+} T_PWR_CTRL_BLOCK;
+
+#endif	/* include guard */