tsens-v2.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (c) 2015, The Linux Foundation. All rights reserved.
  4. * Copyright (c) 2018, Linaro Limited
  5. * Copyright (c) 2023-2024, Qualcomm Innovation Center, Inc. All rights reserved.
  6. */
  7. #include <linux/bitops.h>
  8. #include <linux/regmap.h>
  9. #include "tsens.h"
  10. /* ----- SROT ------ */
  11. #define SROT_HW_VER_OFF 0x0000
  12. #define SROT_CTRL_OFF 0x0004
  13. /* ----- TM ------ */
  14. #define TM_INT_EN_OFF 0x0004
  15. #define TM_UPPER_LOWER_INT_STATUS_OFF 0x0008
  16. #define TM_UPPER_LOWER_INT_CLEAR_OFF 0x000c
  17. #define TM_UPPER_LOWER_INT_MASK_OFF 0x0010
  18. #define TM_CRITICAL_INT_STATUS_OFF 0x0014
  19. #define TM_CRITICAL_INT_CLEAR_OFF 0x0018
  20. #define TM_CRITICAL_INT_MASK_OFF 0x001c
  21. #define TM_Sn_UPPER_LOWER_THRESHOLD_OFF 0x0020
  22. #define TM_Sn_CRITICAL_THRESHOLD_OFF 0x0060
  23. #define TM_Sn_STATUS_OFF 0x00a0
  24. #define TM_TRDY_OFF 0x00e4
  25. #define TM_COLD_INT_STATUS_OFF 0x00e0
  26. #define TM_WDOG_LOG_OFF 0x013c
  27. /* v2.x: 8996, 8998, sdm845 */
  28. static struct tsens_features tsens_v2_feat = {
  29. .ver_major = VER_2_X,
  30. .crit_int = 1,
  31. .adc = 0,
  32. .srot_split = 1,
  33. .max_sensors = 16,
  34. };
  35. static const struct reg_field tsens_v2_regfields[MAX_REGFIELDS] = {
  36. /* ----- SROT ------ */
  37. /* VERSION */
  38. [VER_MAJOR] = REG_FIELD(SROT_HW_VER_OFF, 28, 31),
  39. [VER_MINOR] = REG_FIELD(SROT_HW_VER_OFF, 16, 27),
  40. [VER_STEP] = REG_FIELD(SROT_HW_VER_OFF, 0, 15),
  41. /* CTRL_OFF */
  42. [TSENS_EN] = REG_FIELD(SROT_CTRL_OFF, 0, 0),
  43. [TSENS_SW_RST] = REG_FIELD(SROT_CTRL_OFF, 1, 1),
  44. /* ----- TM ------ */
  45. /* INTERRUPT ENABLE */
  46. /* v2 has separate enables for UPPER/LOWER/CRITICAL interrupts */
  47. [INT_EN] = REG_FIELD(TM_INT_EN_OFF, 0, 2),
  48. /* TEMPERATURE THRESHOLDS */
  49. REG_FIELD_FOR_EACH_SENSOR16(LOW_THRESH, TM_Sn_UPPER_LOWER_THRESHOLD_OFF, 0, 11),
  50. REG_FIELD_FOR_EACH_SENSOR16(UP_THRESH, TM_Sn_UPPER_LOWER_THRESHOLD_OFF, 12, 23),
  51. REG_FIELD_FOR_EACH_SENSOR16(CRIT_THRESH, TM_Sn_CRITICAL_THRESHOLD_OFF, 0, 11),
  52. /* INTERRUPTS [CLEAR/STATUS/MASK] */
  53. REG_FIELD_SPLIT_BITS_0_15(LOW_INT_STATUS, TM_UPPER_LOWER_INT_STATUS_OFF),
  54. REG_FIELD_SPLIT_BITS_0_15(LOW_INT_CLEAR, TM_UPPER_LOWER_INT_CLEAR_OFF),
  55. REG_FIELD_SPLIT_BITS_0_15(LOW_INT_MASK, TM_UPPER_LOWER_INT_MASK_OFF),
  56. REG_FIELD_SPLIT_BITS_16_31(UP_INT_STATUS, TM_UPPER_LOWER_INT_STATUS_OFF),
  57. REG_FIELD_SPLIT_BITS_16_31(UP_INT_CLEAR, TM_UPPER_LOWER_INT_CLEAR_OFF),
  58. REG_FIELD_SPLIT_BITS_16_31(UP_INT_MASK, TM_UPPER_LOWER_INT_MASK_OFF),
  59. REG_FIELD_SPLIT_BITS_0_15(CRIT_INT_STATUS, TM_CRITICAL_INT_STATUS_OFF),
  60. REG_FIELD_SPLIT_BITS_0_15(CRIT_INT_CLEAR, TM_CRITICAL_INT_CLEAR_OFF),
  61. REG_FIELD_SPLIT_BITS_0_15(CRIT_INT_MASK, TM_CRITICAL_INT_MASK_OFF),
  62. /* WATCHDOG on v2.3 or later */
  63. [WDOG_BARK_STATUS] = REG_FIELD(TM_CRITICAL_INT_STATUS_OFF, 31, 31),
  64. [WDOG_BARK_CLEAR] = REG_FIELD(TM_CRITICAL_INT_CLEAR_OFF, 31, 31),
  65. [WDOG_BARK_MASK] = REG_FIELD(TM_CRITICAL_INT_MASK_OFF, 31, 31),
  66. [CC_MON_STATUS] = REG_FIELD(TM_CRITICAL_INT_STATUS_OFF, 30, 30),
  67. [CC_MON_CLEAR] = REG_FIELD(TM_CRITICAL_INT_CLEAR_OFF, 30, 30),
  68. [CC_MON_MASK] = REG_FIELD(TM_CRITICAL_INT_MASK_OFF, 30, 30),
  69. [WDOG_BARK_COUNT] = REG_FIELD(TM_WDOG_LOG_OFF, 0, 7),
  70. /* Sn_STATUS */
  71. REG_FIELD_FOR_EACH_SENSOR16(LAST_TEMP, TM_Sn_STATUS_OFF, 0, 11),
  72. REG_FIELD_FOR_EACH_SENSOR16(VALID, TM_Sn_STATUS_OFF, 21, 21),
  73. /* xxx_STATUS bits: 1 == threshold violated */
  74. REG_FIELD_FOR_EACH_SENSOR16(MIN_STATUS, TM_Sn_STATUS_OFF, 16, 16),
  75. REG_FIELD_FOR_EACH_SENSOR16(LOWER_STATUS, TM_Sn_STATUS_OFF, 17, 17),
  76. REG_FIELD_FOR_EACH_SENSOR16(UPPER_STATUS, TM_Sn_STATUS_OFF, 18, 18),
  77. REG_FIELD_FOR_EACH_SENSOR16(CRITICAL_STATUS, TM_Sn_STATUS_OFF, 19, 19),
  78. REG_FIELD_FOR_EACH_SENSOR16(MAX_STATUS, TM_Sn_STATUS_OFF, 20, 20),
  79. /* COLD INTERRUPT STATUS */
  80. [COLD_STATUS] = REG_FIELD(TM_COLD_INT_STATUS_OFF, 0, 0),
  81. /* TRDY: 1=ready, 0=in progress */
  82. [TRDY] = REG_FIELD(TM_TRDY_OFF, 0, 0),
  83. };
  84. static const struct tsens_ops ops_generic_v2 = {
  85. .init = init_common,
  86. .get_temp = get_temp_tsens_valid,
  87. .suspend = tsens_v2_tsens_suspend,
  88. .resume = tsens_v2_tsens_resume,
  89. .get_cold_status = get_cold_int_status,
  90. };
  91. struct tsens_plat_data data_tsens_v2 = {
  92. .ops = &ops_generic_v2,
  93. .feat = &tsens_v2_feat,
  94. .fields = tsens_v2_regfields,
  95. };
  96. /* Kept around for backward compatibility with old msm8996.dtsi */
  97. struct tsens_plat_data data_8996 = {
  98. .num_sensors = 13,
  99. .ops = &ops_generic_v2,
  100. .feat = &tsens_v2_feat,
  101. .fields = tsens_v2_regfields,
  102. };