blob: 3ac971234013e5bc10c93e51a460132420323353 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
SRICHARAN R21144292012-03-12 02:25:48 +00002/*
Nishanth Menoncb199102013-03-26 05:20:54 +00003 * (C) Copyright 2012-2013
SRICHARAN R21144292012-03-12 02:25:48 +00004 * Texas Instruments, <www.ti.com>
SRICHARAN R21144292012-03-12 02:25:48 +00005 */
6#include <config.h>
Nishanth Menoncb199102013-03-26 05:20:54 +00007#include <palmas.h>
Simon Glass1e94b462023-09-14 18:21:46 -06008#include <linux/printk.h>
SRICHARAN R21144292012-03-12 02:25:48 +00009
Nishanth Menon12733882013-03-26 05:20:55 +000010void palmas_init_settings(void)
SRICHARAN R21144292012-03-12 02:25:48 +000011{
Lubomir Popove9090fa2013-06-06 04:16:40 +000012#ifdef CONFIG_PALMAS_SMPS7_FPWM
13 int err;
14 /*
15 * Set SMPS7 (1.8 V I/O supply on platforms with TWL6035/37) to
16 * forced PWM mode. This reduces noise (but affects efficiency).
17 */
18 u8 val = SMPS_MODE_SLP_FPWM | SMPS_MODE_ACT_FPWM;
19 err = palmas_i2c_write_u8(TWL603X_CHIP_P1, SMPS7_CTRL, val);
20 if (err)
21 printf("palmas: could not force PWM for SMPS7: err = %d\n",
22 err);
23#endif
SRICHARAN R21144292012-03-12 02:25:48 +000024}
Balaji T Kdd23e592012-03-12 02:25:49 +000025
Lokesh Vutlab4b06002016-11-23 13:25:28 +053026#if defined(CONFIG_OMAP54XX)
27int lp873x_mmc1_poweron_ldo(uint voltage)
28{
29 if (palmas_i2c_write_u8(LP873X_LDO1_ADDR, LP873X_LDO1_VOLTAGE,
30 voltage)) {
31 printf("lp873x: could not set LDO1 voltage.\n");
32 return 1;
33 }
34 /* TURN ON LDO1 */
35 if (palmas_i2c_write_u8(LP873X_LDO1_ADDR, LP873X_LDO1_CTRL,
36 LP873X_LDO_CTRL_EN | LP873X_LDO_CTRL_RDIS_EN)) {
37 printf("lp873x: could not turn on LDO1.\n");
38 return 1;
39 }
40 return 0;
41
42}
43#endif
44
Lokesh Vutladb4fce82017-08-21 12:50:50 +053045int palmas_mmc1_poweron_ldo(uint ldo_volt, uint ldo_ctrl, uint voltage)
Balaji T Kdd23e592012-03-12 02:25:49 +000046{
47 u8 val = 0;
48
Nishanth Menon3891a542016-11-29 15:22:00 +053049#if defined(CONFIG_DRA7XX)
Jaehoon Chung505cf472016-12-15 20:49:50 +090050 int ret;
Lokesh Vutladb4fce82017-08-21 12:50:50 +053051
52 ret = palmas_i2c_write_u8(TPS65903X_CHIP_P1, ldo_volt, voltage);
Jaehoon Chung505cf472016-12-15 20:49:50 +090053 if (ret) {
Lubomir Popove9090fa2013-06-06 04:16:40 +000054 printf("tps65903x: could not set LDO1 voltage.\n");
Jaehoon Chung505cf472016-12-15 20:49:50 +090055 return ret;
Vincent Stehléce851c82012-12-03 05:23:17 +000056 }
Lubomir Popove9090fa2013-06-06 04:16:40 +000057 /* TURN ON LDO1 */
58 val = RSC_MODE_SLEEP | RSC_MODE_ACTIVE;
Lokesh Vutladb4fce82017-08-21 12:50:50 +053059 ret = palmas_i2c_write_u8(TPS65903X_CHIP_P1, ldo_ctrl, val);
Jaehoon Chung505cf472016-12-15 20:49:50 +090060 if (ret) {
Lubomir Popove9090fa2013-06-06 04:16:40 +000061 printf("tps65903x: could not turn on LDO1.\n");
Jaehoon Chung505cf472016-12-15 20:49:50 +090062 return ret;
Vincent Stehléce851c82012-12-03 05:23:17 +000063 }
Vincent Stehléce851c82012-12-03 05:23:17 +000064 return 0;
Lubomir Popove9090fa2013-06-06 04:16:40 +000065#else
66 /*
67 * We assume that this is a OMAP543X + TWL603X board:
68 * Set TWL6035/37 LDO9 to 3.0 V
69 */
70 val = LDO_VOLT_3V0;
71 return twl603x_mmc1_set_ldo9(val);
72#endif
73}
74
75/*
76 * On some OMAP5 + TWL603X hardware the SD card socket and LDO9_IN are
77 * powered by an external 3.3 V regulator, while the output of LDO9
78 * supplies VDDS_SDCARD for the OMAP5 interface only. This implies that
79 * LDO9 could be set to 'bypass' mode when required (e.g. for 3.3 V cards).
80 */
81int twl603x_mmc1_set_ldo9(u8 vsel)
82{
83 u8 cval = 0, vval = 0; /* Off by default */
84 int err;
85
86 if (vsel) {
87 /* Turn on */
88 if (vsel > LDO_VOLT_3V3) {
89 /* Put LDO9 in bypass */
90 cval = LDO9_BYP_EN | RSC_MODE_SLEEP | RSC_MODE_ACTIVE;
91 vval = LDO_VOLT_3V3;
92 } else {
93 cval = RSC_MODE_SLEEP | RSC_MODE_ACTIVE;
94 vval = vsel & 0x3f;
95 }
96 }
97 err = palmas_i2c_write_u8(TWL603X_CHIP_P1, LDO9_VOLTAGE, vval);
98 if (err) {
99 printf("twl603x: could not set LDO9 %s: err = %d\n",
100 vsel > LDO_VOLT_3V3 ? "bypass" : "voltage", err);
101 return err;
102 }
103 err = palmas_i2c_write_u8(TWL603X_CHIP_P1, LDO9_CTRL, cval);
104 if (err)
105 printf("twl603x: could not turn %s LDO9: err = %d\n",
106 cval ? "on" : "off", err);
107 return err;
108}
109
110#ifdef CONFIG_PALMAS_AUDPWR
111/*
112 * Turn audio codec power and 32 kHz clock on/off. Use for
113 * testing OMAP543X + TWL603X + TWL604X boards only.
114 */
115int twl603x_audio_power(u8 on)
116{
117 u8 cval = 0, vval = 0, c32k = 0;
118 int err;
119
120 if (on) {
121 vval = SMPS_VOLT_2V1;
122 cval = SMPS_MODE_SLP_AUTO | SMPS_MODE_ACT_AUTO;
123 c32k = RSC_MODE_SLEEP | RSC_MODE_ACTIVE;
124 }
125 /* Set SMPS9 to 2.1 V (for TWL604x), or to 0 (off) */
126 err = palmas_i2c_write_u8(TWL603X_CHIP_P1, SMPS9_VOLTAGE, vval);
127 if (err) {
128 printf("twl603x: could not set SMPS9 voltage: err = %d\n",
129 err);
130 return err;
131 }
132 /* Turn on or off SMPS9 */
133 err = palmas_i2c_write_u8(TWL603X_CHIP_P1, SMPS9_CTRL, cval);
134 if (err) {
135 printf("twl603x: could not turn SMPS9 %s: err = %d\n",
136 cval ? "on" : "off", err);
137 return err;
138 }
139 /* Output 32 kHz clock on or off */
140 err = palmas_i2c_write_u8(TWL603X_CHIP_P1, CLK32KGAUDIO_CTRL, c32k);
141 if (err)
142 printf("twl603x: could not turn CLK32KGAUDIO %s: err = %d\n",
143 c32k ? "on" : "off", err);
144 return err;
145}
146#endif
147
Dan Murphy1bd435b2013-08-26 08:54:49 -0500148#ifdef CONFIG_PALMAS_USB_SS_PWR
149/**
150 * @brief palmas_enable_ss_ldo - Configure EVM board specific configurations
151 * for the USB Super speed SMPS10 regulator.
152 *
Heinrich Schuchardt185f8122022-01-19 18:05:50 +0100153 * Return: 0
Dan Murphy1bd435b2013-08-26 08:54:49 -0500154 */
155int palmas_enable_ss_ldo(void)
156{
157 /* Enable smps10 regulator */
158 return palmas_i2c_write_u8(TWL603X_CHIP_P1, SMPS10_CTRL,
159 SMPS10_MODE_ACTIVE_D);
160}
161#endif
162
Lubomir Popove9090fa2013-06-06 04:16:40 +0000163/*
164 * Enable/disable back-up battery (or super cap) charging on TWL6035/37.
165 * Please use defined BB_xxx values.
166 */
167int twl603x_enable_bb_charge(u8 bb_fields)
168{
169 u8 val = bb_fields & 0x0f;
170 int err;
171
172 val |= (VRTC_EN_SLP | VRTC_EN_OFF | VRTC_PWEN);
173 err = palmas_i2c_write_u8(TWL603X_CHIP_P1, BB_VRTC_CTRL, val);
174 if (err)
175 printf("twl603x: could not set BB_VRTC_CTRL to 0x%02x: err = %d\n",
176 val, err);
177 return err;
Balaji T Kdd23e592012-03-12 02:25:49 +0000178}
Jean-Jacques Hiblotfb1b7712018-12-07 14:50:46 +0100179
Igor Opaniuk2147a162021-02-09 13:52:45 +0200180#if CONFIG_IS_ENABLED(DM_I2C)
Jean-Jacques Hiblotfb1b7712018-12-07 14:50:46 +0100181int palmas_i2c_write_u8(u8 chip_no, u8 reg, u8 val)
182{
183 struct udevice *dev;
184 int ret;
185
186 ret = i2c_get_chip_for_busnum(0, chip_no, 1, &dev);
187 if (ret) {
188 pr_err("unable to get I2C bus. ret %d\n", ret);
189 return ret;
190 }
191 ret = dm_i2c_reg_write(dev, reg, val);
192 if (ret) {
193 pr_err("writing to palmas failed. ret %d\n", ret);
194 return ret;
195 }
196 return 0;
197}
198
199int palmas_i2c_read_u8(u8 chip_no, u8 reg, u8 *valp)
200{
201 struct udevice *dev;
202 int ret;
203
204 ret = i2c_get_chip_for_busnum(0, chip_no, 1, &dev);
205 if (ret) {
206 pr_err("unable to get I2C bus. ret %d\n", ret);
207 return ret;
208 }
209 ret = dm_i2c_reg_read(dev, reg);
210 if (ret < 0) {
211 pr_err("reading from palmas failed. ret %d\n", ret);
212 return ret;
213 }
214 *valp = (u8)ret;
215 return 0;
216}
217#endif