mirror of https://github.com/F-Stack/f-stack.git
44 lines
1.2 KiB
C
44 lines
1.2 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright(C) 2021 Marvell.
|
|
*/
|
|
|
|
#ifndef _ROC_BPHY_IRQ_
|
|
#define _ROC_BPHY_IRQ_
|
|
|
|
struct roc_bphy_irq_vec {
|
|
int fd;
|
|
int handler_cpu;
|
|
void (*handler)(int irq_num, void *isr_data);
|
|
void *isr_data;
|
|
};
|
|
|
|
struct roc_bphy_irq_chip {
|
|
struct roc_bphy_irq_vec *irq_vecs;
|
|
uint64_t max_irq;
|
|
uint64_t avail_irq_bmask;
|
|
int intfd;
|
|
int n_handlers;
|
|
char *mz_name;
|
|
};
|
|
|
|
struct roc_bphy_intr {
|
|
int irq_num;
|
|
void (*intr_handler)(int irq_num, void *isr_data);
|
|
void *isr_data;
|
|
int cpu;
|
|
/* stack for this interrupt, not supplied by a user */
|
|
uint8_t *sp;
|
|
};
|
|
|
|
__roc_api struct roc_bphy_irq_chip *roc_bphy_intr_init(void);
|
|
__roc_api void roc_bphy_intr_fini(struct roc_bphy_irq_chip *irq_chip);
|
|
__roc_api void roc_bphy_intr_handler(unsigned int irq_num);
|
|
__roc_api bool roc_bphy_intr_available(struct roc_bphy_irq_chip *irq_chip,
|
|
int irq_num);
|
|
__roc_api int roc_bphy_intr_clear(struct roc_bphy_irq_chip *chip, int irq_num);
|
|
__roc_api uint64_t roc_bphy_intr_max_get(struct roc_bphy_irq_chip *irq_chip);
|
|
__roc_api int roc_bphy_intr_register(struct roc_bphy_irq_chip *irq_chip,
|
|
struct roc_bphy_intr *intr);
|
|
|
|
#endif /* _ROC_BPHY_IRQ_ */
|