pmic_max8997.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2012 Samsung Electronics
  4. * Lukasz Majewski <l.majewski@samsung.com>
  5. */
  6. #include <common.h>
  7. #include <power/pmic.h>
  8. #include <power/max8997_pmic.h>
  9. #include <i2c.h>
  10. #include <errno.h>
  11. unsigned char max8997_reg_ldo(int uV)
  12. {
  13. unsigned char ret;
  14. if (uV <= 800000)
  15. return 0;
  16. if (uV >= 3950000)
  17. return MAX8997_LDO_MAX_VAL;
  18. ret = (uV - 800000) / 50000;
  19. if (ret > MAX8997_LDO_MAX_VAL) {
  20. printf("MAX8997 LDO SETTING ERROR (%duV) -> %u\n", uV, ret);
  21. ret = MAX8997_LDO_MAX_VAL;
  22. }
  23. return ret;
  24. }
  25. static int pmic_charger_state(struct pmic *p, int state, int current)
  26. {
  27. unsigned char fc;
  28. u32 val = 0;
  29. if (pmic_probe(p))
  30. return -ENODEV;
  31. if (state == PMIC_CHARGER_DISABLE) {
  32. puts("Disable the charger.\n");
  33. pmic_reg_read(p, MAX8997_REG_MBCCTRL2, &val);
  34. val &= ~(MBCHOSTEN | VCHGR_FC);
  35. pmic_reg_write(p, MAX8997_REG_MBCCTRL2, val);
  36. return -ENOTSUPP;
  37. }
  38. if (current < CHARGER_MIN_CURRENT || current > CHARGER_MAX_CURRENT) {
  39. printf("%s: Wrong charge current: %d [mA]\n",
  40. __func__, current);
  41. return -EINVAL;
  42. }
  43. fc = (current - CHARGER_MIN_CURRENT) / CHARGER_CURRENT_RESOLUTION;
  44. fc = fc & 0xf; /* up to 950 mA */
  45. printf("Enable the charger @ %d [mA]\n", fc * CHARGER_CURRENT_RESOLUTION
  46. + CHARGER_MIN_CURRENT);
  47. val = fc | MBCICHFCSET;
  48. pmic_reg_write(p, MAX8997_REG_MBCCTRL4, val);
  49. pmic_reg_read(p, MAX8997_REG_MBCCTRL2, &val);
  50. val = MBCHOSTEN | VCHGR_FC; /* enable charger & fast charge */
  51. pmic_reg_write(p, MAX8997_REG_MBCCTRL2, val);
  52. return 0;
  53. }
  54. static int pmic_charger_bat_present(struct pmic *p)
  55. {
  56. u32 val;
  57. if (pmic_probe(p))
  58. return -ENODEV;
  59. pmic_reg_read(p, MAX8997_REG_STATUS4, &val);
  60. return !(val & DETBAT);
  61. }
  62. static struct power_chrg power_chrg_pmic_ops = {
  63. .chrg_bat_present = pmic_charger_bat_present,
  64. .chrg_state = pmic_charger_state,
  65. };
  66. int pmic_init(unsigned char bus)
  67. {
  68. static const char name[] = "MAX8997_PMIC";
  69. struct pmic *p = pmic_alloc();
  70. if (!p) {
  71. printf("%s: POWER allocation error!\n", __func__);
  72. return -ENOMEM;
  73. }
  74. debug("Board PMIC init\n");
  75. p->name = name;
  76. p->interface = PMIC_I2C;
  77. p->number_of_regs = PMIC_NUM_OF_REGS;
  78. p->hw.i2c.addr = MAX8997_I2C_ADDR;
  79. p->hw.i2c.tx_num = 1;
  80. p->bus = bus;
  81. p->chrg = &power_chrg_pmic_ops;
  82. return 0;
  83. }