diff options
author | Lennert Buytenhek <buytenh@wantstofly.org> | 2011-01-12 20:00:18 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-01-13 11:03:14 -0500 |
commit | 673860c107d3adc3fb0c85d7b4c86f551e75dc01 (patch) | |
tree | b76637b526b9b3b8d1c842d38a10874fada05af5 | |
parent | 2a866f39146a5613d5c2db9031c13c218a4c7402 (diff) |
gpio: sx150x: irq_data conversion
Converts irq_chips and flow handlers over to the new struct irq_data based
irq_chip functions.
Signed-off-by: Lennert Buytenhek <buytenh@secretlab.ca>
Cc: Gregory Bean <gbean@codeaurora.org>
Tested-by: Rohit Vaswani <rvaswani@codeaurora.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | drivers/gpio/sx150x.c | 46 |
1 files changed, 23 insertions, 23 deletions
diff --git a/drivers/gpio/sx150x.c b/drivers/gpio/sx150x.c index 823559ab0e24..e60be0015c9b 100644 --- a/drivers/gpio/sx150x.c +++ b/drivers/gpio/sx150x.c | |||
@@ -304,36 +304,36 @@ static int sx150x_gpio_to_irq(struct gpio_chip *gc, unsigned offset) | |||
304 | return chip->irq_base + offset; | 304 | return chip->irq_base + offset; |
305 | } | 305 | } |
306 | 306 | ||
307 | static void sx150x_irq_mask(unsigned int irq) | 307 | static void sx150x_irq_mask(struct irq_data *d) |
308 | { | 308 | { |
309 | struct irq_chip *ic = get_irq_chip(irq); | 309 | struct irq_chip *ic = irq_data_get_irq_chip(d); |
310 | struct sx150x_chip *chip; | 310 | struct sx150x_chip *chip; |
311 | unsigned n; | 311 | unsigned n; |
312 | 312 | ||
313 | chip = container_of(ic, struct sx150x_chip, irq_chip); | 313 | chip = container_of(ic, struct sx150x_chip, irq_chip); |
314 | n = irq - chip->irq_base; | 314 | n = d->irq - chip->irq_base; |
315 | 315 | ||
316 | sx150x_write_cfg(chip, n, 1, chip->dev_cfg->reg_irq_mask, 1); | 316 | sx150x_write_cfg(chip, n, 1, chip->dev_cfg->reg_irq_mask, 1); |
317 | sx150x_write_cfg(chip, n, 2, chip->dev_cfg->reg_sense, 0); | 317 | sx150x_write_cfg(chip, n, 2, chip->dev_cfg->reg_sense, 0); |
318 | } | 318 | } |
319 | 319 | ||
320 | static void sx150x_irq_unmask(unsigned int irq) | 320 | static void sx150x_irq_unmask(struct irq_data *d) |
321 | { | 321 | { |
322 | struct irq_chip *ic = get_irq_chip(irq); | 322 | struct irq_chip *ic = irq_data_get_irq_chip(d); |
323 | struct sx150x_chip *chip; | 323 | struct sx150x_chip *chip; |
324 | unsigned n; | 324 | unsigned n; |
325 | 325 | ||
326 | chip = container_of(ic, struct sx150x_chip, irq_chip); | 326 | chip = container_of(ic, struct sx150x_chip, irq_chip); |
327 | n = irq - chip->irq_base; | 327 | n = d->irq - chip->irq_base; |
328 | 328 | ||
329 | sx150x_write_cfg(chip, n, 1, chip->dev_cfg->reg_irq_mask, 0); | 329 | sx150x_write_cfg(chip, n, 1, chip->dev_cfg->reg_irq_mask, 0); |
330 | sx150x_write_cfg(chip, n, 2, chip->dev_cfg->reg_sense, | 330 | sx150x_write_cfg(chip, n, 2, chip->dev_cfg->reg_sense, |
331 | chip->irq_sense >> (n * 2)); | 331 | chip->irq_sense >> (n * 2)); |
332 | } | 332 | } |
333 | 333 | ||
334 | static int sx150x_irq_set_type(unsigned int irq, unsigned int flow_type) | 334 | static int sx150x_irq_set_type(struct irq_data *d, unsigned int flow_type) |
335 | { | 335 | { |
336 | struct irq_chip *ic = get_irq_chip(irq); | 336 | struct irq_chip *ic = irq_data_get_irq_chip(d); |
337 | struct sx150x_chip *chip; | 337 | struct sx150x_chip *chip; |
338 | unsigned n, val = 0; | 338 | unsigned n, val = 0; |
339 | 339 | ||
@@ -341,7 +341,7 @@ static int sx150x_irq_set_type(unsigned int irq, unsigned int flow_type) | |||
341 | return -EINVAL; | 341 | return -EINVAL; |
342 | 342 | ||
343 | chip = container_of(ic, struct sx150x_chip, irq_chip); | 343 | chip = container_of(ic, struct sx150x_chip, irq_chip); |
344 | n = irq - chip->irq_base; | 344 | n = d->irq - chip->irq_base; |
345 | 345 | ||
346 | if (flow_type & IRQ_TYPE_EDGE_RISING) | 346 | if (flow_type & IRQ_TYPE_EDGE_RISING) |
347 | val |= 0x1; | 347 | val |= 0x1; |
@@ -386,9 +386,9 @@ static irqreturn_t sx150x_irq_thread_fn(int irq, void *dev_id) | |||
386 | return (nhandled > 0 ? IRQ_HANDLED : IRQ_NONE); | 386 | return (nhandled > 0 ? IRQ_HANDLED : IRQ_NONE); |
387 | } | 387 | } |
388 | 388 | ||
389 | static void sx150x_irq_bus_lock(unsigned int irq) | 389 | static void sx150x_irq_bus_lock(struct irq_data *d) |
390 | { | 390 | { |
391 | struct irq_chip *ic = get_irq_chip(irq); | 391 | struct irq_chip *ic = irq_data_get_irq_chip(d); |
392 | struct sx150x_chip *chip; | 392 | struct sx150x_chip *chip; |
393 | 393 | ||
394 | chip = container_of(ic, struct sx150x_chip, irq_chip); | 394 | chip = container_of(ic, struct sx150x_chip, irq_chip); |
@@ -396,9 +396,9 @@ static void sx150x_irq_bus_lock(unsigned int irq) | |||
396 | mutex_lock(&chip->lock); | 396 | mutex_lock(&chip->lock); |
397 | } | 397 | } |
398 | 398 | ||
399 | static void sx150x_irq_bus_sync_unlock(unsigned int irq) | 399 | static void sx150x_irq_bus_sync_unlock(struct irq_data *d) |
400 | { | 400 | { |
401 | struct irq_chip *ic = get_irq_chip(irq); | 401 | struct irq_chip *ic = irq_data_get_irq_chip(d); |
402 | struct sx150x_chip *chip; | 402 | struct sx150x_chip *chip; |
403 | unsigned n; | 403 | unsigned n; |
404 | 404 | ||
@@ -437,16 +437,16 @@ static void sx150x_init_chip(struct sx150x_chip *chip, | |||
437 | if (pdata->oscio_is_gpo) | 437 | if (pdata->oscio_is_gpo) |
438 | ++chip->gpio_chip.ngpio; | 438 | ++chip->gpio_chip.ngpio; |
439 | 439 | ||
440 | chip->irq_chip.name = client->name; | 440 | chip->irq_chip.name = client->name; |
441 | chip->irq_chip.mask = sx150x_irq_mask; | 441 | chip->irq_chip.irq_mask = sx150x_irq_mask; |
442 | chip->irq_chip.unmask = sx150x_irq_unmask; | 442 | chip->irq_chip.irq_unmask = sx150x_irq_unmask; |
443 | chip->irq_chip.set_type = sx150x_irq_set_type; | 443 | chip->irq_chip.irq_set_type = sx150x_irq_set_type; |
444 | chip->irq_chip.bus_lock = sx150x_irq_bus_lock; | 444 | chip->irq_chip.irq_bus_lock = sx150x_irq_bus_lock; |
445 | chip->irq_chip.bus_sync_unlock = sx150x_irq_bus_sync_unlock; | 445 | chip->irq_chip.irq_bus_sync_unlock = sx150x_irq_bus_sync_unlock; |
446 | chip->irq_summary = -1; | 446 | chip->irq_summary = -1; |
447 | chip->irq_base = -1; | 447 | chip->irq_base = -1; |
448 | chip->irq_sense = 0; | 448 | chip->irq_sense = 0; |
449 | chip->irq_set_type_pending = 0; | 449 | chip->irq_set_type_pending = 0; |
450 | } | 450 | } |
451 | 451 | ||
452 | static int sx150x_init_io(struct sx150x_chip *chip, u8 base, u16 cfg) | 452 | static int sx150x_init_io(struct sx150x_chip *chip, u8 base, u16 cfg) |