batterydata.txt 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. Battery Profile Data
  2. Battery Data is a collection of battery profile data made available to
  3. the QPNP Charger and BMS drivers via device tree.
  4. qcom,battery-data node required properties:
  5. - qcom,rpull-up-kohm : The vadc pullup resistor's resistance value in kOhms.
  6. - qcom,vref-batt-therm-uv : The vadc voltage used to make readings.
  7. For Qualcomm Technologies, Inc. VADCs, this should be
  8. 1800000uV.
  9. qcom,battery-data node optional properties:
  10. - qcom,batt-id-range-pct : The area of variation between upper and lower bound
  11. for which a given battery ID resistance is valid. This
  12. value is expressed as a percentage of the specified kohm
  13. resistance provided by qcom,batt-id-kohm.
  14. qcom,battery-data can also include any number of children nodes. These children
  15. nodes will be treated as battery profile data nodes.
  16. Profile data node required properties:
  17. - qcom,fcc-mah : Full charge count of the battery in milliamp-hours
  18. - qcom,default-rbatt-mohm : The nominal battery resistance value
  19. - qcom,rbatt-capacitive-mohm : The capacitive resistance of the battery.
  20. - qcom,flat-ocv-threshold-uv : The threshold under which the battery can be
  21. considered to be in the flat portion of the discharge
  22. curve.
  23. - qcom,max-voltage-uv : The maximum rated voltage of the battery
  24. - qcom,v-cutoff-uv : The cutoff voltage of the battery at which the device
  25. should shutdown gracefully.
  26. - qcom,chg-term-ua : The termination charging current of the battery.
  27. - qcom,batt-id-kohm : The battery id resistance of the battery. It can be
  28. used as an array which could support multiple IDs for one battery
  29. module when the ID resistance of some battery modules goes across
  30. several ranges.
  31. - qcom,battery-type : A string indicating the type of battery.
  32. - qcom,fg-profile-data : An array of hexadecimal values used to configure more
  33. complex fuel gauge peripherals which have a large amount
  34. of coefficients used in hardware state machines and thus
  35. influencing the final output of the state of charge read
  36. by software.
  37. Profile data node optional properties:
  38. - qcom,chg-rslow-comp-c1 : A constant for rslow compensation in the fuel gauge.
  39. This will be provided by the profiling tool for
  40. additional fuel gauge accuracy during charging.
  41. - qcom,chg-rslow-comp-c2 : A constant for rslow compensation in the fuel gauge.
  42. This will be provided by the profiling tool for
  43. additional fuel gauge accuracy during charging.
  44. - qcom,chg-rslow-comp-thr : A constant for rslow compensation in the fuel gauge.
  45. This will be provided by the profiling tool for
  46. additional fuel gauge accuracy during charging.
  47. - qcom,chg-rs-to-rslow: A constant for rslow compensation in the fuel gauge.
  48. This will be provided by the profiling tool for
  49. additional fuel gauge accuracy during charging.
  50. - qcom,fastchg-current-ma: Specifies the maximum fastcharge current.
  51. - qcom,fg-cc-cv-threshold-mv: Voltage threshold in mV for transition from constant
  52. charge (CC) to constant voltage (CV). This value should
  53. be 10 mV less than the float voltage.
  54. This property should only be specified if
  55. "qcom,autoadjust-vfloat" property is specified in the
  56. charger driver to ensure a proper operation.
  57. - qcom,thermal-coefficients: Byte array of thermal coefficients for reading
  58. battery thermistor. This should be exactly 6 bytes
  59. in length.
  60. Example: [01 02 03 04 05 06]
  61. - qcom,soc-based-step-chg: A bool property to indicate if the battery will
  62. perform SoC (State of Charge) based step charging.
  63. If yes, the low and high thresholds defined in
  64. "qcom,step-chg-ranges" tuples should be assigned as
  65. SoC values in percentage.
  66. - qcom,step-chg-ranges: Array of tuples in which a tuple describes a range
  67. data of step charging setting.
  68. A range contains following 3 integer elements:
  69. [0]: the low threshold of battery votlage in uV
  70. or SoC (State of Charge) in percentage when
  71. SoC based step charge is used;
  72. [1]: the high threshold of battery voltage in uV
  73. or SoC in percentage when SoC based step charge
  74. is used;
  75. [2]: the FCC (full charging current) in uA when battery
  76. voltage or SoC falls between the low and high
  77. thresholds.
  78. The threshold values in range should be in ascending
  79. and shouldn't overlap. It support 8 ranges at max.
  80. - qcom,jeita-fcc-ranges: Array of tuples in which a tuple describes a range
  81. data of sw-jeita FCC (full charging current) setting.
  82. A range contains following 3 integer elements:
  83. [0]: the low threshold of battery temperature in deci-degree;
  84. [1]: the high threshold of battery temperature in deci-degree;
  85. [2]: the FCC in uA when battery temperature falls between
  86. the low and high thresholds.
  87. The threshold values in range should be in ascending
  88. and shouldn't overlap. It support 8 ranges at max.
  89. - qcom,jeita-fv-ranges: Array of tuples in which a tuple describes a range
  90. data of sw-jeita FV (float voltage) setting.
  91. A range contains following 3 integer elements:
  92. [0]: the low threshold of battery temperature in deci-degree;
  93. [1]: the high threshold of battery temperature in deci-degree;
  94. [3]: the FV in uV when battery temperature falls between
  95. the low and high thresholds.
  96. The threshold values in range should be in ascending
  97. and shouldn't overlap. It support 8 ranges at max.
  98. - qcom,jeita-soft-thresholds: A tuple entry to specify ADC code for battery's soft JEITA
  99. threshold.
  100. <SOFT_COLD_ADC_CODE, SOFT_HOT_ADC_CODE>.
  101. - qcom,jeita-hard-thresholds: A tuple entry to specify ADC code for battery's hard JEITA
  102. threshold.
  103. <HARD_COLD_ADC_CODE, HARD_HOT_ADC_CODE>.
  104. Profile data node required subnodes:
  105. - qcom,fcc-temp-lut : An 1-dimensional lookup table node that encodes
  106. temperature to fcc lookup. The units for this lookup
  107. table should be degrees celsius to milliamp-hours.
  108. - qcom,pc-temp-ocv-lut : A 2-dimensional lookup table node that encodes
  109. temperature and percent charge to open circuit voltage
  110. lookup. The units for this lookup table should be
  111. degrees celsius and percent to millivolts.
  112. - qcom,rbatt-sf-lut : A 2-dimentional lookup table node that encodes
  113. temperature and percent charge to battery internal
  114. resistance lookup. The units for this lookup table
  115. should be degrees celsius and percent to milliohms.
  116. Profile data node optional subnodes:
  117. - qcom,ibat-acc-luit: A 2-dimentional lookup table that encodes temperature
  118. and battery current to battery ACC (apparent charge
  119. capacity). The units for this lookup table should be
  120. temperature in degrees celsius, ibat in milli-amps
  121. and ACC in milli-ampere-hour.
  122. Lookup table required properties:
  123. - qcom,lut-col-legend : An array that encodes the legend of the lookup table's
  124. columns. The length of this array will determine the
  125. lookup table's width.
  126. - qcom,lut-data : An array that encodes the lookup table's data. The size of this
  127. array should be equal to the size of qcom,lut-col-legend
  128. multiplied by 1 if it's a 1-dimensional table, or
  129. the size of qcom,lut-row-legend if it's a 2-dimensional
  130. table. The data should be in a flattened row-major
  131. representation.
  132. Lookup table optional properties:
  133. - qcom,lut-row-legend : An array that encodes the legend of the lookup table's rows.
  134. If this property exists, then it is assumed that the
  135. lookup table is a 2-dimensional table.
  136. Example:
  137. In msm8974-mtp.dtsi:
  138. mtp_batterydata: qcom,battery-data {
  139. qcom,rpull-up-kohm = <100>;
  140. qcom,vref-batt-therm-uv = <1800000>;
  141. /include/ "batterydata-palladium.dtsi"
  142. /include/ "batterydata-mtp-3000mah.dtsi"
  143. };
  144. &pm8941_bms {
  145. qcom,battery-data = <&mtp_batterydata>;
  146. };
  147. In batterydata-palladium.dtsi:
  148. qcom,palladium-batterydata {
  149. qcom,fcc-mah = <1500>;
  150. qcom,default-rbatt-mohm = <236>;
  151. qcom,rbatt-capacitive-mohm = <50>;
  152. qcom,flat-ocv-threshold-uv = <3800000>;
  153. qcom,max-voltage-uv = <4200000>;
  154. qcom,v-cutoff-uv = <3400000>;
  155. qcom,chg-term-ua = <100000>;
  156. qcom,batt-id-kohm = <75>;
  157. qcom,jeita-soft-thresholds = <0x3ecc 0x1bff>;
  158. qcom,jeita-hard-thresholds = <0x4aff 0x15aa>;
  159. qcom,step-chg-ranges = <3600000 4000000 3000000
  160. 4001000 4200000 2800000
  161. 4201000 4400000 2000000>;
  162. qcom,jeita-fcc-ranges = <0 100 600000
  163. 101 200 2000000
  164. 201 450 3000000
  165. 451 550 600000>;
  166. qcom,jeita-fv-ranges = <0 100 4200000
  167. 101 450 4350000
  168. 451 550 4200000>;
  169. qcom,battery-type = "palladium_1500mah";
  170. qcom,fcc-temp-lut {
  171. qcom,lut-col-legend = <(-20) 0 25 40 65>;
  172. qcom,lut-data = <1492 1492 1493 1483 1502>;
  173. };
  174. qcom,pc-temp-ocv-lut {
  175. qcom,lut-col-legend = <(-20) 0 25 40 65>;
  176. qcom,lut-row-legend = <100 95 90 85 80 75 70>,
  177. <65 60 55 50 45 40 35>,
  178. <30 25 20 15 10 9 8>,
  179. <7 6 5 4 3 2 1 0>;
  180. qcom,lut-data = <4173 4167 4163 4156 4154>,
  181. <4104 4107 4108 4102 4104>,
  182. <4057 4072 4069 4061 4060>,
  183. <3973 4009 4019 4016 4020>,
  184. <3932 3959 3981 3982 3983>,
  185. <3899 3928 3954 3950 3950>,
  186. <3868 3895 3925 3921 3920>,
  187. <3837 3866 3898 3894 3892>,
  188. <3812 3841 3853 3856 3862>,
  189. <3794 3818 3825 3823 3822>,
  190. <3780 3799 3804 3804 3803>,
  191. <3768 3787 3790 3788 3788>,
  192. <3757 3779 3778 3775 3776>,
  193. <3747 3772 3771 3766 3765>,
  194. <3736 3763 3766 3760 3746>,
  195. <3725 3749 3756 3747 3729>,
  196. <3714 3718 3734 3724 3706>,
  197. <3701 3703 3696 3689 3668>,
  198. <3675 3695 3682 3675 3662>,
  199. <3670 3691 3680 3673 3661>,
  200. <3661 3686 3679 3672 3656>,
  201. <3649 3680 3676 3669 3641>,
  202. <3633 3669 3667 3655 3606>,
  203. <3610 3647 3640 3620 3560>,
  204. <3580 3607 3596 3572 3501>,
  205. <3533 3548 3537 3512 3425>,
  206. <3457 3468 3459 3429 3324>,
  207. <3328 3348 3340 3297 3172>,
  208. <3000 3000 3000 3000 3000>;
  209. };
  210. qcom,rbatt-sf-lut {
  211. qcom,lut-col-legend = <(-20) 0 25 40 65>;
  212. qcom,lut-row-legend = <100 95 90 85 80 75 70>,
  213. <65 60 55 50 45 40 35>,
  214. <30 25 20 15 10 9 8>,
  215. <7 6 5 4 3 2 1 0>;
  216. qcom,lut-data = <357 187 100 91 91>,
  217. <400 208 105 94 94>,
  218. <390 204 106 95 96>,
  219. <391 201 108 98 98>,
  220. <391 202 110 98 100>,
  221. <390 200 110 99 102>,
  222. <389 200 110 99 102>,
  223. <393 202 101 93 100>,
  224. <407 205 99 89 94>,
  225. <428 208 100 91 96>,
  226. <455 212 102 92 98>,
  227. <495 220 104 93 101>,
  228. <561 232 107 95 102>,
  229. <634 245 112 98 98>,
  230. <714 258 114 98 98>,
  231. <791 266 114 97 100>,
  232. <871 289 108 95 97>,
  233. <973 340 124 108 105>,
  234. <489 241 109 96 99>,
  235. <511 246 110 96 99>,
  236. <534 252 111 95 98>,
  237. <579 263 112 96 96>,
  238. <636 276 111 95 97>,
  239. <730 294 109 96 99>,
  240. <868 328 112 98 104>,
  241. <1089 374 119 101 115>,
  242. <1559 457 128 105 213>,
  243. <12886 1026 637 422 3269>,
  244. <170899 127211 98968 88907 77102>;
  245. };
  246. qcom,ibat-acc-lut {
  247. qcom,lut-col-legend = <(-20) 0 25>;
  248. qcom,lut-row-legend = <0 250 500 1000>;
  249. qcom,lut-data = <1470 1470 1473>,
  250. <1406 1406 1430>,
  251. <1247 1247 1414>,
  252. <764 764 1338>;
  253. };
  254. };