mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2026-01-02 21:25:03 +00:00
Only link actually used this function, but all batteries were required to provide an (empty) implementation. Use CONFIG_BATTERY_VENDOR_PARAMS to gate this functionality, so non-link battery code can be simpler. BUG=chrome-os-partner:18343 BRANCH=none TEST=build all platforms and pass unit tests Change-Id: Ic2c6dd1163a981e48873d798f77891cc7de1f8cf Signed-off-by: Randall Spangler <rspangler@chromium.org> Reviewed-on: https://gerrit.chromium.org/gerrit/65257 Reviewed-by: Bill Richardson <wfrichar@chromium.org> Reviewed-by: Rong Chang <rongchang@chromium.org>
67 lines
1.8 KiB
C
67 lines
1.8 KiB
C
/* Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*
|
|
* Common API for battery pack vendor provided charging profile
|
|
*/
|
|
#ifndef __CROS_EC_BATTERY_PACK_H
|
|
#define __CROS_EC_BATTERY_PACK_H
|
|
|
|
#include "common.h"
|
|
|
|
/* Battery parameters */
|
|
struct batt_params {
|
|
int temperature; /* Temperature in 0.1 K */
|
|
int state_of_charge; /* State of charge (percent, 0-100) */
|
|
int voltage; /* Battery voltage (mV) */
|
|
int current; /* Battery current (mA) */
|
|
int desired_voltage; /* Charging voltage desired by battery (mV) */
|
|
int desired_current; /* Charging current desired by battery (mA) */
|
|
};
|
|
|
|
/* Working temperature ranges in degrees C */
|
|
struct battery_temperature_ranges {
|
|
int8_t start_charging_min_c;
|
|
int8_t start_charging_max_c;
|
|
int8_t charging_min_c;
|
|
int8_t charging_max_c;
|
|
int8_t discharging_min_c;
|
|
int8_t discharging_max_c;
|
|
};
|
|
extern const struct battery_temperature_ranges bat_temp_ranges;
|
|
|
|
/* Battery constants */
|
|
struct battery_info {
|
|
/* Design voltage in mV */
|
|
int voltage_max;
|
|
int voltage_normal;
|
|
int voltage_min;
|
|
/* Pre-charge current in mA */
|
|
int precharge_current;
|
|
};
|
|
|
|
/**
|
|
* Return vendor-provided battery constants.
|
|
*/
|
|
const struct battery_info *battery_get_info(void);
|
|
|
|
#ifdef CONFIG_BATTERY_VENDOR_PARAMS
|
|
/**
|
|
* Modify battery parameters to match vendor charging profile.
|
|
*
|
|
* @param batt Battery parameters to modify
|
|
*/
|
|
void battery_vendor_params(struct batt_params *batt);
|
|
#endif
|
|
|
|
#ifdef CONFIG_BATTERY_CHECK_CONNECTED
|
|
/**
|
|
* Attempt communication with the battery.
|
|
*
|
|
* @return non-zero if the battery responds.
|
|
*/
|
|
int battery_is_connected(void);
|
|
#endif /* CONFIG_BATTERY_CHECK_CONNECTED */
|
|
|
|
#endif /* __CROS_EC_BATTERY_PACK_H */
|