xref: /openbmc/u-boot/drivers/power/power_fsl.c (revision e8f80a5a)
1*83d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
2316a51beSŁukasz Majewski /*
3316a51beSŁukasz Majewski  *  Copyright (C) 2011 Samsung Electronics
4316a51beSŁukasz Majewski  *  Lukasz Majewski <l.majewski@samsung.com>
5316a51beSŁukasz Majewski  */
6316a51beSŁukasz Majewski 
7316a51beSŁukasz Majewski #include <common.h>
8316a51beSŁukasz Majewski #include <spi.h>
9316a51beSŁukasz Majewski #include <power/pmic.h>
10316a51beSŁukasz Majewski #include <fsl_pmic.h>
11316a51beSŁukasz Majewski #include <errno.h>
12316a51beSŁukasz Majewski 
13913702caSSimon Glass #if defined(CONFIG_POWER_FSL_MC13892)
142c601c72SMinkyu Kang #define FSL_PMIC_I2C_LENGTH	3
15913702caSSimon Glass #elif defined(CONFIG_POWER_FSL_MC34704)
162c601c72SMinkyu Kang #define FSL_PMIC_I2C_LENGTH	1
172c601c72SMinkyu Kang #endif
182c601c72SMinkyu Kang 
19be3b51aaSŁukasz Majewski #if defined(CONFIG_POWER_SPI)
pmic_spi_prepare_tx(u32 reg,u32 * val,u32 write)20316a51beSŁukasz Majewski static u32 pmic_spi_prepare_tx(u32 reg, u32 *val, u32 write)
21316a51beSŁukasz Majewski {
22316a51beSŁukasz Majewski 	return (write << 31) | (reg << 25) | (*val & 0x00FFFFFF);
23316a51beSŁukasz Majewski }
24316a51beSŁukasz Majewski #endif
25316a51beSŁukasz Majewski 
pmic_init(unsigned char bus)26316a51beSŁukasz Majewski int pmic_init(unsigned char bus)
27316a51beSŁukasz Majewski {
28316a51beSŁukasz Majewski 	static const char name[] = "FSL_PMIC";
29316a51beSŁukasz Majewski 	struct pmic *p = pmic_alloc();
30316a51beSŁukasz Majewski 
31316a51beSŁukasz Majewski 	if (!p) {
32316a51beSŁukasz Majewski 		printf("%s: POWER allocation error!\n", __func__);
33316a51beSŁukasz Majewski 		return -ENOMEM;
34316a51beSŁukasz Majewski 	}
35316a51beSŁukasz Majewski 
36316a51beSŁukasz Majewski 	p->name = name;
37316a51beSŁukasz Majewski 	p->number_of_regs = PMIC_NUM_OF_REGS;
38839f4d4eSFabio Estevam 	p->bus = bus;
39316a51beSŁukasz Majewski 
40be3b51aaSŁukasz Majewski #if defined(CONFIG_POWER_SPI)
41316a51beSŁukasz Majewski 	p->interface = PMIC_SPI;
42316a51beSŁukasz Majewski 	p->hw.spi.cs = CONFIG_FSL_PMIC_CS;
43316a51beSŁukasz Majewski 	p->hw.spi.clk = CONFIG_FSL_PMIC_CLK;
44316a51beSŁukasz Majewski 	p->hw.spi.mode = CONFIG_FSL_PMIC_MODE;
45316a51beSŁukasz Majewski 	p->hw.spi.bitlen = CONFIG_FSL_PMIC_BITLEN;
46316a51beSŁukasz Majewski 	p->hw.spi.flags = SPI_XFER_BEGIN | SPI_XFER_END;
47316a51beSŁukasz Majewski 	p->hw.spi.prepare_tx = pmic_spi_prepare_tx;
48be3b51aaSŁukasz Majewski #elif defined(CONFIG_POWER_I2C)
49316a51beSŁukasz Majewski 	p->interface = PMIC_I2C;
50316a51beSŁukasz Majewski 	p->hw.i2c.addr = CONFIG_SYS_FSL_PMIC_I2C_ADDR;
512c601c72SMinkyu Kang 	p->hw.i2c.tx_num = FSL_PMIC_I2C_LENGTH;
52316a51beSŁukasz Majewski #else
53913702caSSimon Glass #error "You must select CONFIG_POWER_SPI or CONFIG_POWER_I2C"
54316a51beSŁukasz Majewski #endif
55316a51beSŁukasz Majewski 
56316a51beSŁukasz Majewski 	return 0;
57316a51beSŁukasz Majewski }
58