aboutsummaryrefslogtreecommitdiff
path: root/include/sbi/sbi_irqchip.h
blob: 0ed02eb4ac951193ff830e950b21030406934fb3 (plain)
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
/*
 * SPDX-License-Identifier: BSD-2-Clause
 *
 * Copyright (c) 2022 Ventana Micro Systems Inc.
 *
 * Authors:
 *   Anup Patel <apatel@ventanamicro.com>
 */

#ifndef __SBI_IRQCHIP_H__
#define __SBI_IRQCHIP_H__

#include <sbi/sbi_types.h>

struct sbi_scratch;

/**
 * Set external interrupt handling function
 *
 * This function is called by OpenSBI platform code to set a handler for
 * external interrupts
 *
 * @param fn function pointer for handling external irqs
 */
void sbi_irqchip_set_irqfn(int (*fn)(void));

/**
 * Process external interrupts
 *
 * This function is called by sbi_trap_handler() to handle external
 * interrupts.
 *
 * @param regs pointer for trap registers
 */
int sbi_irqchip_process(void);

/** Initialize interrupt controllers */
int sbi_irqchip_init(struct sbi_scratch *scratch, bool cold_boot);

/** Exit interrupt controllers */
void sbi_irqchip_exit(struct sbi_scratch *scratch);

#endif