Commit 93ff722e authored by Lee Jones's avatar Lee Jones

ab8500-fg: Add power cut feature for ab8505 and ab8540

Add support for a power cut feature which allows user to
configure when ab8505 and ab8540 based platforms should shut
down system due to low battery.
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
parent 330b7ebf
...@@ -113,6 +113,7 @@ ...@@ -113,6 +113,7 @@
#define AB8500_SWITCH_OFF_STATUS 0x00 #define AB8500_SWITCH_OFF_STATUS 0x00
#define AB8500_TURN_ON_STATUS 0x00 #define AB8500_TURN_ON_STATUS 0x00
#define AB8505_TURN_ON_STATUS_2 0x04
#define AB8500_CH_USBCH_STAT1_REG 0x02 #define AB8500_CH_USBCH_STAT1_REG 0x02
#define VBUS_DET_DBNC100 0x02 #define VBUS_DET_DBNC100 0x02
...@@ -1401,6 +1402,21 @@ static ssize_t show_turn_on_status(struct device *dev, ...@@ -1401,6 +1402,21 @@ static ssize_t show_turn_on_status(struct device *dev,
return sprintf(buf, "%#x\n", value); return sprintf(buf, "%#x\n", value);
} }
static ssize_t show_turn_on_status_2(struct device *dev,
struct device_attribute *attr, char *buf)
{
int ret;
u8 value;
struct ab8500 *ab8500;
ab8500 = dev_get_drvdata(dev);
ret = get_register_interruptible(ab8500, AB8500_SYS_CTRL1_BLOCK,
AB8505_TURN_ON_STATUS_2, &value);
if (ret < 0)
return ret;
return sprintf(buf, "%#x\n", (value & 0x1));
}
static ssize_t show_ab9540_dbbrstn(struct device *dev, static ssize_t show_ab9540_dbbrstn(struct device *dev,
struct device_attribute *attr, char *buf) struct device_attribute *attr, char *buf)
{ {
...@@ -1457,6 +1473,7 @@ static ssize_t store_ab9540_dbbrstn(struct device *dev, ...@@ -1457,6 +1473,7 @@ static ssize_t store_ab9540_dbbrstn(struct device *dev,
static DEVICE_ATTR(chip_id, S_IRUGO, show_chip_id, NULL); static DEVICE_ATTR(chip_id, S_IRUGO, show_chip_id, NULL);
static DEVICE_ATTR(switch_off_status, S_IRUGO, show_switch_off_status, NULL); static DEVICE_ATTR(switch_off_status, S_IRUGO, show_switch_off_status, NULL);
static DEVICE_ATTR(turn_on_status, S_IRUGO, show_turn_on_status, NULL); static DEVICE_ATTR(turn_on_status, S_IRUGO, show_turn_on_status, NULL);
static DEVICE_ATTR(turn_on_status_2, S_IRUGO, show_turn_on_status_2, NULL);
static DEVICE_ATTR(dbbrstn, S_IRUGO | S_IWUSR, static DEVICE_ATTR(dbbrstn, S_IRUGO | S_IWUSR,
show_ab9540_dbbrstn, store_ab9540_dbbrstn); show_ab9540_dbbrstn, store_ab9540_dbbrstn);
...@@ -1467,6 +1484,11 @@ static struct attribute *ab8500_sysfs_entries[] = { ...@@ -1467,6 +1484,11 @@ static struct attribute *ab8500_sysfs_entries[] = {
NULL, NULL,
}; };
static struct attribute *ab8505_sysfs_entries[] = {
&dev_attr_turn_on_status_2.attr,
NULL,
};
static struct attribute *ab9540_sysfs_entries[] = { static struct attribute *ab9540_sysfs_entries[] = {
&dev_attr_chip_id.attr, &dev_attr_chip_id.attr,
&dev_attr_switch_off_status.attr, &dev_attr_switch_off_status.attr,
...@@ -1479,6 +1501,10 @@ static struct attribute_group ab8500_attr_group = { ...@@ -1479,6 +1501,10 @@ static struct attribute_group ab8500_attr_group = {
.attrs = ab8500_sysfs_entries, .attrs = ab8500_sysfs_entries,
}; };
static struct attribute_group ab8505_attr_group = {
.attrs = ab8505_sysfs_entries,
};
static struct attribute_group ab9540_attr_group = { static struct attribute_group ab9540_attr_group = {
.attrs = ab9540_sysfs_entries, .attrs = ab9540_sysfs_entries,
}; };
...@@ -1719,6 +1745,12 @@ static int ab8500_probe(struct platform_device *pdev) ...@@ -1719,6 +1745,12 @@ static int ab8500_probe(struct platform_device *pdev)
else else
ret = sysfs_create_group(&ab8500->dev->kobj, ret = sysfs_create_group(&ab8500->dev->kobj,
&ab8500_attr_group); &ab8500_attr_group);
if ((is_ab8505(ab8500) || is_ab9540(ab8500)) &&
ab8500->chip_id >= AB8500_CUT2P0)
ret = sysfs_create_group(&ab8500->dev->kobj,
&ab8505_attr_group);
if (ret) if (ret)
dev_err(ab8500->dev, "error creating sysfs entries\n"); dev_err(ab8500->dev, "error creating sysfs entries\n");
...@@ -1735,6 +1767,10 @@ static int ab8500_remove(struct platform_device *pdev) ...@@ -1735,6 +1767,10 @@ static int ab8500_remove(struct platform_device *pdev)
else else
sysfs_remove_group(&ab8500->dev->kobj, &ab8500_attr_group); sysfs_remove_group(&ab8500->dev->kobj, &ab8500_attr_group);
if ((is_ab8505(ab8500) || is_ab9540(ab8500)) &&
ab8500->chip_id >= AB8500_CUT2P0)
sysfs_remove_group(&ab8500->dev->kobj, &ab8505_attr_group);
mfd_remove_devices(ab8500->dev); mfd_remove_devices(ab8500->dev);
return 0; return 0;
......
...@@ -407,6 +407,11 @@ static const struct abx500_fg_parameters fg = { ...@@ -407,6 +407,11 @@ static const struct abx500_fg_parameters fg = {
.battok_raising_th_sel1 = 2860, .battok_raising_th_sel1 = 2860,
.maint_thres = 95, .maint_thres = 95,
.user_cap_limit = 15, .user_cap_limit = 15,
.pcut_enable = 1,
.pcut_max_time = 127,
.pcut_flag_time = 112,
.pcut_max_restart = 15,
.pcut_debounce_time = 2,
}; };
static const struct abx500_maxim_parameters maxi_params = { static const struct abx500_maxim_parameters maxi_params = {
......
This diff is collapsed.
...@@ -89,6 +89,11 @@ struct abx500_fg; ...@@ -89,6 +89,11 @@ struct abx500_fg;
* points. * points.
* @maint_thres This is the threshold where we stop reporting * @maint_thres This is the threshold where we stop reporting
* battery full while in maintenance, in per cent * battery full while in maintenance, in per cent
* @pcut_enable: Enable power cut feature in ab8505
* @pcut_max_time: Max time threshold
* @pcut_flag_time: Flagtime threshold
* @pcut_max_restart: Max number of restarts
* @pcut_debounce_time: Sets battery debounce time
*/ */
struct abx500_fg_parameters { struct abx500_fg_parameters {
int recovery_sleep_timer; int recovery_sleep_timer;
...@@ -106,6 +111,11 @@ struct abx500_fg_parameters { ...@@ -106,6 +111,11 @@ struct abx500_fg_parameters {
int battok_raising_th_sel1; int battok_raising_th_sel1;
int user_cap_limit; int user_cap_limit;
int maint_thres; int maint_thres;
bool pcut_enable;
u8 pcut_max_time;
u8 pcut_flag_time;
u8 pcut_max_restart;
u8 pcut_debounce_time;
}; };
/** /**
......
...@@ -235,6 +235,14 @@ ...@@ -235,6 +235,14 @@
/* Battery type */ /* Battery type */
#define BATTERY_UNKNOWN 00 #define BATTERY_UNKNOWN 00
/* Registers for pcut feature in ab8505 and ab9540 */
#define AB8505_RTC_PCUT_CTL_STATUS_REG 0x12
#define AB8505_RTC_PCUT_TIME_REG 0x13
#define AB8505_RTC_PCUT_MAX_TIME_REG 0x14
#define AB8505_RTC_PCUT_FLAG_TIME_REG 0x15
#define AB8505_RTC_PCUT_RESTART_REG 0x16
#define AB8505_RTC_PCUT_DEBOUNCE_REG 0x17
/** /**
* struct res_to_temp - defines one point in a temp to res curve. To * struct res_to_temp - defines one point in a temp to res curve. To
* be used in battery packs that combines the identification resistor with a * be used in battery packs that combines the identification resistor with a
...@@ -283,6 +291,11 @@ struct ab8500_fg; ...@@ -283,6 +291,11 @@ struct ab8500_fg;
* points. * points.
* @maint_thres This is the threshold where we stop reporting * @maint_thres This is the threshold where we stop reporting
* battery full while in maintenance, in per cent * battery full while in maintenance, in per cent
* @pcut_enable: Enable power cut feature in ab8505
* @pcut_max_time: Max time threshold
* @pcut_flag_time: Flagtime threshold
* @pcut_max_restart: Max number of restarts
* @pcut_debunce_time: Sets battery debounce time
*/ */
struct ab8500_fg_parameters { struct ab8500_fg_parameters {
int recovery_sleep_timer; int recovery_sleep_timer;
...@@ -299,6 +312,11 @@ struct ab8500_fg_parameters { ...@@ -299,6 +312,11 @@ struct ab8500_fg_parameters {
int battok_raising_th_sel1; int battok_raising_th_sel1;
int user_cap_limit; int user_cap_limit;
int maint_thres; int maint_thres;
bool pcut_enable;
u8 pcut_max_time;
u8 pcut_flag_time;
u8 pcut_max_restart;
u8 pcut_debunce_time;
}; };
/** /**
......
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