2 * Support for TI bq24022 (bqTINY-II) Dual Input (USB/AC Adpater)
3 * 1-Cell Li-Ion Charger connected via GPIOs.
5 * Copyright (c) 2008 Philipp Zabel
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
13 #include <linux/kernel.h>
14 #include <linux/init.h>
15 #include <linux/platform_device.h>
16 #include <linux/err.h>
17 #include <linux/module.h>
18 #include <linux/gpio.h>
19 #include <linux/regulator/bq24022.h>
20 #include <linux/regulator/driver.h>
23 static int bq24022_set_current_limit(struct regulator_dev
*rdev
,
24 int min_uA
, int max_uA
)
26 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
28 dev_dbg(rdev_get_dev(rdev
), "setting current limit to %s mA\n",
29 max_uA
>= 500000 ? "500" : "100");
31 /* REVISIT: maybe return error if min_uA != 0 ? */
32 gpio_set_value(pdata
->gpio_iset2
, max_uA
>= 500000);
36 static int bq24022_get_current_limit(struct regulator_dev
*rdev
)
38 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
40 return gpio_get_value(pdata
->gpio_iset2
) ? 500000 : 100000;
43 static int bq24022_enable(struct regulator_dev
*rdev
)
45 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
47 dev_dbg(rdev_get_dev(rdev
), "enabling charger\n");
49 gpio_set_value(pdata
->gpio_nce
, 0);
53 static int bq24022_disable(struct regulator_dev
*rdev
)
55 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
57 dev_dbg(rdev_get_dev(rdev
), "disabling charger\n");
59 gpio_set_value(pdata
->gpio_nce
, 1);
63 static int bq24022_is_enabled(struct regulator_dev
*rdev
)
65 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
67 return !gpio_get_value(pdata
->gpio_nce
);
70 static struct regulator_ops bq24022_ops
= {
71 .set_current_limit
= bq24022_set_current_limit
,
72 .get_current_limit
= bq24022_get_current_limit
,
73 .enable
= bq24022_enable
,
74 .disable
= bq24022_disable
,
75 .is_enabled
= bq24022_is_enabled
,
78 static struct regulator_desc bq24022_desc
= {
81 .type
= REGULATOR_CURRENT
,
85 static int __init
bq24022_probe(struct platform_device
*pdev
)
87 struct bq24022_mach_info
*pdata
= pdev
->dev
.platform_data
;
88 struct regulator_dev
*bq24022
;
91 if (!pdata
|| !pdata
->gpio_nce
|| !pdata
->gpio_iset2
)
94 ret
= gpio_request(pdata
->gpio_nce
, "ncharge_en");
96 dev_dbg(&pdev
->dev
, "couldn't request nCE GPIO: %d\n",
100 ret
= gpio_request(pdata
->gpio_iset2
, "charge_mode");
102 dev_dbg(&pdev
->dev
, "couldn't request ISET2 GPIO: %d\n",
106 ret
= gpio_direction_output(pdata
->gpio_iset2
, 0);
107 ret
= gpio_direction_output(pdata
->gpio_nce
, 1);
109 bq24022
= regulator_register(&bq24022_desc
, &pdev
->dev
,
110 pdata
->init_data
, pdata
);
111 if (IS_ERR(bq24022
)) {
112 dev_dbg(&pdev
->dev
, "couldn't register regulator\n");
113 ret
= PTR_ERR(bq24022
);
116 platform_set_drvdata(pdev
, bq24022
);
117 dev_dbg(&pdev
->dev
, "registered regulator\n");
121 gpio_free(pdata
->gpio_iset2
);
123 gpio_free(pdata
->gpio_nce
);
128 static int __devexit
bq24022_remove(struct platform_device
*pdev
)
130 struct bq24022_mach_info
*pdata
= pdev
->dev
.platform_data
;
131 struct regulator_dev
*bq24022
= platform_get_drvdata(pdev
);
133 regulator_unregister(bq24022
);
134 gpio_free(pdata
->gpio_iset2
);
135 gpio_free(pdata
->gpio_nce
);
140 static struct platform_driver bq24022_driver
= {
144 .remove
= __devexit_p(bq24022_remove
),
147 static int __init
bq24022_init(void)
149 return platform_driver_probe(&bq24022_driver
, bq24022_probe
);
152 static void __exit
bq24022_exit(void)
154 platform_driver_unregister(&bq24022_driver
);
157 module_init(bq24022_init
);
158 module_exit(bq24022_exit
);
160 MODULE_AUTHOR("Philipp Zabel");
161 MODULE_DESCRIPTION("TI bq24022 Li-Ion Charger driver");
162 MODULE_LICENSE("GPL");