Thomas Gleixner | 1621633 | 2019-05-19 15:51:31 +0200 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0-or-later |
Peter Horton | cdc3f10 | 2010-12-06 11:37:38 +0000 | [diff] [blame] | 2 | /* |
| 3 | * Copyright (C) BitBox Ltd 2010 |
Peter Horton | cdc3f10 | 2010-12-06 11:37:38 +0000 | [diff] [blame] | 4 | */ |
| 5 | |
| 6 | #include <linux/module.h> |
| 7 | #include <linux/irq.h> |
Fabio Estevam | baa2559 | 2013-05-24 16:55:41 -0300 | [diff] [blame] | 8 | #include <linux/platform_data/asoc-imx-ssi.h> |
Peter Horton | cdc3f10 | 2010-12-06 11:37:38 +0000 | [diff] [blame] | 9 | |
| 10 | #include "irq-common.h" |
| 11 | |
Peter Horton | cdc3f10 | 2010-12-06 11:37:38 +0000 | [diff] [blame] | 12 | int mxc_set_irq_fiq(unsigned int irq, unsigned int type) |
| 13 | { |
Shawn Guo | 8b6c44f | 2011-06-07 13:59:14 +0800 | [diff] [blame] | 14 | struct irq_chip_generic *gc; |
Hui Wang | 3439a39 | 2011-09-22 17:40:08 +0800 | [diff] [blame] | 15 | struct mxc_extra_irq *exirq; |
Peter Horton | cdc3f10 | 2010-12-06 11:37:38 +0000 | [diff] [blame] | 16 | int ret; |
| 17 | |
| 18 | ret = -ENOSYS; |
| 19 | |
Shawn Guo | 8b6c44f | 2011-06-07 13:59:14 +0800 | [diff] [blame] | 20 | gc = irq_get_chip_data(irq); |
| 21 | if (gc && gc->private) { |
Hui Wang | 3439a39 | 2011-09-22 17:40:08 +0800 | [diff] [blame] | 22 | exirq = gc->private; |
Alexander Shiyan | d1e1c31 | 2016-06-19 09:55:53 +0300 | [diff] [blame] | 23 | if (exirq->set_irq_fiq) { |
| 24 | struct irq_data *d = irq_get_irq_data(irq); |
| 25 | ret = exirq->set_irq_fiq(irqd_to_hwirq(d), type); |
| 26 | } |
Peter Horton | cdc3f10 | 2010-12-06 11:37:38 +0000 | [diff] [blame] | 27 | } |
| 28 | |
| 29 | return ret; |
| 30 | } |
| 31 | EXPORT_SYMBOL(mxc_set_irq_fiq); |