| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * Copyright (C) 2022 Xilinx, Inc. |
| */ |
| #ifndef _XILINX_MB_MANAGER_H |
| #define _XILINX_MB_MANAGER_H |
| |
| # ifndef __ASSEMBLY__ |
| |
| #include <linux/of_address.h> |
| |
| /* |
| * When the break vector gets asserted because of error injection, the break |
| * signal must be blocked before exiting from the break handler, Below api |
| * updates the manager address and control register and error counter callback |
| * arguments, which will be used by the break handler to block the break and |
| * call the callback function. |
| */ |
| void xmb_manager_register(uintptr_t phys_baseaddr, u32 cr_val, |
| void (*callback)(void *data), |
| void *priv, void (*reset_callback)(void *data)); |
| asmlinkage void xmb_inject_err(void); |
| |
| # endif /* __ASSEMBLY__ */ |
| |
| /* Error injection offset */ |
| #define XMB_INJECT_ERR_OFFSET 0x200 |
| |
| #endif /* _XILINX_MB_MANAGER_H */ |