mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2026-01-08 16:41:55 +00:00
This change moves vendor specific temperature ranges to battery pack files or board setup files. And added a host test case to verify that does not change x86 smart battery charging state machine behavior. BUG=chrome-os-partner:21181 BRANCH=None TEST=manual build test: util/ecmakeall.sh hosttests: make hosttests && make runtests Change-Id: I48e76826b5555f64b78e3c063ce5f02416c72aa2 Signed-off-by: Rong Chang <rongchang@chromium.org> Reviewed-on: https://gerrit.chromium.org/gerrit/62978 Reviewed-by: Vic Yang <victoryang@chromium.org>
49 lines
1.1 KiB
C
49 lines
1.1 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.
|
|
*
|
|
* Battery pack vendor provided charging profile
|
|
*/
|
|
|
|
#include "battery_pack.h"
|
|
#include "gpio.h"
|
|
|
|
/* FIXME: We need REAL values for all this stuff */
|
|
const struct battery_temperature_ranges bat_temp_ranges = {
|
|
.start_charging_min_c = 0,
|
|
.start_charging_max_c = 50,
|
|
.charging_min_c = 0,
|
|
.charging_max_c = 50,
|
|
.discharging_min_c = -20,
|
|
.discharging_max_c = 60,
|
|
};
|
|
|
|
static const struct battery_info info = {
|
|
|
|
.voltage_max = 16800,
|
|
.voltage_normal = 14800,
|
|
.voltage_min = 10800,
|
|
|
|
/* Pre-charge values. */
|
|
.precharge_current = 256, /* mA */
|
|
};
|
|
|
|
const struct battery_info *battery_get_info(void)
|
|
{
|
|
return &info;
|
|
}
|
|
|
|
/* FIXME: The smart battery should do the right thing - that's why it's
|
|
* called "smart". Do we really want to second-guess it? For now, let's not. */
|
|
void battery_vendor_params(struct batt_params *batt)
|
|
{
|
|
}
|
|
|
|
/**
|
|
* Physical detection of battery connection.
|
|
*/
|
|
int battery_is_connected(void)
|
|
{
|
|
return (gpio_get_level(GPIO_BAT_DETECT_L) == 0);
|
|
}
|