blob: 9dc930fb305aecb0302408447349f34b52f854cd [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Stefano Babic222be652011-10-05 12:38:27 +02002/*
3 * Copyright (C) 2011 Samsung Electronics
4 * Lukasz Majewski <l.majewski@samsung.com>
Stefano Babic222be652011-10-05 12:38:27 +02005 */
6
7#include <common.h>
8#include <spi.h>
Łukasz Majewski1c6dba12012-11-13 03:21:55 +00009#include <power/pmic.h>
Stefano Babic222be652011-10-05 12:38:27 +020010#include <fsl_pmic.h>
Łukasz Majewski1c6dba12012-11-13 03:21:55 +000011#include <errno.h>
Stefano Babic222be652011-10-05 12:38:27 +020012
Simon Glass02229812014-05-20 06:01:34 -060013#if defined(CONFIG_POWER_FSL_MC13892)
Fabio Estevam57c922b2012-10-23 06:34:50 +000014#define FSL_PMIC_I2C_LENGTH 3
Simon Glass02229812014-05-20 06:01:34 -060015#elif defined(CONFIG_POWER_FSL_MC34704)
Fabio Estevam2e6453d2012-10-23 06:36:18 +000016#define FSL_PMIC_I2C_LENGTH 1
Fabio Estevam57c922b2012-10-23 06:34:50 +000017#endif
18
Łukasz Majewski1b6d9ed2012-11-13 03:22:14 +000019#if defined(CONFIG_POWER_SPI)
Stefano Babic222be652011-10-05 12:38:27 +020020static u32 pmic_spi_prepare_tx(u32 reg, u32 *val, u32 write)
21{
Helmut Raigerb6e18412011-10-19 20:34:43 +000022 return (write << 31) | (reg << 25) | (*val & 0x00FFFFFF);
Stefano Babic222be652011-10-05 12:38:27 +020023}
Stefano Babic54324c12011-10-06 21:06:39 +020024#endif
Stefano Babic222be652011-10-05 12:38:27 +020025
Łukasz Majewski1c6dba12012-11-13 03:21:55 +000026int pmic_init(unsigned char bus)
Stefano Babic222be652011-10-05 12:38:27 +020027{
Stefano Babic222be652011-10-05 12:38:27 +020028 static const char name[] = "FSL_PMIC";
Łukasz Majewski1c6dba12012-11-13 03:21:55 +000029 struct pmic *p = pmic_alloc();
30
31 if (!p) {
32 printf("%s: POWER allocation error!\n", __func__);
33 return -ENOMEM;
34 }
Stefano Babic222be652011-10-05 12:38:27 +020035
Stefano Babic222be652011-10-05 12:38:27 +020036 p->name = name;
Stefano Babic222be652011-10-05 12:38:27 +020037 p->number_of_regs = PMIC_NUM_OF_REGS;
Fabio Estevam883bdb12013-11-20 20:26:06 -020038 p->bus = bus;
Stefano Babic222be652011-10-05 12:38:27 +020039
Łukasz Majewski1b6d9ed2012-11-13 03:22:14 +000040#if defined(CONFIG_POWER_SPI)
Stefano Babic54324c12011-10-06 21:06:39 +020041 p->interface = PMIC_SPI;
Tom Rini610d41f2022-12-04 10:04:01 -050042 p->hw.spi.cs = CFG_FSL_PMIC_CS;
Tom Rinia35b7ba2022-12-04 10:04:00 -050043 p->hw.spi.clk = CFG_FSL_PMIC_CLK;
Tom Rinifc9d6a12022-12-04 10:04:02 -050044 p->hw.spi.mode = CFG_FSL_PMIC_MODE;
Tom Rini0da17ea2022-12-04 10:03:58 -050045 p->hw.spi.bitlen = CFG_FSL_PMIC_BITLEN;
Stefano Babic222be652011-10-05 12:38:27 +020046 p->hw.spi.flags = SPI_XFER_BEGIN | SPI_XFER_END;
47 p->hw.spi.prepare_tx = pmic_spi_prepare_tx;
Łukasz Majewski1b6d9ed2012-11-13 03:22:14 +000048#elif defined(CONFIG_POWER_I2C)
Stefano Babic54324c12011-10-06 21:06:39 +020049 p->interface = PMIC_I2C;
Tom Rini376b88a2022-10-28 20:27:13 -040050 p->hw.i2c.addr = CFG_SYS_FSL_PMIC_I2C_ADDR;
Fabio Estevam57c922b2012-10-23 06:34:50 +000051 p->hw.i2c.tx_num = FSL_PMIC_I2C_LENGTH;
Stefano Babic54324c12011-10-06 21:06:39 +020052#endif
Stefano Babic222be652011-10-05 12:38:27 +020053
54 return 0;
55}