ml5238.h 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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. typedef void (*ml5238_notify_hander)(int event);
  13. void ml5238_register_notify_handler(ml5238_notify_hander handler);
  14. #define ML5238_Event_Charger_Over_Current 1
  15. #define ML5238_Event_Short_Current 2
  16. #define ML5238_Event_Load_Disconnect 3
  17. #define SHORT_CURRENT_MODE_DISABLE -1
  18. #define SHORT_CURRENT_MODE_33_3A 0
  19. #define SHORT_CURRENT_MODE_66_6A 1
  20. #define SHORT_CURRENT_MODE_100A 2
  21. #define SHORT_CURRENT_MODE_133_3A 3
  22. /* ml5238 will amplify the vmon val by 0.5, so we need
  23. * multi 2 to the adc value, to get the real vol
  24. */
  25. #define cell_real_vol(v) (v * 2)
  26. #include "ml5238_reg.h"
  27. int ml5238_write(uint8_t regaddr, uint8_t data);
  28. /* disable the vmon output the cell voltage */
  29. #define ML5238_VMON_DISABLE() {ml5238_write(ML5238_VMON, 0x00);};
  30. /* select one cell (0-14) connect to vmon, so we can measure
  31. * the cell voltage from vmon pin
  32. */
  33. #define ML5238_SELECT_CELL(i) {ml5238_write(ML5238_VMON, i | VMON_OUT);};
  34. /* IMON output disable */
  35. #define ML5238_IMON_DISABLE() {ml5238_write(ML5238_IMON, 0x02);};
  36. /* IMON output 0V, used to cali the GAIN */
  37. #define ML5238_IMON_OUT_ZERO_10X() {ml5238_write(ML5238_IMON, 0x12);delay_us(1000);};
  38. #define ML5238_IMON_OUT_ZERO_50X() {ml5238_write(ML5238_IMON, 0x13);delay_us(5000);};
  39. /* IMON output 2V, used to cali the GAIN */
  40. #define ML5238_IMON_OUT_V2000_10X() {ml5238_write(ML5238_IMON, 0x14);delay_us(1000);};
  41. #define ML5238_IMON_OUT_V2000_50X() {ml5238_write(ML5238_IMON, 0x15);delay_us(5000);};
  42. /* IMON output 100mV, used to cali the GAIN */
  43. #define ML5238_IMON_OUT_V100_10X() {ml5238_write(ML5238_IMON, 0x1c);delay_us(1000);};
  44. #define ML5238_IMON_OUT_V100_50X() {ml5238_write(ML5238_IMON, 0x1d);delay_us(5000);};
  45. /* IMON output real pin's voltage */
  46. #define ML5238_IMON_OUT_10X() {ml5238_write(ML5238_IMON, 0x10);delay_us(1000);};
  47. #define ML5238_IMON_OUT_50X() {ml5238_write(ML5238_IMON, 0x11);delay_us(5000);};
  48. //vim0 == xxx_OUT_ZERO_xxx, vim1 == xxx_OUT_V2000_xxx, vr == xxx_OUT_V100_xxx
  49. #define ML5238_GAIN(vim0, vim1, vr) ((vim1-vim0)/vr)
  50. //r_v :real voltage, gain == ML5238_GAIN
  51. #define ML5238_V_RSENSER(r_v, vim0, gain) ((r_v-vim0)/gain)
  52. #endif /* _ML5238_H__ */