On Wed, Dec 2, 2009 at 7:33 PM, Felipe Balbi <felipe.balbi@xxxxxxxxx> wrote: > Hi, > > On Fri, Nov 27, 2009 at 03:44:20PM +0100, ext Grazvydas Ignotas wrote: >> >> diff --git a/drivers/power/Makefile b/drivers/power/Makefile >> index b96f29d..9cea9b5 100644 >> --- a/drivers/power/Makefile >> +++ b/drivers/power/Makefile >> @@ -29,3 +29,4 @@ obj-$(CONFIG_BATTERY_BQ27x00) += bq27x00_battery.o >> obj-$(CONFIG_BATTERY_DA9030) += da9030_battery.o >> obj-$(CONFIG_BATTERY_MAX17040) += max17040_battery.o >> obj-$(CONFIG_CHARGER_PCF50633) += pcf50633-charger.o >> +obj-$(CONFIG_CHARGER_TWL4030) += twl4030_charger.o >> diff --git a/drivers/power/twl4030_charger.c >> b/drivers/power/twl4030_charger.c >> new file mode 100644 >> index 0000000..604dd56 >> --- /dev/null >> +++ b/drivers/power/twl4030_charger.c >> @@ -0,0 +1,499 @@ >> +/* >> + * TWL4030/TPS65950 BCI (Battery Charger Interface) driver >> + * >> + * Copyright (C) 2009 Gražvydas Ignotas <notasas@xxxxxxxxx> >> + * >> + * based on twl4030_bci_battery.c by TI >> + * Copyright (C) 2008 Texas Instruments, Inc. >> + * >> + * This program is free software; you can redistribute it and/or modify >> + * it under the terms of the GNU General Public License as published by >> + * the Free Software Foundation; either version 2 of the License, or >> + * (at your option) any later version. >> + */ >> + >> +#include <linux/init.h> >> +#include <linux/module.h> >> +#include <linux/platform_device.h> >> +#include <linux/interrupt.h> >> +#include <linux/i2c/twl4030.h> >> +#include <linux/power_supply.h> >> + >> +#define REG_BCIMSTATEC 0x02 > > please prepend these defines with e.g. TWL4030_BCI_ > > this would look like: > > #define TWL4030_BCI_MSTATEC 0x02 ok <snip> >> + >> +#define BCI_DELAY 100 > > 100ms ??? that's too quick for battery monitoring. Imagine that you'll have > 10 i2c transfers per-second forever with this one. Don't you think you're > waking up omap for nothing ?? The work item doesn't queue itself, so this is only used once after every interrupt. The delay itself is needed because charge state machine needs some time to switch states and is not yet in expected state at the time VBUS/AC detect interrupt kicks. > something like 1 second when doing heavy operation should be enough and 5 to > 10 seconds in idle is good enough as well. > >> +static struct twl4030_bci_device_info twl4030_bci = { > > this should be allocated on probe() time. I need to access it from twl4030charger_usb_en().. Could only leave delayed_work global and allocate everything else in probe() if you prefer that. > >> +/* >> + * called by TWL4030 USB transceiver driver on USB_PRES interrupt. >> + */ >> +int twl4030charger_usb_en(int enable) >> +{ >> + if (twl4030_bci.started) >> + schedule_delayed_work(&twl4030_bci.bat_work, >> + msecs_to_jiffies(BCI_DELAY)); > > I don't like the way you did this. I would expect twl4030-usb to kick the > charger detection based on the VBUS irq. You have to consider the > possibility of boards which won't use BCI module and will have some bq24xxx > chip dealing with that like RX51. So instead of implementing this here and > forcing people to have this driver enabled on e.g. RX51, you should > implement the charger_enable_usb() logic in twl4030-usb itself. /me thinks I don't think charging is twl4030-usb's business, also notifying power_supply core about charge state changes that I do here. What about just returning early from twl4030charger_usb_en() if this driver is not started? TWL4030-core requires twl4030_bci_platform_data to be present to even register this driver, so it won't start on RX51. RX51 can also choose not to compile this driver in, then twl4030charger_usb_en() call won't even be done fom twl4030-usb. > >> +static int __devinit twl4030_bci_probe(struct platform_device *pdev) >> +{ >> + int irq; >> + int ret; >> + >> + twl4030_charger_enable_ac(true); >> + twl4030_charger_enable_usb(true); >> + >> + irq = platform_get_irq(pdev, 0); >> + >> + /* CHG_PRES irq */ >> + ret = request_irq(irq, twl4030_charger_interrupt, >> + 0, pdev->name, &twl4030_bci); > > how about using request_threaded_irq() ?? then you avoid having that > workqueue. I need to do some delayed processing after VBUS/AC detect interrupts kick, delayed_work looked perfect for this. Also note that I can't get USB_PRES interrupt (taken by twl4030-usb), only a callback from twl4030-usb. > > -- > balbi > -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html