2019-06-04 10:11:33 +02:00
// SPDX-License-Identifier: GPL-2.0-only
2013-03-21 00:21:21 +01:00
/*
* Dummy IRQ handler driver .
*
* This module only registers itself as a handler that is specified to it
* by the ' irq ' parameter .
*
* The sole purpose of this module is to help with debugging of systems on
* which spurious IRQs would happen on disabled IRQ vector .
*
* Copyright ( C ) 2013 Jiri Kosina
*/
# include <linux/module.h>
# include <linux/irq.h>
# include <linux/interrupt.h>
2013-04-30 22:42:33 +02:00
static int irq = - 1 ;
2013-03-21 00:21:21 +01:00
static irqreturn_t dummy_interrupt ( int irq , void * dev_id )
{
static int count = 0 ;
if ( count = = 0 ) {
2013-05-21 23:13:12 +09:00
printk ( KERN_INFO " dummy-irq: interrupt occurred on IRQ %d \n " ,
2013-03-21 00:21:21 +01:00
irq ) ;
count + + ;
}
return IRQ_NONE ;
}
static int __init dummy_irq_init ( void )
{
2013-04-30 22:42:33 +02:00
if ( irq < 0 ) {
printk ( KERN_ERR " dummy-irq: no IRQ given. Use irq=N \n " ) ;
return - EIO ;
}
2013-03-21 00:21:21 +01:00
if ( request_irq ( irq , & dummy_interrupt , IRQF_SHARED , " dummy_irq " , & irq ) ) {
printk ( KERN_ERR " dummy-irq: cannot register IRQ %d \n " , irq ) ;
return - EIO ;
}
printk ( KERN_INFO " dummy-irq: registered for IRQ %d \n " , irq ) ;
return 0 ;
}
static void __exit dummy_irq_exit ( void )
{
printk ( KERN_INFO " dummy-irq unloaded \n " ) ;
free_irq ( irq , & irq ) ;
}
module_init ( dummy_irq_init ) ;
module_exit ( dummy_irq_exit ) ;
MODULE_LICENSE ( " GPL " ) ;
MODULE_AUTHOR ( " Jiri Kosina " ) ;
2017-04-04 16:54:24 +01:00
module_param_hw ( irq , uint , irq , 0444 ) ;
2013-03-21 00:21:21 +01:00
MODULE_PARM_DESC ( irq , " The IRQ to register for " ) ;
2014-07-02 21:02:25 +08:00
MODULE_DESCRIPTION ( " Dummy IRQ handler driver " ) ;