Altera HWLIB  16.0
The Altera HW Manager API Reference Manual
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Groups
alt_interrupt_common.h
1 /******************************************************************************
2 *
3 * Copyright 2013 Altera Corporation. All Rights Reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 *
8 * 1. Redistributions of source code must retain the above copyright notice,
9 * this list of conditions and the following disclaimer.
10 *
11 * 2. Redistributions in binary form must reproduce the above copyright notice,
12 * this list of conditions and the following disclaimer in the documentation
13 * and/or other materials provided with the distribution.
14 *
15 * 3. Neither the name of the copyright holder nor the names of its contributors
16 * may be used to endorse or promote products derived from this software without
17 * specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
30 *
31 ******************************************************************************/
32 
33 /*
34  * $Id: //depot/embedded/rel/15.0/ip/hps/altera_hps/hwlib/include/alt_interrupt_common.h#1 $
35  */
36 
37 #ifndef __ALT_INT_COMMON_H__
38 #define __ALT_INT_COMMON_H__
39 
40 #include <stdbool.h>
41 #include <stddef.h>
42 #include "hwlib.h"
43 #include "alt_int_device.h"
44 
45 #ifdef __cplusplus
46 extern "C"
47 {
48 #endif
49 
65 typedef uint32_t alt_int_cpu_target_t;
66 
70 typedef enum ALT_INT_TRIGGER_e
71 {
78 
85 
91 
100 
106 }
108 
117 {
123 
129 
135 }
137 
141 #define ALT_INT_ICCIAR_CPUID_GET(icciar) ((icciar >> 10) & 0x7)
142 
146 #define ALT_INT_ICCIAR_ACKINTID_GET(icciar) (icciar & 0x3FF)
147 
157 typedef void (*alt_int_callback_t)(uint32_t icciar, void * context);
158 
163 #ifdef __cplusplus
164 }
165 #endif
166 
167 #endif /* __ALT_INT_COMMON_H__ */