pmic_tps65217.c 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. /*
  2. * (C) Copyright 2011-2013
  3. * Texas Instruments, <www.ti.com>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #include <common.h>
  8. #include <i2c.h>
  9. #include <power/tps65217.h>
  10. /**
  11. * tps65217_reg_read() - Generic function that can read a TPS65217 register
  12. * @src_reg: Source register address
  13. * @src_val: Address of destination variable
  14. * @return: 0 for success, not 0 on failure.
  15. */
  16. int tps65217_reg_read(uchar src_reg, uchar *src_val)
  17. {
  18. return i2c_read(TPS65217_CHIP_PM, src_reg, 1, src_val, 1);
  19. }
  20. /**
  21. * tps65217_reg_write() - Generic function that can write a TPS65217 PMIC
  22. * register or bit field regardless of protection
  23. * level.
  24. *
  25. * @prot_level: Register password protection. Use
  26. * TPS65217_PROT_LEVEL_NONE,
  27. * TPS65217_PROT_LEVEL_1 or TPS65217_PROT_LEVEL_2
  28. * @dest_reg: Register address to write.
  29. * @dest_val: Value to write.
  30. * @mask: Bit mask (8 bits) to be applied. Function will only
  31. * change bits that are set in the bit mask.
  32. *
  33. * @return: 0 for success, not 0 on failure, as per the i2c API
  34. */
  35. int tps65217_reg_write(uchar prot_level, uchar dest_reg, uchar dest_val,
  36. uchar mask)
  37. {
  38. uchar read_val;
  39. uchar xor_reg;
  40. int ret;
  41. /*
  42. * If we are affecting only a bit field, read dest_reg and apply the
  43. * mask
  44. */
  45. if (mask != TPS65217_MASK_ALL_BITS) {
  46. ret = i2c_read(TPS65217_CHIP_PM, dest_reg, 1, &read_val, 1);
  47. if (ret)
  48. return ret;
  49. read_val &= (~mask);
  50. read_val |= (dest_val & mask);
  51. dest_val = read_val;
  52. }
  53. if (prot_level > 0) {
  54. xor_reg = dest_reg ^ TPS65217_PASSWORD_UNLOCK;
  55. ret = i2c_write(TPS65217_CHIP_PM, TPS65217_PASSWORD, 1,
  56. &xor_reg, 1);
  57. if (ret)
  58. return ret;
  59. }
  60. ret = i2c_write(TPS65217_CHIP_PM, dest_reg, 1, &dest_val, 1);
  61. if (ret)
  62. return ret;
  63. if (prot_level == TPS65217_PROT_LEVEL_2) {
  64. ret = i2c_write(TPS65217_CHIP_PM, TPS65217_PASSWORD, 1,
  65. &xor_reg, 1);
  66. if (ret)
  67. return ret;
  68. ret = i2c_write(TPS65217_CHIP_PM, dest_reg, 1, &dest_val, 1);
  69. if (ret)
  70. return ret;
  71. }
  72. return 0;
  73. }
  74. /**
  75. * tps65217_voltage_update() - Function to change a voltage level, as this
  76. * is a multi-step process.
  77. * @dc_cntrl_reg: DC voltage control register to change.
  78. * @volt_sel: New value for the voltage register
  79. * @return: 0 for success, not 0 on failure.
  80. */
  81. int tps65217_voltage_update(uchar dc_cntrl_reg, uchar volt_sel)
  82. {
  83. if ((dc_cntrl_reg != TPS65217_DEFDCDC1) &&
  84. (dc_cntrl_reg != TPS65217_DEFDCDC2) &&
  85. (dc_cntrl_reg != TPS65217_DEFDCDC3))
  86. return 1;
  87. /* set voltage level */
  88. if (tps65217_reg_write(TPS65217_PROT_LEVEL_2, dc_cntrl_reg, volt_sel,
  89. TPS65217_MASK_ALL_BITS))
  90. return 1;
  91. /* set GO bit to initiate voltage transition */
  92. if (tps65217_reg_write(TPS65217_PROT_LEVEL_2, TPS65217_DEFSLEW,
  93. TPS65217_DCDC_GO, TPS65217_DCDC_GO))
  94. return 1;
  95. return 0;
  96. }