mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-06 05:06:29 +00:00
power: supply: generic-adc-battery: use simple-battery API
Constant battery data is available through power-supply's simple-battery API. This works automatically, so the manual handling can be removed without loosing any feature :) Note, that the POWER_SUPPLY_STATUS_FULL check for the level variable can be dropped, since the variable is never written. It can be re-introduced properly once the driver gets functionality to calculate the current charge level. Apart from that the check must be done fuzzy anyways, since charge estimation usually is not precise enough to always return exactly the full charge capacity for a full battery. Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Reviewed-by: Matti Vaittinen <mazziesaccount@gmail.com> Signed-off-by: Sebastian Reichel <sre@kernel.org>
This commit is contained in:
parent
2f25b9750f
commit
1b27bf793f
@ -22,7 +22,6 @@
|
||||
#include <linux/slab.h>
|
||||
#include <linux/iio/consumer.h>
|
||||
#include <linux/iio/types.h>
|
||||
#include <linux/power/generic-adc-battery.h>
|
||||
#include <linux/devm-helpers.h>
|
||||
|
||||
#define JITTER_DEFAULT 10 /* hope 10ms is enough */
|
||||
@ -48,9 +47,7 @@ struct gab {
|
||||
struct power_supply *psy;
|
||||
struct power_supply_desc psy_desc;
|
||||
struct iio_channel *channel[GAB_MAX_CHAN_TYPE];
|
||||
struct gab_platform_data *pdata;
|
||||
struct delayed_work bat_work;
|
||||
int level;
|
||||
int status;
|
||||
bool cable_plugged;
|
||||
struct gpio_desc *charge_finished;
|
||||
@ -70,14 +67,6 @@ static void gab_ext_power_changed(struct power_supply *psy)
|
||||
|
||||
static const enum power_supply_property gab_props[] = {
|
||||
POWER_SUPPLY_PROP_STATUS,
|
||||
POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN,
|
||||
POWER_SUPPLY_PROP_CHARGE_EMPTY_DESIGN,
|
||||
POWER_SUPPLY_PROP_VOLTAGE_NOW,
|
||||
POWER_SUPPLY_PROP_CURRENT_NOW,
|
||||
POWER_SUPPLY_PROP_TECHNOLOGY,
|
||||
POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN,
|
||||
POWER_SUPPLY_PROP_VOLTAGE_MAX_DESIGN,
|
||||
POWER_SUPPLY_PROP_MODEL_NAME,
|
||||
};
|
||||
|
||||
/*
|
||||
@ -97,17 +86,6 @@ static bool gab_charge_finished(struct gab *adc_bat)
|
||||
return gpiod_get_value(adc_bat->charge_finished);
|
||||
}
|
||||
|
||||
static int gab_get_status(struct gab *adc_bat)
|
||||
{
|
||||
struct gab_platform_data *pdata = adc_bat->pdata;
|
||||
struct power_supply_info *bat_info;
|
||||
|
||||
bat_info = &pdata->battery_info;
|
||||
if (adc_bat->level == bat_info->charge_full_design)
|
||||
return POWER_SUPPLY_STATUS_FULL;
|
||||
return adc_bat->status;
|
||||
}
|
||||
|
||||
static enum gab_chan_type gab_prop_to_chan(enum power_supply_property psp)
|
||||
{
|
||||
switch (psp) {
|
||||
@ -144,27 +122,14 @@ static int read_channel(struct gab *adc_bat, enum power_supply_property psp,
|
||||
static int gab_get_property(struct power_supply *psy,
|
||||
enum power_supply_property psp, union power_supply_propval *val)
|
||||
{
|
||||
struct gab *adc_bat;
|
||||
struct gab_platform_data *pdata;
|
||||
struct power_supply_info *bat_info;
|
||||
struct gab *adc_bat = to_generic_bat(psy);
|
||||
int result = 0;
|
||||
int ret = 0;
|
||||
|
||||
adc_bat = to_generic_bat(psy);
|
||||
if (!adc_bat) {
|
||||
dev_err(&psy->dev, "no battery infos ?!\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
pdata = adc_bat->pdata;
|
||||
bat_info = &pdata->battery_info;
|
||||
|
||||
switch (psp) {
|
||||
case POWER_SUPPLY_PROP_STATUS:
|
||||
val->intval = gab_get_status(adc_bat);
|
||||
break;
|
||||
case POWER_SUPPLY_PROP_CHARGE_EMPTY_DESIGN:
|
||||
val->intval = 0;
|
||||
break;
|
||||
val->intval = adc_bat->status;
|
||||
return 0;
|
||||
case POWER_SUPPLY_PROP_VOLTAGE_NOW:
|
||||
case POWER_SUPPLY_PROP_CURRENT_NOW:
|
||||
case POWER_SUPPLY_PROP_POWER_NOW:
|
||||
@ -173,21 +138,6 @@ static int gab_get_property(struct power_supply *psy,
|
||||
goto err;
|
||||
val->intval = result;
|
||||
break;
|
||||
case POWER_SUPPLY_PROP_TECHNOLOGY:
|
||||
val->intval = bat_info->technology;
|
||||
break;
|
||||
case POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN:
|
||||
val->intval = bat_info->voltage_min_design;
|
||||
break;
|
||||
case POWER_SUPPLY_PROP_VOLTAGE_MAX_DESIGN:
|
||||
val->intval = bat_info->voltage_max_design;
|
||||
break;
|
||||
case POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN:
|
||||
val->intval = bat_info->charge_full_design;
|
||||
break;
|
||||
case POWER_SUPPLY_PROP_MODEL_NAME:
|
||||
val->strval = bat_info->name;
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
@ -235,7 +185,6 @@ static int gab_probe(struct platform_device *pdev)
|
||||
struct gab *adc_bat;
|
||||
struct power_supply_desc *psy_desc;
|
||||
struct power_supply_config psy_cfg = {};
|
||||
struct gab_platform_data *pdata = pdev->dev.platform_data;
|
||||
enum power_supply_property *properties;
|
||||
int ret = 0;
|
||||
int chan;
|
||||
@ -248,7 +197,7 @@ static int gab_probe(struct platform_device *pdev)
|
||||
|
||||
psy_cfg.drv_data = adc_bat;
|
||||
psy_desc = &adc_bat->psy_desc;
|
||||
psy_desc->name = pdata->battery_info.name;
|
||||
psy_desc->name = dev_name(&pdev->dev);
|
||||
|
||||
/* bootup default values for the battery */
|
||||
adc_bat->cable_plugged = false;
|
||||
@ -256,7 +205,6 @@ static int gab_probe(struct platform_device *pdev)
|
||||
psy_desc->type = POWER_SUPPLY_TYPE_BATTERY;
|
||||
psy_desc->get_property = gab_get_property;
|
||||
psy_desc->external_power_changed = gab_ext_power_changed;
|
||||
adc_bat->pdata = pdata;
|
||||
|
||||
/*
|
||||
* copying the static properties and allocating extra memory for holding
|
||||
|
@ -1,18 +0,0 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
/*
|
||||
* Copyright (C) 2012, Anish Kumar <anish198519851985@gmail.com>
|
||||
*/
|
||||
|
||||
#ifndef GENERIC_ADC_BATTERY_H
|
||||
#define GENERIC_ADC_BATTERY_H
|
||||
|
||||
/**
|
||||
* struct gab_platform_data - platform_data for generic adc iio battery driver.
|
||||
* @battery_info: recommended structure to specify static power supply
|
||||
* parameters
|
||||
*/
|
||||
struct gab_platform_data {
|
||||
struct power_supply_info battery_info;
|
||||
};
|
||||
|
||||
#endif /* GENERIC_ADC_BATTERY_H */
|
Loading…
Reference in New Issue
Block a user