smb1360-charger-fg.txt 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. SMB1360 battery charger and fuel gauge
  2. SMB1360 is a single path switch-mode battery charger and
  3. fuel gauge. The charger has a max current rating of 1.5A.
  4. The fuel gauge uses voltage + coulomb counting to report
  5. the state of charge.
  6. The smb1360 interface is via I2C bus.
  7. Required Properties:
  8. - compatible: Must be "qcom,smb1360-charger-fg"
  9. - reg: The device 7-bit I2C address.
  10. Optional Properties:
  11. - interrupts This indicates the IRQ number of the GPIO
  12. connected to the STAT pin.
  13. - pinctrl-names: The state name of the pin configuration. Only
  14. support: "default".
  15. - pinctrl-0: The phandle of the pin configuration node in
  16. pinctrl for smb_int_pin.
  17. For details of pinctrl properties, please refer to:
  18. "Documentation/devicetree/bindings/pinctrl/pinctrl-bindings.txt"
  19. - qcom,float-voltage-mv Float Voltage in mV - the maximum voltage up to which
  20. the battery is charged. Supported range 3460V to 4360V
  21. - qcom,charging-timeout Maximum duration in minutes that a single charge
  22. cycle may last. Supported values are: 0, 192, 384,
  23. 768, and 1536. A value of 0 means that no
  24. charge cycle timeout is used and charging can
  25. continue indefinitely.
  26. - qcom,charging-disabled Set this if charging should be disabled in the build
  27. by default. Useful in usecases where battery current
  28. needs to be profiled even when USB is present.
  29. - qcom,recharge-thresh-mv Specifies the minimum voltage drop in millivolts
  30. below the float voltage that is required in
  31. order to initiate a new charging cycle.
  32. Supported values are: 50, 100, 200 and 300mV.
  33. - qcom,recharge-disabled Disabled the auto-recharge function
  34. - qcom,iterm-ma Specifies the termination current to indicate end-of-charge.
  35. Possible values in mA - 25, 50, 75, 100, 125, 150, 175, 200
  36. - qcom,iterm-disabled Disables the termination current feature. This is a bool
  37. property.
  38. - qcom,chg-inhibit-disabled Disables the charger-inhibit function.
  39. - qcom,disable-ov-ends-chg-cycle
  40. The boolean property to indicate if the ov-ends-charge-cycle
  41. feature is disabled. If the feature is disabled, charging
  42. could be resumed from battery OV (over voltage) status; otherwise,
  43. charging cycle will be terminated after battery OV event and
  44. won't be resumed until disable/enable charging.
  45. - qcom,batt-id-disabled Disabled the batt-id function. Doing this will
  46. disable the ability of RID based battery profile selection.
  47. - qcom,fg-delta-soc The delta in SOC which will generate an interrupt
  48. - qcom,fg-soc-max SOC value (max) at which an interrupt is generated.
  49. This can be used to alert the system when the
  50. battery reaches a specific (maximum) SOC value.
  51. - qcom,fg-soc-min SOC value (min) at which an interrupt is generated.
  52. This can be used to alert the system when the
  53. battery reaches a specific (minimum) SOC value.
  54. - qcom,fg-voltage-min-mv The minimum volatge at which an interrupt is generated.
  55. This can be used as an alert mechanism.
  56. - qcom,fg-voltage-empty-mv The voltage which indicates the battery is empty.
  57. - qcom,thermal-mitigation: Array of input current limit values for different
  58. system thermal mitigation level.
  59. - qcom,stat-pulsed-irq: A boolean flag to indicate the state-irq pin will generate pulse
  60. signal when interrupt happened. If this property is not specified,
  61. the default configuration is static level irq.
  62. - qcom,shdn-after-pwroff: A bool property to configure smb1360 for shutdown at power-off.
  63. - qcom,empty-soc-disabled: A bool property to indicate whether stop updating empty_soc flag.
  64. System reports 0% SOC when empty_soc being set.
  65. - qcom,awake-min-soc A bool property to indicate whether the system is prevented from
  66. sleeping when SOC is under the min_soc threshold.
  67. - qcom,batt-profile-select A boolean flag to indicate of battery-profile
  68. selection is enabled.
  69. - qcom,profile-a-rid-kohm The battery-ID resistor (RID) in Kohm supported by
  70. profile-A of SMB1360. This should be specified
  71. if 'batt-profile-select' is defined.
  72. - qcom,profile-b-rid-kohm The battery-ID resistor (RID) in Kohm supported by
  73. profile-B of SMB1360. This should be specified
  74. if 'batt-profile-select' is defined.
  75. - qcom,batt-id-vref-uv The reference voltage on the battery-ID line
  76. specified in micro-volts.
  77. - qcom,batt-id-rpullup-kohm The pull-up resistor connected on the battery-ID
  78. (vref) line.
  79. - qcom,smb1360-vadc VADC device phandle (used for reading the RID)
  80. - qcom,fg-batt-capacity-mah The new battery capacity to be supported.
  81. This updates the ACTUAL and NOMINAL CAPACITY
  82. of the profile.
  83. - qcom,fg-cc-soc-coeff The CC_TO_SOC_COEFF of the new battery capacity.
  84. This is updated only if 'fg-batt-capacity-mah'
  85. is specified. This value is calculated from the
  86. batt-capacity and then encoded as floating number.
  87. cc_soc_coeff = HALF_ENCODING(8192 / batt-capacity)
  88. - qcom,fg-cutoff-voltage-mv This is the minimum allowed system voltage. The
  89. FG will report SOC = 0 at this volatge. This
  90. value is in mv.
  91. - qcom,fg-iterm-ma This is termination current at which the
  92. Monotonic SOC reports 100. The value passed here
  93. is negated in the driver (assuming that the iterm
  94. is always -ve). This value is in mA.
  95. - qcom,fg-ibatt-standby-ma This is the minimum current value for the SOC to
  96. be above 0% at the cutoff voltage. This value
  97. is in mA.
  98. - qcom,fg-cc-to-cv-mv This is the voltage at which the FG transitions
  99. from CC to CV. This value should never be
  100. higher than the float volatge. Its in mV.
  101. - qcom,thermistor-c1-coeff This is the NTC thermistor C1 coeff for the
  102. thermistor inside the battery. This value is
  103. 16-bit float encoded value determined from the
  104. NTC-c1_coeff mapping.
  105. - qcom,otg-batt-curr-limit This property defines the current threshold draw
  106. from battery when device working at OTG mode.
  107. The possible values are: 350, 550, 950, 1500mA.
  108. - qcom,fg-auto-recharge-soc This property defines the auto recharging SOC threshold.
  109. - qcom,min-icl-100ma A bool property to set the minimum ICL current
  110. to 100mA. If this property is not set the minimum
  111. ICL is set to 500mA in all the scenarios.
  112. - qcom,config-hard-thresholds This property indicates if cold and hot thresholds need be modified.
  113. If it's not defined, default temp thresholds will be used. If this
  114. defined, it's required to specify the "qcom,hot-bat-decidegc" and
  115. "qcom,cold-bat-decidegc" values. If this defined, the serial properties
  116. (qcom,otp-hard-jeita-config, qcom,otp-hot-bat-decidegc,
  117. qcom,otp-cold-bat-decidegc) mustn't be defined.
  118. - qcom,hot-bat-decidegc Hot battery temperature in decidegC. This property should only be
  119. defined when "qcom,config-hard-thresholds" defined, and the value
  120. must be out of range [0, 55].
  121. - qcom,cold-bat-decidegc Cold battery temperature in decidegC. This property should only be
  122. defined when "qcom,config-hard-thresholds" defined, and the value
  123. must be out of range [0, 55].
  124. - qcom,otp-hard-jeita-config This property indicates if cold and hot thresholds need be modified.
  125. If it's not defined, default temp thresholds [0, 55] will be used.
  126. If this defined, it's required to specify the "qcom,otp-hot-bat-decidegc"
  127. and "qcom,otp-cold-bat-decidegc" values. If this is defined, the serial
  128. properties (qcom,config-hard-thresholds, qcom,hot-bat-decidegc,
  129. qcom,cold-bat-decidegc) mustn't be defined.
  130. - qcom,otp-hot-bat-decidegc Hot battery temperature in decidegC. This property could only be
  131. defined when qcom,config-otp-hard-jeita exist.
  132. - qcom,otp-cold-bat-decidegc Cold battery temperature in decidegC. This property could only be
  133. defined when qcom,config-otp-hard-jeita exist.
  134. - qcom,otp-hard-jeita-hysteresis This property contains two intergers to define the temperature
  135. hysteresis (in decidegC unit) for hard cold and hard hot.
  136. This property could only be defined when qcom,config-otp-hard-jeita exist.
  137. - qcom,soft-jeita-supported This property indicates whether soft jeita supported.
  138. - qcom,warm-bat-decidegc Warm battery temperature in decidegC. After hitting this threshold,
  139. "qcom,warm-bat-ma" defines maximum charging current and
  140. "qcom,warm-bat-mv" defines maximum target voltage.
  141. This property must be in range [0, 55] if needed.
  142. - qcom,cool-bat-decidegc Cool battery temperature in decidegC. After hitting this threshold,
  143. "qcom,cool-bat-ma" defines maximum charging current and
  144. "qcom,cool-bat-mv" defines maximum target voltage.
  145. This property must be in range [0, 55] if needed.
  146. - qcom,warm-bat-mv Maximum warm battery target voltage in milli-volts.
  147. - qcom,cool-bat-mv Maximum cool battery target voltage in milli-volts.
  148. - qcom,warm-bat-ma Maximum warm battery charge current in milli-amps.
  149. - qcom,cool-bat-ma Maximum cool battery charge current in milli-amps.
  150. - qcom,fg-reset-at-pon This is a bool property which indicates if the
  151. FG reset at power-on is enabled.
  152. - qcom,fg-reset-thresold-mv This value indicates the volatge threshold to
  153. reset the FG. This value is compared against
  154. the difference between in predicted voltage and
  155. current voltage. If this value is not specified
  156. a default value of 50mV is used. Unit is in milli-volts.
  157. - qcom,rsense-10mhom A bool property to indicate the Rsense resistor
  158. configuration. If set, the Rsense is 10mOhm else
  159. its 20mOhm.
  160. - qcom,otg-fet-present A bool property to indicate that a pMOS FET is present
  161. to boost the OTG current. On enabling this the max OTG
  162. current supported is 3x(qcom,otg-batt-curr-limit).
  163. - qcom,otg-fet-enable-gpio GPIO for enabling and disabling OTG FET.
  164. Following should be the PMIC gpio configuration:
  165. {
  166. qcom,mode = <1>; //Digital output
  167. qcom,pull = <0>; //Pull up configuration
  168. qcom,vin-sel = <0>; //Voltage level: VPH_PWR
  169. qcom,src-sel = <0>; //Pin function: GPIO
  170. qcom,master-en = <1>; //Enable
  171. }
  172. Please go through the documentation for PMIC gpio
  173. configuration details:
  174. Documentation/devicetree/bindings/gpio/qpnp-pin.txt
  175. - qcom,parallel-charging-enabled: A bool property which enables SMB1360 to
  176. operate in the parallel mode. SMB1360 acts
  177. as the primary charger.
  178. - qcom,max-parallel-current-ma: This is the max charging current which can be
  179. drawn from the secondary charger. If this is
  180. not specified this value defaults to 540mA.
  181. The overall current charging current is
  182. 1500mA(from SMB) + qcom,max-parallel-current-ma.
  183. Example:
  184. i2c@f9967000 {
  185. smb1360-chg-fg@1b {
  186. compatible = "qcom,smb1360-chg-fg";
  187. reg = <0x1b>;
  188. interrupt-parent = <&spmi_bus>;
  189. interrupts = <0x00 0xcd 0>;
  190. pinctrl-names = "default";
  191. pinctrl-0 = <&smb_int_default>;
  192. /* battery-profile selection properties */
  193. qcom,batt-profile-select;
  194. qcom,smb1360-vadc = <&pm8916_vadc>;
  195. qcom,batt-id-vref-uv = <1800000>;
  196. qcom,batt-id-rpullup-kohm = <100>;
  197. qcom,profile-a-rid-kohm = <78>;
  198. qcom,profile-b-rid-kohm = <200>;
  199. /* battery capacity */
  200. qcom,fg-batt-capacity-mah = <4000>;
  201. qcom,fg-cc-soc-coeff = <0x8009>;
  202. qcom,fg-cutoff-voltage-mv = <3300>;
  203. qcom,fg-iterm-ma = <100>;
  204. qcom,fg-ibatt-standby-ma = <200>;
  205. qcom,fg-cc-to-cv-mv = <4180>;
  206. qcom,thermistor-c1-coeff = <0x86DB>;
  207. qcom,float-voltage-mv = <4200>;
  208. qcom,iterm-ma = <100>;
  209. qcom,charging-disabled;
  210. qcom,recharge-thresh-mv = <100>;
  211. qcom,fg-soc-max = <85>;
  212. qcom,fg-soc-min = <15>;
  213. qcom,fg-auto-recharge-soc = <99>;
  214. qcom,thermal-mitigation = <1500 700 300 0>;
  215. qcom,config-hard-thresholds;
  216. qcom,hot-bat-decidegc = <650>;
  217. qcom,cold-bat-decidegc = <(-100)>;
  218. qcom,soft-jeita-supported;
  219. qcom,warm-bat-decidegc = <450>;
  220. qcom,cool-bat-decidegc = <100>;
  221. qcom,otp-hard-jeita-config;
  222. qcom,otp-hot-bat-decidegc = <550>;
  223. qcom,otp-cold-bat-decidegc = <0>;
  224. qcom,otp-hard-jeita-hysteresis = <0, 50>;
  225. qcom,warm-bat-mv = <4100>;
  226. qcom,cool-bat-mv = <4100>;
  227. qcom,warm-bat-ma = <750>;
  228. qcom,cool-bat-ma = <750>;
  229. qcom,otg-batt-curr-limit = <950>;
  230. qcom,fg-reset-at-pon;
  231. qcom,otg-fet-present;
  232. qcom,otg-fet-enable-gpio = <&pm8916_gpios 3 0>;
  233. };
  234. };