summaryrefslogtreecommitdiff
path: root/include/sbi/sbi_irqchip.h
blob: 6acc6e3f5a55ace1aa0f2a5c0e20cb8741c45173 (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
44
/*
 * 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;
struct sbi_trap_regs;

/**
 * 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)(struct sbi_trap_regs *regs));

/**
 * 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(struct sbi_trap_regs *regs);

/** 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