| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- /* SPDX-License-Identifier: GPL-2.0-or-later */
- /*
- * CXL protocol Error INJection support.
- *
- * Copyright (c) 2023 Advanced Micro Devices, Inc.
- * All Rights Reserved.
- *
- * Author: Ben Cheatham <benjamin.cheatham@amd.com>
- */
- #ifndef EINJ_CXL_H
- #define EINJ_CXL_H
- #include <linux/errno.h>
- #include <linux/types.h>
- struct pci_dev;
- struct seq_file;
- #if IS_ENABLED(CONFIG_ACPI_APEI_EINJ_CXL)
- int einj_cxl_available_error_type_show(struct seq_file *m, void *v);
- int einj_cxl_inject_error(struct pci_dev *dport_dev, u64 type);
- int einj_cxl_inject_rch_error(u64 rcrb, u64 type);
- bool einj_cxl_is_initialized(void);
- #else /* !IS_ENABLED(CONFIG_ACPI_APEI_EINJ_CXL) */
- static inline int einj_cxl_available_error_type_show(struct seq_file *m,
- void *v)
- {
- return -ENXIO;
- }
- static inline int einj_cxl_inject_error(struct pci_dev *dport_dev, u64 type)
- {
- return -ENXIO;
- }
- static inline int einj_cxl_inject_rch_error(u64 rcrb, u64 type)
- {
- return -ENXIO;
- }
- static inline bool einj_cxl_is_initialized(void) { return false; }
- #endif /* CONFIG_ACPI_APEI_EINJ_CXL */
- #endif /* EINJ_CXL_H */
|