Contiki 3.x
Main Page
Related Pages
Modules
Data Structures
Files
Examples
File List
Globals
cpu
x86
drivers
legacy_pc
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_ */
Generated on Thu Jul 6 2017 20:52:51 for Contiki 3.x by
1.8.6