einj.h 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. /*
  3. * CXL protocol Error INJection support.
  4. *
  5. * Copyright (c) 2023 Advanced Micro Devices, Inc.
  6. * All Rights Reserved.
  7. *
  8. * Author: Ben Cheatham <benjamin.cheatham@amd.com>
  9. */
  10. #ifndef EINJ_CXL_H
  11. #define EINJ_CXL_H
  12. #include <linux/errno.h>
  13. #include <linux/types.h>
  14. struct pci_dev;
  15. struct seq_file;
  16. #if IS_ENABLED(CONFIG_ACPI_APEI_EINJ_CXL)
  17. int einj_cxl_available_error_type_show(struct seq_file *m, void *v);
  18. int einj_cxl_inject_error(struct pci_dev *dport_dev, u64 type);
  19. int einj_cxl_inject_rch_error(u64 rcrb, u64 type);
  20. bool einj_cxl_is_initialized(void);
  21. #else /* !IS_ENABLED(CONFIG_ACPI_APEI_EINJ_CXL) */
  22. static inline int einj_cxl_available_error_type_show(struct seq_file *m,
  23. void *v)
  24. {
  25. return -ENXIO;
  26. }
  27. static inline int einj_cxl_inject_error(struct pci_dev *dport_dev, u64 type)
  28. {
  29. return -ENXIO;
  30. }
  31. static inline int einj_cxl_inject_rch_error(u64 rcrb, u64 type)
  32. {
  33. return -ENXIO;
  34. }
  35. static inline bool einj_cxl_is_initialized(void) { return false; }
  36. #endif /* CONFIG_ACPI_APEI_EINJ_CXL */
  37. #endif /* EINJ_CXL_H */