pmic_max77693.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2013 Samsung Electronics
  4. * Piotr Wilczek <p.wilczek@samsung.com>
  5. */
  6. #include <common.h>
  7. #include <power/pmic.h>
  8. #include <power/max77693_pmic.h>
  9. #include <i2c.h>
  10. #include <errno.h>
  11. static int max77693_charger_state(struct pmic *p, int state, int current)
  12. {
  13. unsigned int val;
  14. if (pmic_probe(p))
  15. return -ENODEV;
  16. /* unlock write capability */
  17. val = MAX77693_CHG_UNLOCK;
  18. pmic_reg_write(p, MAX77693_CHG_CNFG_06, val);
  19. if (state == PMIC_CHARGER_DISABLE) {
  20. puts("Disable the charger.\n");
  21. pmic_reg_read(p, MAX77693_CHG_CNFG_00, &val);
  22. val &= ~0x01;
  23. pmic_reg_write(p, MAX77693_CHG_CNFG_00, val);
  24. return -ENOTSUPP;
  25. }
  26. if (current < CHARGER_MIN_CURRENT || current > CHARGER_MAX_CURRENT) {
  27. printf("%s: Wrong charge current: %d [mA]\n",
  28. __func__, current);
  29. return -EINVAL;
  30. }
  31. /* set charging current */
  32. pmic_reg_read(p, MAX77693_CHG_CNFG_02, &val);
  33. val &= ~MAX77693_CHG_CC;
  34. val |= current * 10 / 333; /* 0.1A/3 steps */
  35. pmic_reg_write(p, MAX77693_CHG_CNFG_02, val);
  36. /* enable charging */
  37. val = MAX77693_CHG_MODE_ON;
  38. pmic_reg_write(p, MAX77693_CHG_CNFG_00, val);
  39. /* check charging current */
  40. pmic_reg_read(p, MAX77693_CHG_CNFG_02, &val);
  41. val &= 0x3f;
  42. printf("Enable the charger @ %d [mA]\n", val * 333 / 10);
  43. return 0;
  44. }
  45. static int max77693_charger_bat_present(struct pmic *p)
  46. {
  47. unsigned int val;
  48. if (pmic_probe(p))
  49. return -ENODEV;
  50. pmic_reg_read(p, MAX77693_CHG_INT_OK, &val);
  51. return !(val & MAX77693_CHG_DETBAT);
  52. }
  53. static struct power_chrg power_chrg_pmic_ops = {
  54. .chrg_bat_present = max77693_charger_bat_present,
  55. .chrg_state = max77693_charger_state,
  56. };
  57. int pmic_init_max77693(unsigned char bus)
  58. {
  59. static const char name[] = "MAX77693_PMIC";
  60. struct pmic *p = pmic_alloc();
  61. if (!p) {
  62. printf("%s: POWER allocation error!\n", __func__);
  63. return -ENOMEM;
  64. }
  65. debug("Board PMIC init\n");
  66. p->name = name;
  67. p->interface = PMIC_I2C;
  68. p->number_of_regs = PMIC_NUM_OF_REGS;
  69. p->hw.i2c.addr = MAX77693_PMIC_I2C_ADDR;
  70. p->hw.i2c.tx_num = 1;
  71. p->bus = bus;
  72. p->chrg = &power_chrg_pmic_ops;
  73. return 0;
  74. }