aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/power/pda_power.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/power/pda_power.c')
-rw-r--r--drivers/power/pda_power.c17
1 files changed, 8 insertions, 9 deletions
diff --git a/drivers/power/pda_power.c b/drivers/power/pda_power.c
index 4e1eb040e148..cdc28923e0ce 100644
--- a/drivers/power/pda_power.c
+++ b/drivers/power/pda_power.c
@@ -101,32 +101,31 @@ static void update_charger(void)
101 return; 101 return;
102} 102}
103 103
104static void supply_timer_func(unsigned long irq) 104static void supply_timer_func(unsigned long power_supply_ptr)
105{ 105{
106 if (ac_irq && irq == ac_irq->start) 106 void *power_supply = (void *)power_supply_ptr;
107 power_supply_changed(&pda_power_supplies[0]); 107
108 else if (usb_irq && irq == usb_irq->start) 108 power_supply_changed(power_supply);
109 power_supply_changed(&pda_power_supplies[1]);
110 return; 109 return;
111} 110}
112 111
113static void charger_timer_func(unsigned long irq) 112static void charger_timer_func(unsigned long power_supply_ptr)
114{ 113{
115 update_charger(); 114 update_charger();
116 115
117 /* Okay, charger set. Now wait a bit before notifying supplicants, 116 /* Okay, charger set. Now wait a bit before notifying supplicants,
118 * charge power should stabilize. */ 117 * charge power should stabilize. */
119 supply_timer.data = irq; 118 supply_timer.data = power_supply_ptr;
120 mod_timer(&supply_timer, 119 mod_timer(&supply_timer,
121 jiffies + msecs_to_jiffies(pdata->wait_for_charger)); 120 jiffies + msecs_to_jiffies(pdata->wait_for_charger));
122 return; 121 return;
123} 122}
124 123
125static irqreturn_t power_changed_isr(int irq, void *unused) 124static irqreturn_t power_changed_isr(int irq, void *power_supply)
126{ 125{
127 /* Wait a bit before reading ac/usb line status and setting charger, 126 /* Wait a bit before reading ac/usb line status and setting charger,
128 * because ac/usb status readings may lag from irq. */ 127 * because ac/usb status readings may lag from irq. */
129 charger_timer.data = irq; 128 charger_timer.data = (unsigned long)power_supply;
130 mod_timer(&charger_timer, 129 mod_timer(&charger_timer,
131 jiffies + msecs_to_jiffies(pdata->wait_for_status)); 130 jiffies + msecs_to_jiffies(pdata->wait_for_status));
132 return IRQ_HANDLED; 131 return IRQ_HANDLED;