xref: /rk3399_rockchip-uboot/drivers/power/pmic/max8997.c (revision 90aa625c9a9e1fb7a2f001fd8e50099bacaf92b8)
11a5a05daSJaehoon Chung /*
21a5a05daSJaehoon Chung  *  Copyright (C) 2016 Samsung Electronics
31a5a05daSJaehoon Chung  *  Jaehoon Chung <jh80.chung@samsung.com>
41a5a05daSJaehoon Chung  *
51a5a05daSJaehoon Chung  * SPDX-License-Identifier:	GPL-2.0+
61a5a05daSJaehoon Chung  */
71a5a05daSJaehoon Chung 
81a5a05daSJaehoon Chung #include <common.h>
91a5a05daSJaehoon Chung #include <dm.h>
101a5a05daSJaehoon Chung #include <i2c.h>
111a5a05daSJaehoon Chung #include <power/pmic.h>
121a5a05daSJaehoon Chung #include <power/max8997_pmic.h>
131a5a05daSJaehoon Chung #include <errno.h>
141a5a05daSJaehoon Chung 
151a5a05daSJaehoon Chung DECLARE_GLOBAL_DATA_PTR;
161a5a05daSJaehoon Chung 
max8997_reg_count(struct udevice * dev)171a5a05daSJaehoon Chung static int max8997_reg_count(struct udevice *dev)
181a5a05daSJaehoon Chung {
191a5a05daSJaehoon Chung 	return PMIC_NUM_OF_REGS;
201a5a05daSJaehoon Chung }
211a5a05daSJaehoon Chung 
max8997_write(struct udevice * dev,uint reg,const uint8_t * buff,int len)221a5a05daSJaehoon Chung static int max8997_write(struct udevice *dev, uint reg, const uint8_t *buff,
231a5a05daSJaehoon Chung 		int len)
241a5a05daSJaehoon Chung {
251a5a05daSJaehoon Chung 	int ret;
261a5a05daSJaehoon Chung 
271a5a05daSJaehoon Chung 	ret = dm_i2c_write(dev, reg, buff, len);
281a5a05daSJaehoon Chung 	if (ret)
29*90aa625cSMasahiro Yamada 		pr_err("write error to device: %p register: %#x!", dev, reg);
301a5a05daSJaehoon Chung 
311a5a05daSJaehoon Chung 	return ret;
321a5a05daSJaehoon Chung }
331a5a05daSJaehoon Chung 
max8997_read(struct udevice * dev,uint reg,uint8_t * buff,int len)341a5a05daSJaehoon Chung static int max8997_read(struct udevice *dev, uint reg, uint8_t *buff, int len)
351a5a05daSJaehoon Chung {
361a5a05daSJaehoon Chung 	int ret;
371a5a05daSJaehoon Chung 
381a5a05daSJaehoon Chung 	ret = dm_i2c_read(dev, reg, buff, len);
391a5a05daSJaehoon Chung 	if (ret)
40*90aa625cSMasahiro Yamada 		pr_err("read error from device: %p register: %#x!", dev, reg);
411a5a05daSJaehoon Chung 
421a5a05daSJaehoon Chung 	return ret;
431a5a05daSJaehoon Chung }
441a5a05daSJaehoon Chung 
451a5a05daSJaehoon Chung static struct dm_pmic_ops max8997_ops = {
461a5a05daSJaehoon Chung 	.reg_count = max8997_reg_count,
471a5a05daSJaehoon Chung 	.read	= max8997_read,
481a5a05daSJaehoon Chung 	.write	= max8997_write,
491a5a05daSJaehoon Chung };
501a5a05daSJaehoon Chung 
511a5a05daSJaehoon Chung static const struct udevice_id max8997_ids[] = {
521a5a05daSJaehoon Chung 	{ .compatible = "maxim,max8997" },
531a5a05daSJaehoon Chung 	{ },
541a5a05daSJaehoon Chung };
551a5a05daSJaehoon Chung 
561a5a05daSJaehoon Chung U_BOOT_DRIVER(pmic_max8997) = {
571a5a05daSJaehoon Chung 	.name		= "max8997_pmic",
581a5a05daSJaehoon Chung 	.id		= UCLASS_PMIC,
591a5a05daSJaehoon Chung 	.of_match	= max8997_ids,
601a5a05daSJaehoon Chung 	.ops		= &max8997_ops,
611a5a05daSJaehoon Chung };
62