mca_drv.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * File: mca_drv.h
  4. * Purpose: Define helpers for Generic MCA handling
  5. *
  6. * Copyright (C) 2004 FUJITSU LIMITED
  7. * Copyright (C) 2004 Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
  8. */
  9. /*
  10. * Processor error section:
  11. *
  12. * +-sal_log_processor_info_t *info-------------+
  13. * | sal_log_section_hdr_t header; |
  14. * | ... |
  15. * | sal_log_mod_error_info_t info[0]; |
  16. * +-+----------------+-------------------------+
  17. * | CACHE_CHECK | ^ num_cache_check v
  18. * +----------------+
  19. * | TLB_CHECK | ^ num_tlb_check v
  20. * +----------------+
  21. * | BUS_CHECK | ^ num_bus_check v
  22. * +----------------+
  23. * | REG_FILE_CHECK | ^ num_reg_file_check v
  24. * +----------------+
  25. * | MS_CHECK | ^ num_ms_check v
  26. * +-struct cpuid_info *id----------------------+
  27. * | regs[5]; |
  28. * | reserved; |
  29. * +-sal_processor_static_info_t *regs----------+
  30. * | valid; |
  31. * | ... |
  32. * | fr[128]; |
  33. * +--------------------------------------------+
  34. */
  35. /* peidx: index of processor error section */
  36. typedef struct peidx_table {
  37. sal_log_processor_info_t *info;
  38. struct sal_cpuid_info *id;
  39. sal_processor_static_info_t *regs;
  40. } peidx_table_t;
  41. #define peidx_head(p) (((p)->info))
  42. #define peidx_mid(p) (((p)->id))
  43. #define peidx_bottom(p) (((p)->regs))
  44. #define peidx_psp(p) (&(peidx_head(p)->proc_state_parameter))
  45. #define peidx_field_valid(p) (&(peidx_head(p)->valid))
  46. #define peidx_minstate_area(p) (&(peidx_bottom(p)->min_state_area))
  47. #define peidx_cache_check_num(p) (peidx_head(p)->valid.num_cache_check)
  48. #define peidx_tlb_check_num(p) (peidx_head(p)->valid.num_tlb_check)
  49. #define peidx_bus_check_num(p) (peidx_head(p)->valid.num_bus_check)
  50. #define peidx_reg_file_check_num(p) (peidx_head(p)->valid.num_reg_file_check)
  51. #define peidx_ms_check_num(p) (peidx_head(p)->valid.num_ms_check)
  52. #define peidx_cache_check_idx(p, n) (n)
  53. #define peidx_tlb_check_idx(p, n) (peidx_cache_check_idx(p, peidx_cache_check_num(p)) + n)
  54. #define peidx_bus_check_idx(p, n) (peidx_tlb_check_idx(p, peidx_tlb_check_num(p)) + n)
  55. #define peidx_reg_file_check_idx(p, n) (peidx_bus_check_idx(p, peidx_bus_check_num(p)) + n)
  56. #define peidx_ms_check_idx(p, n) (peidx_reg_file_check_idx(p, peidx_reg_file_check_num(p)) + n)
  57. #define peidx_mod_error_info(p, name, n) \
  58. ({ int __idx = peidx_##name##_idx(p, n); \
  59. sal_log_mod_error_info_t *__ret = NULL; \
  60. if (peidx_##name##_num(p) > n) /*BUG*/ \
  61. __ret = &(peidx_head(p)->info[__idx]); \
  62. __ret; })
  63. #define peidx_cache_check(p, n) peidx_mod_error_info(p, cache_check, n)
  64. #define peidx_tlb_check(p, n) peidx_mod_error_info(p, tlb_check, n)
  65. #define peidx_bus_check(p, n) peidx_mod_error_info(p, bus_check, n)
  66. #define peidx_reg_file_check(p, n) peidx_mod_error_info(p, reg_file_check, n)
  67. #define peidx_ms_check(p, n) peidx_mod_error_info(p, ms_check, n)
  68. #define peidx_check_info(proc, name, n) \
  69. ({ \
  70. sal_log_mod_error_info_t *__info = peidx_mod_error_info(proc, name, n);\
  71. u64 __temp = __info && __info->valid.check_info \
  72. ? __info->check_info : 0; \
  73. __temp; })
  74. /* slidx: index of SAL log error record */
  75. typedef struct slidx_list {
  76. struct list_head list;
  77. sal_log_section_hdr_t *hdr;
  78. } slidx_list_t;
  79. typedef struct slidx_table {
  80. sal_log_record_header_t *header;
  81. int n_sections; /* # of section headers */
  82. struct list_head proc_err;
  83. struct list_head mem_dev_err;
  84. struct list_head sel_dev_err;
  85. struct list_head pci_bus_err;
  86. struct list_head smbios_dev_err;
  87. struct list_head pci_comp_err;
  88. struct list_head plat_specific_err;
  89. struct list_head host_ctlr_err;
  90. struct list_head plat_bus_err;
  91. struct list_head unsupported; /* list of unsupported sections */
  92. } slidx_table_t;
  93. #define slidx_foreach_entry(pos, head) \
  94. list_for_each_entry(pos, head, list)
  95. #define slidx_first_entry(head) \
  96. (((head)->next != (head)) ? list_entry((head)->next, typeof(slidx_list_t), list) : NULL)
  97. #define slidx_count(slidx, sec) \
  98. ({ int __count = 0; \
  99. slidx_list_t *__pos; \
  100. slidx_foreach_entry(__pos, &((slidx)->sec)) { __count++; }\
  101. __count; })
  102. struct mca_table_entry {
  103. int start_addr; /* location-relative starting address of MCA recoverable range */
  104. int end_addr; /* location-relative ending address of MCA recoverable range */
  105. };
  106. extern const struct mca_table_entry *search_mca_tables (unsigned long addr);
  107. extern int mca_recover_range(unsigned long);
  108. extern void ia64_mlogbuf_dump(void);