diff options
Diffstat (limited to 'kernel/irq/autoprobe.c')
| -rw-r--r-- | kernel/irq/autoprobe.c | 43 |
1 files changed, 16 insertions, 27 deletions
diff --git a/kernel/irq/autoprobe.c b/kernel/irq/autoprobe.c index 533068cfb60..cc0f7321b8c 100644 --- a/kernel/irq/autoprobe.c +++ b/kernel/irq/autoprobe.c | |||
| @@ -30,17 +30,16 @@ static DEFINE_MUTEX(probing_active); | |||
| 30 | unsigned long probe_irq_on(void) | 30 | unsigned long probe_irq_on(void) |
| 31 | { | 31 | { |
| 32 | struct irq_desc *desc; | 32 | struct irq_desc *desc; |
| 33 | unsigned long mask; | 33 | unsigned long mask = 0; |
| 34 | unsigned int i; | 34 | unsigned int status; |
| 35 | int i; | ||
| 35 | 36 | ||
| 36 | mutex_lock(&probing_active); | 37 | mutex_lock(&probing_active); |
| 37 | /* | 38 | /* |
| 38 | * something may have generated an irq long ago and we want to | 39 | * something may have generated an irq long ago and we want to |
| 39 | * flush such a longstanding irq before considering it as spurious. | 40 | * flush such a longstanding irq before considering it as spurious. |
| 40 | */ | 41 | */ |
| 41 | for (i = NR_IRQS-1; i > 0; i--) { | 42 | for_each_irq_desc_reverse(i, desc) { |
| 42 | desc = irq_desc + i; | ||
| 43 | |||
| 44 | spin_lock_irq(&desc->lock); | 43 | spin_lock_irq(&desc->lock); |
| 45 | if (!desc->action && !(desc->status & IRQ_NOPROBE)) { | 44 | if (!desc->action && !(desc->status & IRQ_NOPROBE)) { |
| 46 | /* | 45 | /* |
| @@ -68,9 +67,7 @@ unsigned long probe_irq_on(void) | |||
| 68 | * (we must startup again here because if a longstanding irq | 67 | * (we must startup again here because if a longstanding irq |
| 69 | * happened in the previous stage, it may have masked itself) | 68 | * happened in the previous stage, it may have masked itself) |
| 70 | */ | 69 | */ |
| 71 | for (i = NR_IRQS-1; i > 0; i--) { | 70 | for_each_irq_desc_reverse(i, desc) { |
| 72 | desc = irq_desc + i; | ||
| 73 | |||
| 74 | spin_lock_irq(&desc->lock); | 71 | spin_lock_irq(&desc->lock); |
| 75 | if (!desc->action && !(desc->status & IRQ_NOPROBE)) { | 72 | if (!desc->action && !(desc->status & IRQ_NOPROBE)) { |
| 76 | desc->status |= IRQ_AUTODETECT | IRQ_WAITING; | 73 | desc->status |= IRQ_AUTODETECT | IRQ_WAITING; |
| @@ -88,11 +85,7 @@ unsigned long probe_irq_on(void) | |||
| 88 | /* | 85 | /* |
| 89 | * Now filter out any obviously spurious interrupts | 86 | * Now filter out any obviously spurious interrupts |
| 90 | */ | 87 | */ |
| 91 | mask = 0; | 88 | for_each_irq_desc(i, desc) { |
| 92 | for (i = 0; i < NR_IRQS; i++) { | ||
| 93 | unsigned int status; | ||
| 94 | |||
| 95 | desc = irq_desc + i; | ||
| 96 | spin_lock_irq(&desc->lock); | 89 | spin_lock_irq(&desc->lock); |
| 97 | status = desc->status; | 90 | status = desc->status; |
| 98 | 91 | ||
| @@ -126,14 +119,11 @@ EXPORT_SYMBOL(probe_irq_on); | |||
| 126 | */ | 119 | */ |
| 127 | unsigned int probe_irq_mask(unsigned long val) | 120 | unsigned int probe_irq_mask(unsigned long val) |
| 128 | { | 121 | { |
| 129 | unsigned int mask; | 122 | unsigned int status, mask = 0; |
| 123 | struct irq_desc *desc; | ||
| 130 | int i; | 124 | int i; |
| 131 | 125 | ||
| 132 | mask = 0; | 126 | for_each_irq_desc(i, desc) { |
| 133 | for (i = 0; i < NR_IRQS; i++) { | ||
| 134 | struct irq_desc *desc = irq_desc + i; | ||
| 135 | unsigned int status; | ||
| 136 | |||
| 137 | spin_lock_irq(&desc->lock); | 127 | spin_lock_irq(&desc->lock); |
| 138 | status = desc->status; | 128 | status = desc->status; |
| 139 | 129 | ||
| @@ -171,20 +161,19 @@ EXPORT_SYMBOL(probe_irq_mask); | |||
| 171 | */ | 161 | */ |
| 172 | int probe_irq_off(unsigned long val) | 162 | int probe_irq_off(unsigned long val) |
| 173 | { | 163 | { |
| 174 | int i, irq_found = 0, nr_irqs = 0; | 164 | int i, irq_found = 0, nr_of_irqs = 0; |
| 175 | 165 | struct irq_desc *desc; | |
| 176 | for (i = 0; i < NR_IRQS; i++) { | 166 | unsigned int status; |
| 177 | struct irq_desc *desc = irq_desc + i; | ||
| 178 | unsigned int status; | ||
| 179 | 167 | ||
| 168 | for_each_irq_desc(i, desc) { | ||
| 180 | spin_lock_irq(&desc->lock); | 169 | spin_lock_irq(&desc->lock); |
| 181 | status = desc->status; | 170 | status = desc->status; |
| 182 | 171 | ||
| 183 | if (status & IRQ_AUTODETECT) { | 172 | if (status & IRQ_AUTODETECT) { |
| 184 | if (!(status & IRQ_WAITING)) { | 173 | if (!(status & IRQ_WAITING)) { |
| 185 | if (!nr_irqs) | 174 | if (!nr_of_irqs) |
| 186 | irq_found = i; | 175 | irq_found = i; |
| 187 | nr_irqs++; | 176 | nr_of_irqs++; |
| 188 | } | 177 | } |
| 189 | desc->status = status & ~IRQ_AUTODETECT; | 178 | desc->status = status & ~IRQ_AUTODETECT; |
| 190 | desc->chip->shutdown(i); | 179 | desc->chip->shutdown(i); |
| @@ -193,7 +182,7 @@ int probe_irq_off(unsigned long val) | |||
| 193 | } | 182 | } |
| 194 | mutex_unlock(&probing_active); | 183 | mutex_unlock(&probing_active); |
| 195 | 184 | ||
| 196 | if (nr_irqs > 1) | 185 | if (nr_of_irqs > 1) |
| 197 | irq_found = -irq_found; | 186 | irq_found = -irq_found; |
| 198 | 187 | ||
| 199 | return irq_found; | 188 | return irq_found; |
