c8ba181d4b54708006befc5e00ab7a9b63772548
[dragonfly.git] / sys / platform / pc32 / apic / ioapic_abi.h
1 /*
2  * Copyright (c) 1991 The Regents of the University of California.
3  * Copyright (c) 1996, by Steve Passe.  All rights reserved.
4  * Copyright (c) 2005,2008 The DragonFly Project.  All rights reserved.
5  * All rights reserved.
6  * 
7  * This code is derived from software contributed to The DragonFly Project
8  * by Matthew Dillon <dillon@backplane.com>
9  *
10  * This code is derived from software contributed to Berkeley by
11  * William Jolitz.
12  * 
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions
15  * are met:
16  * 
17  * 1. Redistributions of source code must retain the above copyright
18  *    notice, this list of conditions and the following disclaimer.
19  * 2. Redistributions in binary form must reproduce the above copyright
20  *    notice, this list of conditions and the following disclaimer in
21  *    the documentation and/or other materials provided with the
22  *    distribution.
23  * 3. Neither the name of The DragonFly Project nor the names of its
24  *    contributors may be used to endorse or promote products derived
25  *    from this software without specific, prior written permission.
26  * 
27  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
28  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
29  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
30  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE
31  * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
32  * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
33  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
34  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
35  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
36  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
37  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38  * SUCH DAMAGE.
39  */
40
41 #ifndef _ARCH_APIC_IOAPIC_ABI_H_
42 #define _ARCH_APIC_IOAPIC_ABI_H_
43
44 #ifndef _SYS_BUS_H_
45 #include <sys/bus.h>
46 #endif
47
48 #define APIC_INTMAPSIZE 192
49 /*
50  * NOTE:
51  * - Keep size of apic_intmapinfo power of 2
52  * - Update IOAPIC_IM_SZSHIFT after changing apic_intmapinfo size
53  */
54 struct apic_intmapinfo {
55         int ioapic;
56         int int_pin;
57         volatile void *apic_address;
58         int redirindex;
59         uint32_t flags;         /* IOAPIC_IM_FLAG_ */
60         uint32_t pad[3];
61 };
62 #define IOAPIC_IM_SZSHIFT       5
63
64 #define IOAPIC_IM_FLAG_LEVEL    0x1     /* default to edge trigger */
65 #define IOAPIC_IM_FLAG_MASKED   0x2
66
67 extern struct apic_intmapinfo   int_to_apicintpin[];
68
69 extern struct machintr_abi MachIntrABI_IOAPIC;
70
71 int     ioapic_abi_extint_irqmap(int);
72 void    ioapic_abi_set_irqmap(int, int, enum intr_trigger, enum intr_polarity);
73 void    ioapic_abi_fixup_irqmap(void);
74
75 int     ioapic_abi_find_gsi(int, enum intr_trigger, enum intr_polarity);
76 int     ioapic_abi_find_irq(int, enum intr_trigger, enum intr_polarity);
77
78 #endif  /* !_ARCH_APIC_IOAPIC_ABI_H_ */