xref: /linux-6.15/include/linux/ras.h (revision 3b566b30)
1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
2d963cd95SChen, Gong #ifndef __RAS_H__
3d963cd95SChen, Gong #define __RAS_H__
4d963cd95SChen, Gong 
5011d8261SBorislav Petkov #include <asm/errno.h>
6297b64c7STyler Baicar #include <linux/uuid.h>
7e9279e83STyler Baicar #include <linux/cper.h>
8011d8261SBorislav Petkov 
9d963cd95SChen, Gong #ifdef CONFIG_DEBUG_FS
10d963cd95SChen, Gong int ras_userspace_consumers(void);
11d963cd95SChen, Gong void ras_debugfs_init(void);
12d963cd95SChen, Gong int ras_add_daemon_trace(void);
13d963cd95SChen, Gong #else
ras_userspace_consumers(void)14d963cd95SChen, Gong static inline int ras_userspace_consumers(void) { return 0; }
ras_debugfs_init(void)15011d8261SBorislav Petkov static inline void ras_debugfs_init(void) { }
ras_add_daemon_trace(void)16d963cd95SChen, Gong static inline int ras_add_daemon_trace(void) { return 0; }
17d963cd95SChen, Gong #endif
18d963cd95SChen, Gong 
19011d8261SBorislav Petkov #ifdef CONFIG_RAS_CEC
20011d8261SBorislav Petkov int __init parse_cec_param(char *str);
21d963cd95SChen, Gong #endif
22011d8261SBorislav Petkov 
23297b64c7STyler Baicar #ifdef CONFIG_RAS
24297b64c7STyler Baicar void log_non_standard_event(const guid_t *sec_type,
25297b64c7STyler Baicar 			    const guid_t *fru_id, const char *fru_text,
26297b64c7STyler Baicar 			    const u8 sev, const u8 *err, const u32 len);
27e9279e83STyler Baicar void log_arm_hw_error(struct cper_sec_proc_arm *err);
283f317499SYazen Ghannam 
29297b64c7STyler Baicar #else
300607512dSArnd Bergmann static inline void
log_non_standard_event(const guid_t * sec_type,const guid_t * fru_id,const char * fru_text,const u8 sev,const u8 * err,const u32 len)310607512dSArnd Bergmann log_non_standard_event(const guid_t *sec_type,
32297b64c7STyler Baicar 		       const guid_t *fru_id, const char *fru_text,
330607512dSArnd Bergmann 		       const u8 sev, const u8 *err, const u32 len)
340607512dSArnd Bergmann { return; }
350607512dSArnd Bergmann static inline void
log_arm_hw_error(struct cper_sec_proc_arm * err)360607512dSArnd Bergmann log_arm_hw_error(struct cper_sec_proc_arm *err) { return; }
37297b64c7STyler Baicar #endif
38297b64c7STyler Baicar 
393f317499SYazen Ghannam struct atl_err {
403f317499SYazen Ghannam 	u64 addr;
413f317499SYazen Ghannam 	u64 ipid;
423f317499SYazen Ghannam 	u32 cpu;
433f317499SYazen Ghannam };
443f317499SYazen Ghannam 
453f317499SYazen Ghannam #if IS_ENABLED(CONFIG_AMD_ATL)
463f317499SYazen Ghannam void amd_atl_register_decoder(unsigned long (*f)(struct atl_err *));
473f317499SYazen Ghannam void amd_atl_unregister_decoder(void);
48*3b566b30SYazen Ghannam void amd_retire_dram_row(struct atl_err *err);
493f317499SYazen Ghannam unsigned long amd_convert_umc_mca_addr_to_sys_addr(struct atl_err *err);
503f317499SYazen Ghannam #else
amd_retire_dram_row(struct atl_err * err)51*3b566b30SYazen Ghannam static inline void amd_retire_dram_row(struct atl_err *err) { }
523f317499SYazen Ghannam static inline unsigned long
amd_convert_umc_mca_addr_to_sys_addr(struct atl_err * err)533f317499SYazen Ghannam amd_convert_umc_mca_addr_to_sys_addr(struct atl_err *err) { return -EINVAL; }
543f317499SYazen Ghannam #endif /* CONFIG_AMD_ATL */
553f317499SYazen Ghannam 
56011d8261SBorislav Petkov #endif /* __RAS_H__ */
57