2018-03-15 00:15:19 +03:00
// SPDX-License-Identifier: GPL-2.0
2010-09-22 19:09:43 +04:00
/*
* Copyright ( C ) 1992 , 1998 - 2006 Linus Torvalds , Ingo Molnar
* Copyright ( C ) 2005 - 2006 , Thomas Gleixner , Russell King
*
* This file contains the dummy interrupt chip implementation
*/
# include <linux/interrupt.h>
# include <linux/irq.h>
2012-07-31 09:39:20 +04:00
# include <linux/export.h>
2010-09-22 19:09:43 +04:00
# include "internals.h"
/*
* What should we do if we get a hw irq event on an illegal vector ?
* Each architecture has to answer this themself .
*/
static void ack_bad ( struct irq_data * data )
{
struct irq_desc * desc = irq_data_to_desc ( data ) ;
print_irq_desc ( data - > irq , desc ) ;
ack_bad_irq ( data - > irq ) ;
}
/*
* NOP functions
*/
static void noop ( struct irq_data * data ) { }
static unsigned int noop_ret ( struct irq_data * data )
{
return 0 ;
}
/*
* Generic no controller implementation
*/
struct irq_chip no_irq_chip = {
. name = " none " ,
. irq_startup = noop_ret ,
. irq_shutdown = noop ,
. irq_enable = noop ,
. irq_disable = noop ,
. irq_ack = ack_bad ,
2015-05-22 10:58:49 +03:00
. flags = IRQCHIP_SKIP_SET_WAKE ,
2010-09-22 19:09:43 +04:00
} ;
/*
* Generic dummy implementation which can be used for
* real dumb interrupt sources
*/
struct irq_chip dummy_irq_chip = {
. name = " dummy " ,
. irq_startup = noop_ret ,
. irq_shutdown = noop ,
. irq_enable = noop ,
. irq_disable = noop ,
. irq_ack = noop ,
. irq_mask = noop ,
. irq_unmask = noop ,
2015-04-15 11:14:11 +03:00
. flags = IRQCHIP_SKIP_SET_WAKE ,
2010-09-22 19:09:43 +04:00
} ;
2012-07-31 09:39:20 +04:00
EXPORT_SYMBOL_GPL ( dummy_irq_chip ) ;