diff options
author | Jens Taprogge <jens.taprogge@taprogge.org> | 2012-09-12 08:55:36 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-09-12 12:56:01 -0400 |
commit | 877adc406cc7aeb9610f32535ed61c24ff01bfe2 (patch) | |
tree | f8664091cde3b163f85002cf237a04256f0533ca | |
parent | ab0deffcb957d1e0bf8c7e1d6373b4e1587b8192 (diff) |
Staging: ipack/bridges/tpci200: More cleanups.
Rename __tpci_request_irq() to tpci_enable_irq() and __tpci_free_irq()
to tpci_disable_irq(). Change their second argument, move them above
tpci200_interrupt(), and use tpci_disable_irq() in the latter
Signed-off-by: Jens Taprogge <jens.taprogge@taprogge.org>
Signed-off-by: Samuel Iglesias Gonsalvez <siglesias@igalia.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | drivers/staging/ipack/bridges/tpci200.c | 44 |
1 files changed, 21 insertions, 23 deletions
diff --git a/drivers/staging/ipack/bridges/tpci200.c b/drivers/staging/ipack/bridges/tpci200.c index 4eaa2aaec24d..c7ec342d8efa 100644 --- a/drivers/staging/ipack/bridges/tpci200.c +++ b/drivers/staging/ipack/bridges/tpci200.c | |||
@@ -100,6 +100,22 @@ static void tpci200_unregister(struct tpci200_board *tpci200) | |||
100 | } | 100 | } |
101 | } | 101 | } |
102 | 102 | ||
103 | static void tpci200_enable_irq(struct tpci200_board *tpci200, | ||
104 | int islot) | ||
105 | { | ||
106 | tpci200_set_mask(tpci200, | ||
107 | &tpci200->info->interface_regs->control[islot], | ||
108 | TPCI200_INT0_EN | TPCI200_INT1_EN); | ||
109 | } | ||
110 | |||
111 | static void tpci200_disable_irq(struct tpci200_board *tpci200, | ||
112 | int islot) | ||
113 | { | ||
114 | tpci200_clear_mask(tpci200, | ||
115 | &tpci200->info->interface_regs->control[islot], | ||
116 | TPCI200_INT0_EN | TPCI200_INT1_EN); | ||
117 | } | ||
118 | |||
103 | static irqreturn_t tpci200_slot_irq(struct slot_irq *slot_irq) | 119 | static irqreturn_t tpci200_slot_irq(struct slot_irq *slot_irq) |
104 | { | 120 | { |
105 | irqreturn_t ret; | 121 | irqreturn_t ret; |
@@ -141,9 +157,7 @@ static irqreturn_t tpci200_interrupt(int irq, void *dev_id) | |||
141 | dev_info(&tpci200->info->pdev->dev, | 157 | dev_info(&tpci200->info->pdev->dev, |
142 | "No registered ISR for slot [%d:%d]!. IRQ will be disabled.\n", | 158 | "No registered ISR for slot [%d:%d]!. IRQ will be disabled.\n", |
143 | tpci200->number, i); | 159 | tpci200->number, i); |
144 | tpci200_clear_mask(tpci200, | 160 | tpci200_disable_irq(tpci200, i); |
145 | &tpci200->info->interface_regs->control[i], | ||
146 | TPCI200_INT0_EN | TPCI200_INT1_EN); | ||
147 | } | 161 | } |
148 | } | 162 | } |
149 | rcu_read_unlock(); | 163 | rcu_read_unlock(); |
@@ -269,23 +283,6 @@ out_disable_pci: | |||
269 | return res; | 283 | return res; |
270 | } | 284 | } |
271 | 285 | ||
272 | static int __tpci200_request_irq(struct tpci200_board *tpci200, | ||
273 | struct ipack_device *dev) | ||
274 | { | ||
275 | tpci200_set_mask(tpci200, | ||
276 | &tpci200->info->interface_regs->control[dev->slot], | ||
277 | TPCI200_INT0_EN | TPCI200_INT1_EN); | ||
278 | return 0; | ||
279 | } | ||
280 | |||
281 | static void __tpci200_free_irq(struct tpci200_board *tpci200, | ||
282 | struct ipack_device *dev) | ||
283 | { | ||
284 | tpci200_clear_mask(tpci200, | ||
285 | &tpci200->info->interface_regs->control[dev->slot], | ||
286 | TPCI200_INT0_EN | TPCI200_INT1_EN); | ||
287 | } | ||
288 | |||
289 | static int tpci200_free_irq(struct ipack_device *dev) | 286 | static int tpci200_free_irq(struct ipack_device *dev) |
290 | { | 287 | { |
291 | struct slot_irq *slot_irq; | 288 | struct slot_irq *slot_irq; |
@@ -303,8 +300,9 @@ static int tpci200_free_irq(struct ipack_device *dev) | |||
303 | return -EINVAL; | 300 | return -EINVAL; |
304 | } | 301 | } |
305 | 302 | ||
306 | __tpci200_free_irq(tpci200, dev); | 303 | tpci200_disable_irq(tpci200, dev->slot); |
307 | slot_irq = tpci200->slots[dev->slot].irq; | 304 | slot_irq = tpci200->slots[dev->slot].irq; |
305 | /* uninstall handler */ | ||
308 | RCU_INIT_POINTER(tpci200->slots[dev->slot].irq, NULL); | 306 | RCU_INIT_POINTER(tpci200->slots[dev->slot].irq, NULL); |
309 | synchronize_rcu(); | 307 | synchronize_rcu(); |
310 | kfree(slot_irq); | 308 | kfree(slot_irq); |
@@ -453,7 +451,7 @@ out_unlock: | |||
453 | static int tpci200_request_irq(struct ipack_device *dev, int vector, | 451 | static int tpci200_request_irq(struct ipack_device *dev, int vector, |
454 | int (*handler)(void *), void *arg) | 452 | int (*handler)(void *), void *arg) |
455 | { | 453 | { |
456 | int res; | 454 | int res = 0; |
457 | struct slot_irq *slot_irq; | 455 | struct slot_irq *slot_irq; |
458 | struct tpci200_board *tpci200; | 456 | struct tpci200_board *tpci200; |
459 | 457 | ||
@@ -493,7 +491,7 @@ static int tpci200_request_irq(struct ipack_device *dev, int vector, | |||
493 | slot_irq->holder = dev; | 491 | slot_irq->holder = dev; |
494 | 492 | ||
495 | rcu_assign_pointer(tpci200->slots[dev->slot].irq, slot_irq); | 493 | rcu_assign_pointer(tpci200->slots[dev->slot].irq, slot_irq); |
496 | res = __tpci200_request_irq(tpci200, dev); | 494 | tpci200_enable_irq(tpci200, dev->slot); |
497 | 495 | ||
498 | out_unlock: | 496 | out_unlock: |
499 | mutex_unlock(&tpci200->mutex); | 497 | mutex_unlock(&tpci200->mutex); |