]> git.sur5r.net Git - u-boot/blob - drivers/i2c/i2c-uclass-compat.c
de78db6a887f3a4bc74a0486e2ee634c98775057
[u-boot] / drivers / i2c / i2c-uclass-compat.c
1 /*
2  * Copyright (c) 2014 Google, Inc
3  *
4  * SPDX-License-Identifier:     GPL-2.0+
5  */
6
7 #include <common.h>
8 #include <dm.h>
9 #include <errno.h>
10 #include <i2c.h>
11
12 static int cur_busnum __attribute__((section(".data")));
13
14 static int i2c_compat_get_device(uint chip_addr, int alen,
15                                  struct udevice **devp)
16 {
17         struct dm_i2c_chip *chip;
18         int ret;
19
20         ret = i2c_get_chip_for_busnum(cur_busnum, chip_addr, alen, devp);
21         if (ret)
22                 return ret;
23         chip = dev_get_parent_platdata(*devp);
24         if (chip->offset_len != alen) {
25                 printf("I2C chip %x: requested alen %d does not match chip offset_len %d\n",
26                        chip_addr, alen, chip->offset_len);
27                 return -EADDRNOTAVAIL;
28         }
29
30         return 0;
31 }
32
33 int i2c_probe(uint8_t chip_addr)
34 {
35         struct udevice *bus, *dev;
36         int ret;
37
38         ret = uclass_get_device_by_seq(UCLASS_I2C, cur_busnum, &bus);
39         if (ret) {
40                 debug("Cannot find I2C bus %d: err=%d\n", cur_busnum, ret);
41                 return ret;
42         }
43
44         if (!bus)
45                 return -ENOENT;
46
47         return dm_i2c_probe(bus, chip_addr, 0, &dev);
48 }
49
50 int i2c_read(uint8_t chip_addr, unsigned int addr, int alen, uint8_t *buffer,
51              int len)
52 {
53         struct udevice *dev;
54         int ret;
55
56         ret = i2c_compat_get_device(chip_addr, alen, &dev);
57         if (ret)
58                 return ret;
59
60         return dm_i2c_read(dev, addr, buffer, len);
61 }
62
63 int i2c_write(uint8_t chip_addr, unsigned int addr, int alen, uint8_t *buffer,
64               int len)
65 {
66         struct udevice *dev;
67         int ret;
68
69         ret = i2c_compat_get_device(chip_addr, alen, &dev);
70         if (ret)
71                 return ret;
72
73         return dm_i2c_write(dev, addr, buffer, len);
74 }
75
76 int i2c_get_bus_num_fdt(int node)
77 {
78         struct udevice *bus;
79         int ret;
80
81         ret = uclass_get_device_by_of_offset(UCLASS_I2C, node, &bus);
82         if (ret)
83                 return ret;
84
85         return bus->seq;
86 }
87
88 unsigned int i2c_get_bus_num(void)
89 {
90         return cur_busnum;
91 }
92
93 int i2c_set_bus_num(unsigned int bus)
94 {
95         cur_busnum = bus;
96
97         return 0;
98 }
99
100 void i2c_init(int speed, int slaveaddr)
101 {
102         /* Nothing to do here - the init happens through driver model */
103 }
104
105 void board_i2c_init(const void *blob)
106 {
107         /* Nothing to do here - the init happens through driver model */
108 }
109
110 uint8_t i2c_reg_read(uint8_t chip_addr, uint8_t offset)
111 {
112         struct udevice *dev;
113         int ret;
114
115         ret = i2c_compat_get_device(chip_addr, 1, &dev);
116         if (ret)
117                 return 0xff;
118         return dm_i2c_reg_read(dev, offset);
119 }
120
121 void i2c_reg_write(uint8_t chip_addr, uint8_t offset, uint8_t val)
122 {
123         struct udevice *dev;
124         int ret;
125
126         ret = i2c_compat_get_device(chip_addr, 1, &dev);
127         if (!ret)
128                 dm_i2c_reg_write(dev, offset, val);
129 }