ml5238.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #ifndef _ML5238_H__
  2. #define _ML5238_H__
  3. #include "bsp/clock.h"
  4. void ml5238_init(void);
  5. void ml5238_softreset(void);
  6. int ml5238_enable_discharger_mosfet(int enable);
  7. int ml5238_enable_charger_mosfet(int enable);
  8. int ml5238_short_current_detect(int mode);
  9. int ml5238_is_load_disconnect(void);
  10. int ml5238_enable_load_detect(int enable);
  11. void ml5238_cell_start_balance(uint16_t balance_mask);
  12. void ml5238_power_down(void);
  13. void ml5238_power_save(int save);
  14. int ml5238_charger_is_disconnect(int small_current_on);
  15. int ml5238_enable_charger_detect(int small_current_on, int enable);
  16. int ml5238_is_charging(void);
  17. int ml5238_is_discharging(void);
  18. typedef void (*ml5238_notify_hander)(int event);
  19. void ml5238_register_notify_handler(ml5238_notify_hander handler);
  20. #define ML5238_Event_Charger_Over_Current 1
  21. #define ML5238_Event_Short_Current 2
  22. #define ML5238_Event_Load_Disconnect 3
  23. #define SHORT_CURRENT_MODE_DISABLE -1
  24. #define SHORT_CURRENT_MODE_50A_100A 0 //sp600: 50A, SP700: 100A
  25. #define SHORT_CURRENT_MODE_100A_200A 1 //sp600: 100A SP700: 200A
  26. #define SHORT_CURRENT_MODE_150A_300A 2 //sp600: 150A Sp700: 300A
  27. #define SHORT_CURRENT_MODE_200A_400A 3 //sp600:200A SP700: 400A
  28. /* ml5238 will amplify the vmon val by 0.5, so we need
  29. * multi 2 to the adc value, to get the real vol
  30. */
  31. #define cell_real_vol(v) (v * 2)
  32. #include "ml5238_reg.h"
  33. int ml5238_write(uint8_t regaddr, uint8_t data);
  34. /* disable the vmon output the cell voltage */
  35. #define ML5238_VMON_DISABLE() {ml5238_write(ML5238_VMON, 0x00);};
  36. /* select one cell (0-14) connect to vmon, so we can measure
  37. * the cell voltage from vmon pin
  38. */
  39. #define ML5238_SELECT_CELL(i) {ml5238_write(ML5238_VMON, i | VMON_OUT);};
  40. /* IMON output disable */
  41. #define ML5238_IMON_DISABLE() {ml5238_write(ML5238_IMON, 0x02);};
  42. /* IMON output 0V, used to cali the GAIN */
  43. #define ML5238_IMON_OUT_ZERO_10X() {ml5238_write(ML5238_IMON, 0x12);delay_us(1000);};
  44. #define ML5238_IMON_OUT_ZERO_50X() {ml5238_write(ML5238_IMON, 0x13);delay_us(5000);};
  45. /* IMON output 2V, used to cali the GAIN */
  46. #define ML5238_IMON_OUT_V2000_10X() {ml5238_write(ML5238_IMON, 0x14);delay_us(1000);};
  47. #define ML5238_IMON_OUT_V2000_50X() {ml5238_write(ML5238_IMON, 0x15);delay_us(5000);};
  48. /* IMON output 100mV, used to cali the GAIN */
  49. #define ML5238_IMON_OUT_V100_10X() {ml5238_write(ML5238_IMON, 0x1c);delay_us(1000);};
  50. #define ML5238_IMON_OUT_V100_50X() {ml5238_write(ML5238_IMON, 0x1d);delay_us(5000);};
  51. /* IMON output real pin's voltage */
  52. #define ML5238_IMON_OUT_10X() {ml5238_write(ML5238_IMON, 0x10);delay_us(1000);};
  53. #define ML5238_IMON_OUT_50X() {ml5238_write(ML5238_IMON, 0x11);delay_us(5000);};
  54. //vim0 == xxx_OUT_ZERO_xxx, vim1 == xxx_OUT_V2000_xxx, vr == xxx_OUT_V100_xxx
  55. #define ML5238_GAIN(vim0, vim1, vr) ((vim1-vim0)/vr)
  56. //r_v :real voltage, gain == ML5238_GAIN
  57. #define ML5238_V_RSENSER(r_v, vim0, gain) ((vim0 - r_v)/gain)
  58. #endif /* _ML5238_H__ */