Lines Matching +full:scl +full:- +full:gpios

5  * This file is based on: drivers/i2c/soft-i2c.c,
6 * with added driver-model support and code cleanup.
29 * udelay - delay [us] between GPIO toggle operations,
33 /* sda, scl */
34 struct gpio_desc gpios[PIN_COUNT]; member
50 static void i2c_gpio_scl_set(struct gpio_desc *scl, int bit) in i2c_gpio_scl_set() argument
56 dm_gpio_set_dir_flags(scl, flags); in i2c_gpio_scl_set()
59 static void i2c_gpio_write_bit(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_write_bit() argument
62 i2c_gpio_scl_set(scl, 0); in i2c_gpio_write_bit()
66 i2c_gpio_scl_set(scl, 1); in i2c_gpio_write_bit()
70 static int i2c_gpio_read_bit(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_read_bit() argument
75 i2c_gpio_scl_set(scl, 1); in i2c_gpio_read_bit()
79 i2c_gpio_scl_set(scl, 0); in i2c_gpio_read_bit()
85 /* START: High -> Low on SDA while SCL is High */
86 static void i2c_gpio_send_start(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_send_start() argument
92 i2c_gpio_scl_set(scl, 1); in i2c_gpio_send_start()
98 /* STOP: Low -> High on SDA while SCL is High */
99 static void i2c_gpio_send_stop(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_send_stop() argument
102 i2c_gpio_scl_set(scl, 0); in i2c_gpio_send_stop()
106 i2c_gpio_scl_set(scl, 1); in i2c_gpio_send_stop()
113 static void i2c_gpio_send_ack(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_send_ack() argument
116 i2c_gpio_write_bit(scl, sda, delay, ack); in i2c_gpio_send_ack()
117 i2c_gpio_scl_set(scl, 0); in i2c_gpio_send_ack()
126 static void i2c_gpio_send_reset(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_send_reset() argument
132 i2c_gpio_write_bit(scl, sda, delay, 1); in i2c_gpio_send_reset()
134 i2c_gpio_send_stop(scl, sda, delay); in i2c_gpio_send_reset()
138 static void i2c_gpio_sda_high(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_sda_high() argument
141 i2c_gpio_scl_set(scl, 0); in i2c_gpio_sda_high()
148 static int i2c_gpio_write_byte(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_write_byte() argument
155 i2c_gpio_write_bit(scl, sda, delay, data & 0x80); in i2c_gpio_write_byte()
162 i2c_gpio_sda_high(scl, sda, delay); in i2c_gpio_write_byte()
163 nack = i2c_gpio_read_bit(scl, sda, delay); in i2c_gpio_write_byte()
172 static uchar i2c_gpio_read_byte(struct gpio_desc *scl, struct gpio_desc *sda, in i2c_gpio_read_byte() argument
178 i2c_gpio_sda_high(scl, sda, delay); in i2c_gpio_read_byte()
182 data |= i2c_gpio_read_bit(scl, sda, delay); in i2c_gpio_read_byte()
184 i2c_gpio_send_ack(scl, sda, delay, ack); in i2c_gpio_read_byte()
190 int i2c_send_slave_addr(struct gpio_desc *scl, struct gpio_desc *sda, int delay, in i2c_send_slave_addr() argument
193 i2c_gpio_send_start(scl, sda, delay); in i2c_send_slave_addr()
195 if (i2c_gpio_write_byte(scl, sda, delay, chip)) { in i2c_send_slave_addr()
196 i2c_gpio_send_stop(scl, sda, delay); in i2c_send_slave_addr()
197 return -EIO; in i2c_send_slave_addr()
207 struct gpio_desc *scl = &bus->gpios[PIN_SCL]; in i2c_gpio_write_data() local
208 struct gpio_desc *sda = &bus->gpios[PIN_SDA]; in i2c_gpio_write_data()
209 unsigned int delay = bus->udelay; in i2c_gpio_write_data()
214 if (i2c_send_slave_addr(scl, sda, delay, chip << 1)) { in i2c_gpio_write_data()
216 return -EIO; in i2c_gpio_write_data()
219 while (len-- > 0) { in i2c_gpio_write_data()
220 if (i2c_gpio_write_byte(scl, sda, delay, *buffer++)) in i2c_gpio_write_data()
225 i2c_gpio_send_stop(scl, sda, delay); in i2c_gpio_write_data()
229 if (i2c_send_slave_addr(scl, sda, delay, (chip << 1) | 0x1)) { in i2c_gpio_write_data()
231 return -EIO; in i2c_gpio_write_data()
240 struct gpio_desc *scl = &bus->gpios[PIN_SCL]; in i2c_gpio_read_data() local
241 struct gpio_desc *sda = &bus->gpios[PIN_SDA]; in i2c_gpio_read_data()
242 unsigned int delay = bus->udelay; in i2c_gpio_read_data()
246 while (len-- > 0) in i2c_gpio_read_data()
247 *buffer++ = i2c_gpio_read_byte(scl, sda, delay, len == 0); in i2c_gpio_read_data()
249 i2c_gpio_send_stop(scl, sda, delay); in i2c_gpio_read_data()
259 for (; nmsgs > 0; nmsgs--, msg++) { in i2c_gpio_xfer()
262 if (msg->flags & I2C_M_RD) { in i2c_gpio_xfer()
263 ret = i2c_gpio_read_data(bus, msg->addr, msg->buf, in i2c_gpio_xfer()
264 msg->len); in i2c_gpio_xfer()
266 ret = i2c_gpio_write_data(bus, msg->addr, msg->buf, in i2c_gpio_xfer()
267 msg->len, next_is_read); in i2c_gpio_xfer()
271 return -EREMOTEIO; in i2c_gpio_xfer()
280 struct gpio_desc *scl = &bus->gpios[PIN_SCL]; in i2c_gpio_probe() local
281 struct gpio_desc *sda = &bus->gpios[PIN_SDA]; in i2c_gpio_probe()
282 unsigned int delay = bus->udelay; in i2c_gpio_probe()
285 i2c_gpio_send_start(scl, sda, delay); in i2c_gpio_probe()
286 ret = i2c_gpio_write_byte(scl, sda, delay, (chip << 1) | 0); in i2c_gpio_probe()
287 i2c_gpio_send_stop(scl, sda, delay); in i2c_gpio_probe()
290 __func__, dev->seq, dev->name, chip, chip_flags, ret); in i2c_gpio_probe()
298 struct gpio_desc *scl = &bus->gpios[PIN_SCL]; in i2c_gpio_set_bus_speed() local
299 struct gpio_desc *sda = &bus->gpios[PIN_SDA]; in i2c_gpio_set_bus_speed()
301 bus->udelay = 1000000 / (speed_hz << 2); in i2c_gpio_set_bus_speed()
303 i2c_gpio_send_reset(scl, sda, bus->udelay); in i2c_gpio_set_bus_speed()
311 const void *blob = gd->fdt_blob; in i2c_gpio_ofdata_to_platdata()
315 ret = gpio_request_list_by_name(dev, "gpios", bus->gpios, in i2c_gpio_ofdata_to_platdata()
316 ARRAY_SIZE(bus->gpios), 0); in i2c_gpio_ofdata_to_platdata()
320 bus->udelay = fdtdec_get_int(blob, node, "i2c-gpio,delay-us", in i2c_gpio_ofdata_to_platdata()
325 pr_err("Can't get %s gpios! Error: %d", dev->name, ret); in i2c_gpio_ofdata_to_platdata()
336 { .compatible = "i2c-gpio" },
341 .name = "i2c-gpio",