memory_dump.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2012, 2014-2017, 2019-2021, The Linux Foundation. All rights reserved.
  4. */
  5. #ifndef __MSM_MEMORY_DUMP_H
  6. #define __MSM_MEMORY_DUMP_H
  7. #include <linux/errno.h>
  8. #include <linux/types.h>
  9. enum dump_client_type {
  10. MSM_CPU_CTXT = 0,
  11. MSM_L1_CACHE,
  12. MSM_L2_CACHE,
  13. MSM_OCMEM,
  14. MSM_TMC_ETFETB,
  15. MSM_ETM0_REG,
  16. MSM_ETM1_REG,
  17. MSM_ETM2_REG,
  18. MSM_ETM3_REG,
  19. MSM_TMC0_REG, /* TMC_ETR */
  20. MSM_TMC1_REG, /* TMC_ETF */
  21. MSM_LOG_BUF,
  22. MSM_LOG_BUF_FIRST_IDX,
  23. MAX_NUM_CLIENTS,
  24. };
  25. struct msm_client_dump {
  26. enum dump_client_type id;
  27. unsigned long start_addr;
  28. unsigned long end_addr;
  29. };
  30. #ifdef CONFIG_QCOM_MEMORY_DUMP
  31. extern int msm_dump_tbl_register(struct msm_client_dump *client_entry);
  32. #else
  33. static inline int msm_dump_tbl_register(struct msm_client_dump *entry)
  34. {
  35. return -EIO;
  36. }
  37. #endif
  38. #if IS_ENABLED(CONFIG_QCOM_MEMORY_DUMP_V2)
  39. extern uint32_t msm_dump_table_version(void);
  40. #else
  41. static inline uint32_t msm_dump_table_version(void)
  42. {
  43. return 0;
  44. }
  45. #endif
  46. #define MSM_DUMP_MAKE_VERSION(ma, mi) ((ma << 20) | mi)
  47. #define MSM_DUMP_MAJOR(val) (val >> 20)
  48. #define MSM_DUMP_MINOR(val) (val & 0xFFFFF)
  49. #define MAX_NUM_ENTRIES 0x150
  50. enum msm_dump_data_ids {
  51. MSM_DUMP_DATA_CPU_CTX = 0x00,
  52. MSM_DUMP_DATA_L1_INST_CACHE = 0x60,
  53. MSM_DUMP_DATA_L1_DATA_CACHE = 0x80,
  54. MSM_DUMP_DATA_ETM_REG = 0xA0,
  55. MSM_DUMP_DATA_L2_CACHE = 0xC0,
  56. MSM_DUMP_DATA_L3_CACHE = 0xD0,
  57. MSM_DUMP_DATA_OCMEM = 0xE0,
  58. MSM_DUMP_DATA_CNSS_WLAN = 0xE1,
  59. MSM_DUMP_DATA_WIGIG = 0xE2,
  60. MSM_DUMP_DATA_PMIC = 0xE4,
  61. MSM_DUMP_DATA_DBGUI_REG = 0xE5,
  62. MSM_DUMP_DATA_DCC_REG = 0xE6,
  63. MSM_DUMP_DATA_DCC_SRAM = 0xE7,
  64. MSM_DUMP_DATA_MISC = 0xE8,
  65. MSM_DUMP_DATA_VSENSE = 0xE9,
  66. MSM_DUMP_DATA_RPM = 0xEA,
  67. MSM_DUMP_DATA_SCANDUMP = 0xEB,
  68. MSM_DUMP_DATA_RPMH = 0xEC,
  69. MSM_DUMP_DATA_TMC_ETF = 0xF0,
  70. MSM_DUMP_DATA_TMC_ETF_SWAO = 0xF1,
  71. MSM_DUMP_DATA_TMC_REG = 0x100,
  72. MSM_DUMP_DATA_TMC_ETF_SWAO_REG = 0x102,
  73. MSM_DUMP_DATA_LOG_BUF = 0x110,
  74. MSM_DUMP_DATA_LOG_BUF_FIRST_IDX = 0x111,
  75. MSM_DUMP_DATA_SCANDUMP_PER_CPU = 0x130,
  76. MSM_DUMP_DATA_LLCC_PER_INSTANCE = 0x140,
  77. MSM_DUMP_DATA_MAX = MAX_NUM_ENTRIES,
  78. };
  79. enum msm_dump_table_ids {
  80. MSM_DUMP_TABLE_APPS,
  81. MSM_DUMP_TABLE_MAX = MAX_NUM_ENTRIES,
  82. };
  83. enum msm_dump_type {
  84. MSM_DUMP_TYPE_DATA,
  85. MSM_DUMP_TYPE_TABLE,
  86. };
  87. struct msm_dump_data {
  88. uint32_t version;
  89. uint32_t magic;
  90. char name[32];
  91. uint64_t addr;
  92. uint64_t len;
  93. uint32_t reserved;
  94. };
  95. struct msm_dump_entry {
  96. uint32_t id;
  97. char name[32];
  98. uint32_t type;
  99. uint64_t addr;
  100. };
  101. #if IS_ENABLED(CONFIG_QCOM_MEMORY_DUMP_V2)
  102. extern int msm_dump_data_register(enum msm_dump_table_ids id,
  103. struct msm_dump_entry *entry);
  104. extern int msm_dump_data_register_nominidump(enum msm_dump_table_ids id,
  105. struct msm_dump_entry *entry);
  106. #else
  107. static inline int msm_dump_data_register(enum msm_dump_table_ids id,
  108. struct msm_dump_entry *entry)
  109. {
  110. return -EINVAL;
  111. }
  112. static inline int msm_dump_data_register_nominidump(enum msm_dump_table_ids id,
  113. struct msm_dump_entry *entry)
  114. {
  115. return -EINVAL;
  116. }
  117. #endif
  118. #endif