blob: c2a7cbf7e400e6c5b7f95d7279ec610692e784d4 [file] [log] [blame]
Svyatoslav Ryhelaba052b2023-10-27 11:26:10 +03001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright(C) 2023 Svyatoslav Ryhel <clamor95@gmail.com>
4 */
5
6#include <dm.h>
7#include <dm/lists.h>
8#include <power/pmic.h>
9#include <power/max77663.h>
10
11static const struct pmic_child_info pmic_children_info[] = {
12 { .prefix = "ldo", .driver = MAX77663_LDO_DRIVER },
13 { .prefix = "sd", .driver = MAX77663_SD_DRIVER },
14 { },
15};
16
17static int max77663_write(struct udevice *dev, uint reg, const uint8_t *buff,
18 int len)
19{
20 int ret;
21
22 ret = dm_i2c_write(dev, reg, buff, len);
23 if (ret) {
24 log_debug("write error to device: %p register: %#x!\n", dev, reg);
25 return ret;
26 }
27
28 return 0;
29}
30
31static int max77663_read(struct udevice *dev, uint reg, uint8_t *buff, int len)
32{
33 int ret;
34
35 ret = dm_i2c_read(dev, reg, buff, len);
36 if (ret) {
37 log_debug("read error from device: %p register: %#x!\n", dev, reg);
38 return ret;
39 }
40
41 return 0;
42}
43
44static int max77663_bind(struct udevice *dev)
45{
46 ofnode regulators_node;
Svyatoslav Ryhel52914ea2023-10-24 10:49:05 +030047 int children, ret;
48
49 if (IS_ENABLED(CONFIG_SYSRESET_MAX77663)) {
Svyatoslav Ryhel0b5132d2024-12-09 12:51:33 +020050 ret = device_bind_driver_to_node(dev, MAX77663_RST_DRIVER,
51 "sysreset", dev_ofnode(dev),
52 NULL);
Svyatoslav Ryhel52914ea2023-10-24 10:49:05 +030053 if (ret) {
54 log_err("cannot bind SYSRESET (ret = %d)\n", ret);
55 return ret;
56 }
57 }
Svyatoslav Ryhelaba052b2023-10-27 11:26:10 +030058
Svyatoslav Ryhel16360b82023-07-15 22:25:03 +030059 if (IS_ENABLED(CONFIG_MAX77663_GPIO)) {
Svyatoslav Ryhel0b5132d2024-12-09 12:51:33 +020060 ret = device_bind_driver_to_node(dev, MAX77663_GPIO_DRIVER,
61 "gpio", dev_ofnode(dev), NULL);
Svyatoslav Ryhel16360b82023-07-15 22:25:03 +030062 if (ret) {
63 log_err("cannot bind GPIOs (ret = %d)\n", ret);
64 return ret;
65 }
66 }
67
Svyatoslav Ryhelaba052b2023-10-27 11:26:10 +030068 regulators_node = dev_read_subnode(dev, "regulators");
69 if (!ofnode_valid(regulators_node)) {
70 log_err("%s regulators subnode not found!\n", dev->name);
71 return -ENXIO;
72 }
73
74 debug("%s: '%s' - found regulators subnode\n", __func__, dev->name);
75
76 children = pmic_bind_children(dev, regulators_node, pmic_children_info);
77 if (!children)
78 log_err("%s - no child found\n", dev->name);
79
80 /* Always return success for this device */
81 return 0;
82}
83
84static struct dm_pmic_ops max77663_ops = {
85 .read = max77663_read,
86 .write = max77663_write,
87};
88
89static const struct udevice_id max77663_ids[] = {
90 { .compatible = "maxim,max77663" },
91 { }
92};
93
94U_BOOT_DRIVER(pmic_max77663) = {
95 .name = "max77663_pmic",
96 .id = UCLASS_PMIC,
97 .of_match = max77663_ids,
98 .bind = max77663_bind,
99 .ops = &max77663_ops,
100};