Commit 01ec8c54 authored by Michel JAOUEN's avatar Michel JAOUEN Committed by Lee Jones

pm2301: Provide u9540 support for the pm2301 charger

AC charger driver for the DB9540 based platforms.
Signed-off-by: default avatarRajkumar Kasirajan <rajkumar.kasirajan@stericsson.com>
Signed-off-by: default avatarLoic Pallardy <loic.pallardy@stericsson.com>
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
Reviewed-by: default avatarMichel JAOUEN <michel.jaouen@stericsson.com>
Tested-by: default avatarMichel JAOUEN <michel.jaouen@stericsson.com>
parent 8fd526fd
...@@ -346,6 +346,13 @@ config AB8500_BM ...@@ -346,6 +346,13 @@ config AB8500_BM
help help
Say Y to include support for AB8500 battery management. Say Y to include support for AB8500 battery management.
config CHARGER_PM2301
bool "PM2301 Battery Charger Driver"
depends on AB8500_BM
help
Say Y to include support for PM2301 charger driver.
Depends on AB8500 battery management core.
source "drivers/power/reset/Kconfig" source "drivers/power/reset/Kconfig"
endif # POWER_SUPPLY endif # POWER_SUPPLY
......
...@@ -46,6 +46,7 @@ obj-$(CONFIG_CHARGER_LP8727) += lp8727_charger.o ...@@ -46,6 +46,7 @@ obj-$(CONFIG_CHARGER_LP8727) += lp8727_charger.o
obj-$(CONFIG_CHARGER_LP8788) += lp8788-charger.o obj-$(CONFIG_CHARGER_LP8788) += lp8788-charger.o
obj-$(CONFIG_CHARGER_GPIO) += gpio-charger.o obj-$(CONFIG_CHARGER_GPIO) += gpio-charger.o
obj-$(CONFIG_CHARGER_MANAGER) += charger-manager.o obj-$(CONFIG_CHARGER_MANAGER) += charger-manager.o
obj-$(CONFIG_CHARGER_PM2301) += pm2301_charger.o
obj-$(CONFIG_CHARGER_MAX8997) += max8997_charger.o obj-$(CONFIG_CHARGER_MAX8997) += max8997_charger.o
obj-$(CONFIG_CHARGER_MAX8998) += max8998_charger.o obj-$(CONFIG_CHARGER_MAX8998) += max8998_charger.o
obj-$(CONFIG_CHARGER_BQ2415X) += bq2415x_charger.o obj-$(CONFIG_CHARGER_BQ2415X) += bq2415x_charger.o
......
...@@ -2830,8 +2830,11 @@ static int ab8500_charger_remove(struct platform_device *pdev) ...@@ -2830,8 +2830,11 @@ static int ab8500_charger_remove(struct platform_device *pdev)
destroy_workqueue(di->charger_wq); destroy_workqueue(di->charger_wq);
flush_scheduled_work(); flush_scheduled_work();
power_supply_unregister(&di->usb_chg.psy); if(di->usb_chg.enabled)
power_supply_unregister(&di->ac_chg.psy); power_supply_unregister(&di->usb_chg.psy);
if(di->ac_chg.enabled)
power_supply_unregister(&di->ac_chg.psy);
platform_set_drvdata(pdev, NULL); platform_set_drvdata(pdev, NULL);
return 0; return 0;
...@@ -2899,6 +2902,7 @@ static int ab8500_charger_probe(struct platform_device *pdev) ...@@ -2899,6 +2902,7 @@ static int ab8500_charger_probe(struct platform_device *pdev)
ARRAY_SIZE(ab8500_charger_voltage_map) - 1]; ARRAY_SIZE(ab8500_charger_voltage_map) - 1];
di->ac_chg.max_out_curr = ab8500_charger_current_map[ di->ac_chg.max_out_curr = ab8500_charger_current_map[
ARRAY_SIZE(ab8500_charger_current_map) - 1]; ARRAY_SIZE(ab8500_charger_current_map) - 1];
di->ac_chg.enabled = di->pdata->ac_enabled;
/* USB supply */ /* USB supply */
/* power_supply base class */ /* power_supply base class */
...@@ -2917,7 +2921,7 @@ static int ab8500_charger_probe(struct platform_device *pdev) ...@@ -2917,7 +2921,7 @@ static int ab8500_charger_probe(struct platform_device *pdev)
ARRAY_SIZE(ab8500_charger_voltage_map) - 1]; ARRAY_SIZE(ab8500_charger_voltage_map) - 1];
di->usb_chg.max_out_curr = ab8500_charger_current_map[ di->usb_chg.max_out_curr = ab8500_charger_current_map[
ARRAY_SIZE(ab8500_charger_current_map) - 1]; ARRAY_SIZE(ab8500_charger_current_map) - 1];
di->usb_chg.enabled = di->pdata->usb_enabled;
/* Create a work queue for the charger */ /* Create a work queue for the charger */
di->charger_wq = di->charger_wq =
...@@ -2995,17 +2999,21 @@ static int ab8500_charger_probe(struct platform_device *pdev) ...@@ -2995,17 +2999,21 @@ static int ab8500_charger_probe(struct platform_device *pdev)
} }
/* Register AC charger class */ /* Register AC charger class */
ret = power_supply_register(di->dev, &di->ac_chg.psy); if(di->ac_chg.enabled) {
if (ret) { ret = power_supply_register(di->dev, &di->ac_chg.psy);
dev_err(di->dev, "failed to register AC charger\n"); if (ret) {
goto free_charger_wq; dev_err(di->dev, "failed to register AC charger\n");
goto free_charger_wq;
}
} }
/* Register USB charger class */ /* Register USB charger class */
ret = power_supply_register(di->dev, &di->usb_chg.psy); if(di->usb_chg.enabled) {
if (ret) { ret = power_supply_register(di->dev, &di->usb_chg.psy);
dev_err(di->dev, "failed to register USB charger\n"); if (ret) {
goto free_ac; dev_err(di->dev, "failed to register USB charger\n");
goto free_ac;
}
} }
di->usb_phy = usb_get_phy(USB_PHY_TYPE_USB2); di->usb_phy = usb_get_phy(USB_PHY_TYPE_USB2);
...@@ -3085,9 +3093,11 @@ static int ab8500_charger_probe(struct platform_device *pdev) ...@@ -3085,9 +3093,11 @@ static int ab8500_charger_probe(struct platform_device *pdev)
put_usb_phy: put_usb_phy:
usb_put_phy(di->usb_phy); usb_put_phy(di->usb_phy);
free_usb: free_usb:
power_supply_unregister(&di->usb_chg.psy); if(di->usb_chg.enabled)
power_supply_unregister(&di->usb_chg.psy);
free_ac: free_ac:
power_supply_unregister(&di->ac_chg.psy); if(di->ac_chg.enabled)
power_supply_unregister(&di->ac_chg.psy);
free_charger_wq: free_charger_wq:
destroy_workqueue(di->charger_wq); destroy_workqueue(di->charger_wq);
return ret; return ret;
......
This diff is collapsed.
...@@ -406,6 +406,8 @@ struct ab8500_charger_platform_data { ...@@ -406,6 +406,8 @@ struct ab8500_charger_platform_data {
char **supplied_to; char **supplied_to;
size_t num_supplicants; size_t num_supplicants;
bool autopower_cfg; bool autopower_cfg;
bool ac_enabled;
bool usb_enabled;
}; };
struct ab8500_btemp_platform_data { struct ab8500_btemp_platform_data {
......
...@@ -27,12 +27,14 @@ struct ux500_charger_ops { ...@@ -27,12 +27,14 @@ struct ux500_charger_ops {
* @ops ux500 charger operations * @ops ux500 charger operations
* @max_out_volt maximum output charger voltage in mV * @max_out_volt maximum output charger voltage in mV
* @max_out_curr maximum output charger current in mA * @max_out_curr maximum output charger current in mA
* @enabled indicates if this charger is used or not
*/ */
struct ux500_charger { struct ux500_charger {
struct power_supply psy; struct power_supply psy;
struct ux500_charger_ops ops; struct ux500_charger_ops ops;
int max_out_volt; int max_out_volt;
int max_out_curr; int max_out_curr;
bool enabled;
}; };
#endif #endif
/*
* PM2301 charger driver.
*
* Copyright (C) 2012 ST Ericsson Corporation
*
* Contact: Olivier LAUNAY (olivier.launay@stericsson.com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* version 2 as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA
*/
#ifndef __LINUX_PM2301_H
#define __LINUX_PM2301_H
/**
* struct pm2xxx_bm_charger_parameters - Charger specific parameters
* @ac_volt_max: maximum allowed AC charger voltage in mV
* @ac_curr_max: maximum allowed AC charger current in mA
*/
struct pm2xxx_bm_charger_parameters {
int ac_volt_max;
int ac_curr_max;
};
/**
* struct pm2xxx_bm_data - pm2xxx battery management data
* @enable_overshoot flag to enable VBAT overshoot control
* @chg_params charger parameters
*/
struct pm2xxx_bm_data {
bool enable_overshoot;
const struct pm2xxx_bm_charger_parameters *chg_params;
};
struct pm2xxx_charger_platform_data {
char **supplied_to;
size_t num_supplicants;
int i2c_bus;
const char *label;
int irq_number;
int irq_type;
};
struct pm2xxx_platform_data {
struct pm2xxx_charger_platform_data *wall_charger;
struct pm2xxx_bm_data *battery;
};
#endif /* __LINUX_PM2301_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment