Contiki 3.x
shared-isr.h
1 /*
2  * Copyright (C) 2016, Intel Corporation. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  *
13  * 3. Neither the name of the copyright holder nor the names of its
14  * contributors may be used to endorse or promote products derived
15  * from this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
20  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
21  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
22  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
24  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
26  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
28  * OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30 
31 #ifndef CPU_X86_DRIVERS_LEGACY_PC_SHARED_ISR_H_
32 #define CPU_X86_DRIVERS_LEGACY_PC_SHARED_ISR_H_
33 
34 #include <stdbool.h>
35 #include "pci.h"
36 
37 /**
38  * The handler function should return true if and only if it handled the
39  * interrupt.
40  */
41 typedef bool (*shared_isr_handler_t)(void);
42 
43 typedef struct shared_isr_client {
44  uint8_t irq;
45  IRQAGENT agent;
46  INTR_PIN pin;
47  PIRQ pirq;
48  shared_isr_handler_t handler;
49 } shared_isr_client_t;
50 
51 /* Unlike a non-shared interrupt handler function, an individual interrupt
52  * handler for a shared interrupt must not issue an EOI. The EOI is issued by
53  * the shared-isr subsystem.
54  */
55 #define DEFINE_SHARED_IRQ(irq_, agent_, pin_, pirq_, handler_) \
56 static struct shared_isr_client \
57  __attribute__((used, section(".shared_isr_data"))) _shared_irq_##irq_ = { \
58  .irq = irq_, \
59  .agent = agent_, \
60  .pin = pin_, \
61  .pirq = pirq_, \
62  .handler = handler_ \
63 }
64 
65 void shared_isr_init(void);
66 
67 #endif /* CPU_X86_DRIVERS_LEGACY_PC_SHARED_ISR_H_ */