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/gpio.h>
18 #include <linux/regulator/bq24022.h>
19 #include <linux/regulator/driver.h>
22 static int bq24022_set_current_limit(struct regulator_dev
*rdev
,
23 int min_uA
, int max_uA
)
25 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
27 dev_dbg(rdev_get_dev(rdev
), "setting current limit to %s mA\n",
28 max_uA
>= 500000 ? "500" : "100");
30 /* REVISIT: maybe return error if min_uA != 0 ? */
31 gpio_set_value(pdata
->gpio_iset2
, max_uA
>= 500000);
35 static int bq24022_get_current_limit(struct regulator_dev
*rdev
)
37 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
39 return gpio_get_value(pdata
->gpio_iset2
) ? 500000 : 100000;
42 static int bq24022_enable(struct regulator_dev
*rdev
)
44 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
46 dev_dbg(rdev_get_dev(rdev
), "enabling charger\n");
48 gpio_set_value(pdata
->gpio_nce
, 0);
52 static int bq24022_disable(struct regulator_dev
*rdev
)
54 struct bq24022_mach_info
*pdata
= rdev_get_drvdata(rdev
);
56 dev_dbg(rdev_get_dev(rdev
), "disabling charger\n");
58 gpio_set_value(pdata
->gpio_nce
, 1);
62 static int bq24022_is_enabled(struct regulator_dev
*rdev
)
64 struct platform_device
*pdev
= rdev_get_drvdata(rdev
);
65 struct bq24022_mach_info
*pdata
= pdev
->dev
.platform_data
;
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
,
84 static int __init
bq24022_probe(struct platform_device
*pdev
)
86 struct bq24022_mach_info
*pdata
= pdev
->dev
.platform_data
;
87 struct regulator_dev
*bq24022
;
90 if (!pdata
|| !pdata
->gpio_nce
|| !pdata
->gpio_iset2
)
93 ret
= gpio_request(pdata
->gpio_nce
, "ncharge_en");
95 dev_dbg(&pdev
->dev
, "couldn't request nCE GPIO: %d\n",
99 ret
= gpio_request(pdata
->gpio_iset2
, "charge_mode");
101 dev_dbg(&pdev
->dev
, "couldn't request ISET2 GPIO: %d\n",
105 ret
= gpio_direction_output(pdata
->gpio_iset2
, 0);
106 ret
= gpio_direction_output(pdata
->gpio_nce
, 1);
108 bq24022
= regulator_register(&bq24022_desc
, &pdev
->dev
,
109 pdata
->init_data
, pdata
);
110 if (IS_ERR(bq24022
)) {
111 dev_dbg(&pdev
->dev
, "couldn't register regulator\n");
112 ret
= PTR_ERR(bq24022
);
115 platform_set_drvdata(pdev
, bq24022
);
116 dev_dbg(&pdev
->dev
, "registered regulator\n");
120 gpio_free(pdata
->gpio_iset2
);
122 gpio_free(pdata
->gpio_nce
);
127 static int __devexit
bq24022_remove(struct platform_device
*pdev
)
129 struct bq24022_mach_info
*pdata
= pdev
->dev
.platform_data
;
130 struct regulator_dev
*bq24022
= platform_get_drvdata(pdev
);
132 regulator_unregister(bq24022
);
133 gpio_free(pdata
->gpio_iset2
);
134 gpio_free(pdata
->gpio_nce
);
139 static struct platform_driver bq24022_driver
= {
143 .remove
= __devexit_p(bq24022_remove
),
146 static int __init
bq24022_init(void)
148 return platform_driver_probe(&bq24022_driver
, bq24022_probe
);
151 static void __exit
bq24022_exit(void)
153 platform_driver_unregister(&bq24022_driver
);
156 module_init(bq24022_init
);
157 module_exit(bq24022_exit
);
159 MODULE_AUTHOR("Philipp Zabel");
160 MODULE_DESCRIPTION("TI bq24022 Li-Ion Charger driver");
161 MODULE_LICENSE("GPL");