hc
2025-02-14 bbb9540dc49f70f6b703d1c8d1b85fa5f602d86e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/*
 * (C) Copyright 2009
 * Graeme Russ, graeme.russ@gmail.com
 *
 * (C) Copyright 2002
 * Daniel Engström, Omicron Ceti AB, daniel@omicron.se
 *
 * SPDX-License-Identifier:    GPL-2.0+
 */
 
#ifndef __ASM_INTERRUPT_H_
#define __ASM_INTERRUPT_H_ 1
 
#include <asm/types.h>
 
#define SYS_NUM_IRQS    16
 
/* Architecture defined exceptions */
enum x86_exception {
   EXC_DE = 0,
   EXC_DB,
   EXC_NMI,
   EXC_BP,
   EXC_OF,
   EXC_BR,
   EXC_UD,
   EXC_NM,
   EXC_DF,
   EXC_CSO,
   EXC_TS,
   EXC_NP,
   EXC_SS,
   EXC_GP,
   EXC_PF,
   EXC_MF = 16,
   EXC_AC,
   EXC_MC,
   EXC_XM,
   EXC_VE
};
 
/* arch/x86/cpu/interrupts.c */
void set_vector(u8 intnum, void *routine);
 
/* Architecture specific functions */
void mask_irq(int irq);
void unmask_irq(int irq);
void specific_eoi(int irq);
 
extern char exception_stack[];
 
/**
 * configure_irq_trigger() - Configure IRQ triggering
 *
 * Switch the given interrupt to be level / edge triggered
 *
 * @param int_num legacy interrupt number (3-7, 9-15)
 * @param is_level_triggered true for level triggered interrupt, false for
 *    edge triggered interrupt
 */
void configure_irq_trigger(int int_num, bool is_level_triggered);
 
void *x86_get_idt(void);
 
#endif