ncp1854.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307
  1. /*****************************************************************************
  2. *
  3. * Filename:
  4. * ---------
  5. * ncp1854.h
  6. *
  7. * Project:
  8. * --------
  9. * Android
  10. *
  11. * Description:
  12. * ------------
  13. * ncp1854 header file
  14. *
  15. * Author:
  16. * -------
  17. *
  18. ****************************************************************************/
  19. #ifndef _NCP1854_SW_H_
  20. #define _NCP1854_SW_H_
  21. #define NCP1854_CON0 0x00
  22. #define NCP1854_CON1 0x01
  23. #define NCP1854_CON2 0x02
  24. #define NCP1854_CON3 0x03
  25. #define NCP1854_CON4 0x04
  26. #define NCP1854_CON5 0x05
  27. #define NCP1854_CON6 0x06
  28. #define NCP1854_CON7 0x07
  29. #define NCP1854_CON8 0x08
  30. #define NCP1854_CON9 0x09
  31. #define NCP1854_CON10 0x0A
  32. #define NCP1854_CON11 0x0B
  33. #define NCP1854_CON12 0x0C
  34. #define NCP1854_CON13 0x0D
  35. #define NCP1854_CON14 0x0E
  36. #define NCP1854_CON15 0x0F
  37. #define NCP1854_CON16 0x10
  38. #define NCP1854_CON17 0x11
  39. #define NCP1854_CON18 0x12
  40. #define ncp1854_REG_NUM 18
  41. /**********************************************************
  42. *
  43. * [MASK/SHIFT]
  44. *
  45. *********************************************************/
  46. /* CON0 */
  47. #define CON0_STATE_MASK 0x0F
  48. #define CON0_STATE_SHIFT 4
  49. #define CON0_BATFET_MASK 0x01
  50. #define CON0_BATFET_SHIFT 3
  51. #define CON0_STATINT_MASK 0x01
  52. #define CON0_STATINT_SHIFT 1
  53. #define CON0_FAULTINT_MASK 0x01
  54. #define CON0_FAULTINT_SHIFT 0
  55. /* CON1 */
  56. #define CON1_REG_RST_MASK 0x01
  57. #define CON1_REG_RST_SHIFT 7
  58. #define CON1_CHG_EN_MASK 0x01
  59. #define CON1_CHG_EN_SHIFT 6
  60. #define CON1_OTG_EN_MASK 0x01
  61. #define CON1_OTG_EN_SHIFT 5
  62. #define CON1_FCTRY_MOD_MASK 0x01
  63. #define CON1_FCTRY_MOD_SHIFT 4
  64. #define CON1_TJ_WARN_OPT_MASK 0x01
  65. #define CON1_TJ_WARN_OPT_SHIFT 3
  66. #define CON1_JEITA_OPT_MASK 0x01
  67. #define CON1_JEITA_OPT_SHIFT 2
  68. #define CON1_TCHG_RST_MASK 0x01
  69. #define CON1_TCHG_RST_SHIFT 1
  70. #define CON1_INT_MASK_MASK 0x01
  71. #define CON1_INT_MASK_SHIFT 0
  72. /* CON2 */
  73. #define CON2_WDTO_DIS_MASK 0x01
  74. #define CON2_WDTO_DIS_SHIFT 7
  75. #define CON2_CHGTO_DIS_MASK 0x01
  76. #define CON2_CHGTO_DIS_SHIFT 6
  77. #define CON2_PWR_PATH_MASK 0x01
  78. #define CON2_PWR_PATH_SHIFT 5
  79. #define CON2_TRANS_EN_MASK 0x01
  80. #define CON2_TRANS_EN_SHIFT 4
  81. #define CON2_IINSET_PIN_EN_MASK 0x01
  82. #define CON2_IINSET_PIN_EN_SHIFT 2
  83. #define CON2_IINLIM_EN_MASK 0x01
  84. #define CON2_IINLIM_EN_SHIFT 1
  85. #define CON2_AICL_EN_MASK 0x01
  86. #define CON2_AICL_EN_SHIFT 0
  87. /* CON3 */
  88. /* Status flag */
  89. /* CON4 */
  90. /* Status flag */
  91. /* CON5 */
  92. /* Status flag */
  93. /* CON6 */
  94. /* Boost mode interrupt */
  95. #define CON6_VOBSTOL2_MASK 0x01
  96. #define CON6_VOBSTOL2_SHIFT 3
  97. #define CON6_VOBSTOL1_MASK 0x01
  98. #define CON6_VOBSTOL1_SHIFT 2
  99. #define CON6_VBUSOV_MASK 0x01
  100. #define CON6_VBUSOV_SHIFT 1
  101. #define CON6_VBAT_NOK_MASK 0x01
  102. #define CON6_VBAT_NOK_SHIFT 0
  103. /* CON7 */
  104. /* Status flag */
  105. /* CON8 */
  106. #define CON8_NTC_RMV_MASK 0x01
  107. #define CON8_NTC_RMV_SHIFT 7
  108. #define CON8_VBAT_OV_MASK 0x01
  109. #define CON8_VBAT_OV_SHIFT 6
  110. #define CON8_VRECHG_OK_MASK 0x01
  111. #define CON8_VRECHG_OK_SHIFT 5
  112. #define CON8_VFET_OK_MASK 0x01
  113. #define CON8_VFET_OK_SHIFT 4
  114. #define CON8_VPRE_OK_MASK 0x01
  115. #define CON8_VPRE_OK_SHIFT 3
  116. #define CON8_VSAFE_OK_MASK 0x01
  117. #define CON8_VSAFE_OK_SHIFT 2
  118. #define CON8_IEOC_OK_MASK 0x01
  119. #define CON8_IEOC_OK_SHIFT 1
  120. /* CON9 */
  121. #define CON9_TSD_MASK 0x01
  122. #define CON9_TSD_SHIFT 3
  123. #define CON9_TM2_MASK 0x01
  124. #define CON9_TM2_SHIFT 2
  125. #define CON9_TM1_MASK 0x01
  126. #define CON9_TM1_SHIFT 1
  127. #define CON9_TWARN_MASK 0x01
  128. #define CON9_TWARN_SHIFT 0
  129. /* CON10 */
  130. /* Interrupt mask */
  131. /* CON11 */
  132. /* Interrupt mask */
  133. /* CON12 */
  134. /* Interrupt mask */
  135. /* CON13 */
  136. /* Interrupt mask */
  137. /* CON14 */
  138. #define CON14_CTRL_VBAT_MASK 0x3F
  139. #define CON14_CTRL_VBAT_SHIFT 0
  140. /* CON15 */
  141. #define CON15_ICHG_HIGH_MASK 0x01
  142. #define CON15_ICHG_HIGH_SHIFT 7
  143. #define CON15_IEOC_MASK 0x07
  144. #define CON15_IEOC_SHIFT 4
  145. #define CON15_ICHG_MASK 0x0F
  146. #define CON15_ICHG_SHIFT 0
  147. /* CON16 */
  148. #define CON16_IWEAK_MASK 0x03
  149. #define CON16_IWEAK_SHIFT 5
  150. #define CON16_CTRL_VFET_MASK 0x07
  151. #define CON16_CTRL_VFET_SHIFT 2
  152. #define CON16_IINLIM_MASK 0x3
  153. #define CON16_IINLIM_SHIFT 0
  154. /* CON17 */
  155. #define CON17_IINLIM_TA_MASK 0x0F
  156. #define CON17_IINLIM_TA_SHIFT 4
  157. /* CON18 */
  158. #define CON18_BATCOLD_MASK 0x07
  159. #define CON18_BATCOLD_SHIFT 5
  160. #define CON18_BATHOT_MASK 0x07
  161. #define CON18_BATHOT_SHIFT 2
  162. #define CON18_BATCHIL_MASK 0x01
  163. #define CON18_BATCHIL_SHIFT 1
  164. #define CON18_BATWARM_MASK 0x01
  165. #define CON18_BATWARM_SHIFT 0
  166. /**********************************************************
  167. *
  168. * [Extern Function]
  169. *
  170. *********************************************************/
  171. #define NCP1854_REG_NUM 18
  172. extern unsigned char ncp1854_reg[NCP1854_REG_NUM];
  173. /* CON0 */
  174. extern unsigned int ncp1854_get_chip_status(void);
  175. extern unsigned int ncp1854_get_batfet(void);
  176. extern unsigned int ncp1854_get_statint(void);
  177. extern unsigned int ncp1854_get_faultint(void);
  178. /* CON1 */
  179. extern void ncp1854_set_reset(unsigned int val);
  180. extern void ncp1854_set_chg_en(unsigned int val);
  181. extern void ncp1854_set_otg_en(unsigned int val);
  182. extern unsigned int ncp1854_get_otg_en(void);
  183. extern void ncp1854_set_fctry_mode(unsigned int val);
  184. extern void ncp1854_set_tj_warn_opt(unsigned int val);
  185. extern unsigned int ncp1854_get_usb_cfg(void);
  186. extern void ncp1854_set_tchg_rst(unsigned int val);
  187. extern void ncp1854_set_int_mask(unsigned int val);
  188. /* CON2 */
  189. extern void ncp1854_set_wdto_dis(unsigned int val);
  190. extern void ncp1854_set_chgto_dis(unsigned int val);
  191. extern void ncp1854_set_pwr_path(unsigned int val);
  192. extern void ncp1854_set_trans_en(unsigned int val);
  193. extern void ncp1854_set_chg_halt(unsigned int val);
  194. extern void ncp1854_set_iinset_pin_en(unsigned int val);
  195. extern void ncp1854_set_iinlim_en(unsigned int val);
  196. extern void ncp1854_set_aicl_en(unsigned int val);
  197. /* CON8 */
  198. extern unsigned int ncp1854_get_vfet_ok(void);
  199. /* CON14 */
  200. extern void ncp1854_set_ctrl_vbat(unsigned int val);
  201. /* CON15 */
  202. extern void ncp1854_set_ieoc(unsigned int val);
  203. extern void ncp1854_set_ichg_high(unsigned int val);
  204. extern void ncp1854_set_ichg(unsigned int val);
  205. extern unsigned int ncp1854_get_ichg(void);
  206. /* CON16 */
  207. extern void ncp1854_set_iweak(unsigned int val);
  208. extern void ncp1854_set_ctrl_vfet(unsigned int val);
  209. extern void ncp1854_set_iinlim(unsigned int val);
  210. /* CON17 */
  211. extern void ncp1854_set_iinlim_ta(unsigned int val);
  212. extern void ncp1854_dump_register(void);
  213. extern void ncp1854_read_register(int i);
  214. #endif /* _NCP1854_SW_H_ */