blob: fcd766ba9b6a255f916a17639541554385a9acf1 [file] [log] [blame]
Graeme Russ0c8c62e2008-12-07 10:29:01 +11001/*
Graeme Russ77290ee2009-02-24 21:13:40 +11002 * (C) Copyright 2009
Graeme Russ0c8c62e2008-12-07 10:29:01 +11003 * Graeme Russ, graeme.russ@gmail.com
4 *
Graeme Russ77290ee2009-02-24 21:13:40 +11005 * (C) Copyright 2002
Albert ARIBAUD60fbc8d2011-08-04 18:45:45 +02006 * Daniel Engström, Omicron Ceti AB, daniel@omicron.se
Graeme Russ77290ee2009-02-24 21:13:40 +11007 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02008 * SPDX-License-Identifier: GPL-2.0+
Graeme Russ0c8c62e2008-12-07 10:29:01 +11009 */
10
11#ifndef __ASM_INTERRUPT_H_
12#define __ASM_INTERRUPT_H_ 1
13
Graeme Russ43261532010-10-07 20:03:23 +110014#include <asm/types.h>
15
Bin Meng9ff054b2015-07-10 10:38:32 +080016/* Architecture defined exceptions */
17enum x86_exception {
18 EXC_DE = 0,
19 EXC_DB,
20 EXC_NMI,
21 EXC_BP,
22 EXC_OF,
23 EXC_BR,
24 EXC_UD,
25 EXC_NM,
26 EXC_DF,
27 EXC_CSO,
28 EXC_TS,
29 EXC_NP,
30 EXC_SS,
31 EXC_GP,
32 EXC_PF,
33 EXC_MF = 16,
34 EXC_AC,
35 EXC_MC,
36 EXC_XM,
37 EXC_VE
38};
39
Graeme Russcbfce1d2011-04-13 19:43:28 +100040/* arch/x86/cpu/interrupts.c */
Graeme Russ77290ee2009-02-24 21:13:40 +110041void set_vector(u8 intnum, void *routine);
42
Graeme Russ77290ee2009-02-24 21:13:40 +110043/* Architecture specific functions */
44void mask_irq(int irq);
45void unmask_irq(int irq);
46void specific_eoi(int irq);
47
48extern char exception_stack[];
49
Simon Glass0e9c6332014-11-14 18:18:31 -070050/**
51 * configure_irq_trigger() - Configure IRQ triggering
52 *
53 * Switch the given interrupt to be level / edge triggered
54 *
55 * @param int_num legacy interrupt number (3-7, 9-15)
56 * @param is_level_triggered true for level triggered interrupt, false for
57 * edge triggered interrupt
58 */
59void configure_irq_trigger(int int_num, bool is_level_triggered);
60
Simon Glass98d7e982015-04-28 20:25:16 -060061void *x86_get_idt(void);
62
Graeme Russ0c8c62e2008-12-07 10:29:01 +110063#endif