Lines Matching +full:pins +full:- +full:cmd +full:- +full:dat
1 // SPDX-License-Identifier: GPL-2.0-or-later
5 * Copyright (C) 1995-99 Simon G. Vogl
10 * Copyright (C) 2013-2017 Wolfram Sang <wsa@kernel.org>
13 #define pr_fmt(fmt) "i2c-core: " fmt
15 #include <dt-bindings/i2c/i2c.h>
17 #include <linux/clk/clk-conf.h>
24 #include <linux/i2c-smbus.h>
44 #include "i2c-core.h"
107 while (id->name[0]) { in i2c_match_id()
108 if (strcmp(client->name, id->name) == 0) in i2c_match_id()
123 if (i2c_of_match_device(drv->of_match_table, client)) in i2c_device_match()
133 if (i2c_match_id(driver->id_table, client)) in i2c_device_match()
145 if (rc != -ENODEV) in i2c_device_uevent()
149 if (rc != -ENODEV) in i2c_device_uevent()
152 return add_uevent_var(env, "MODALIAS=%s%s", I2C_MODULE_PREFIX, client->name); in i2c_device_uevent()
158 return gpiod_get_value_cansleep(adap->bus_recovery_info->scl_gpiod); in get_scl_gpio_value()
163 gpiod_set_value_cansleep(adap->bus_recovery_info->scl_gpiod, val); in set_scl_gpio_value()
168 return gpiod_get_value_cansleep(adap->bus_recovery_info->sda_gpiod); in get_sda_gpio_value()
173 gpiod_set_value_cansleep(adap->bus_recovery_info->sda_gpiod, val); in set_sda_gpio_value()
178 struct i2c_bus_recovery_info *bri = adap->bus_recovery_info; in i2c_generic_bus_free()
179 int ret = -EOPNOTSUPP; in i2c_generic_bus_free()
181 if (bri->get_bus_free) in i2c_generic_bus_free()
182 ret = bri->get_bus_free(adap); in i2c_generic_bus_free()
183 else if (bri->get_sda) in i2c_generic_bus_free()
184 ret = bri->get_sda(adap); in i2c_generic_bus_free()
189 return ret ? 0 : -EBUSY; in i2c_generic_bus_free()
202 struct i2c_bus_recovery_info *bri = adap->bus_recovery_info; in i2c_generic_scl_recovery()
205 if (bri->prepare_recovery) in i2c_generic_scl_recovery()
206 bri->prepare_recovery(adap); in i2c_generic_scl_recovery()
207 if (bri->pinctrl) in i2c_generic_scl_recovery()
208 pinctrl_select_state(bri->pinctrl, bri->pins_gpio); in i2c_generic_scl_recovery()
217 bri->set_scl(adap, scl); in i2c_generic_scl_recovery()
219 if (bri->set_sda) in i2c_generic_scl_recovery()
220 bri->set_sda(adap, scl); in i2c_generic_scl_recovery()
224 * By this time SCL is high, as we need to give 9 falling-rising edges in i2c_generic_scl_recovery()
229 if (!bri->get_scl(adap)) { in i2c_generic_scl_recovery()
230 dev_err(&adap->dev, in i2c_generic_scl_recovery()
232 ret = -EBUSY; in i2c_generic_scl_recovery()
238 bri->set_scl(adap, scl); in i2c_generic_scl_recovery()
244 /* Honour minimum tf and thd:dat */ in i2c_generic_scl_recovery()
247 if (bri->set_sda) in i2c_generic_scl_recovery()
248 bri->set_sda(adap, scl); in i2c_generic_scl_recovery()
259 if (ret == -EOPNOTSUPP) in i2c_generic_scl_recovery()
262 if (bri->unprepare_recovery) in i2c_generic_scl_recovery()
263 bri->unprepare_recovery(adap); in i2c_generic_scl_recovery()
264 if (bri->pinctrl) in i2c_generic_scl_recovery()
265 pinctrl_select_state(bri->pinctrl, bri->pins_default); in i2c_generic_scl_recovery()
273 if (!adap->bus_recovery_info) in i2c_recover_bus()
274 return -EBUSY; in i2c_recover_bus()
276 dev_dbg(&adap->dev, "Trying i2c bus recovery\n"); in i2c_recover_bus()
277 return adap->bus_recovery_info->recover_bus(adap); in i2c_recover_bus()
283 struct i2c_bus_recovery_info *bri = adap->bus_recovery_info; in i2c_gpio_init_pinctrl_recovery()
284 struct device *dev = &adap->dev; in i2c_gpio_init_pinctrl_recovery()
285 struct pinctrl *p = bri->pinctrl; in i2c_gpio_init_pinctrl_recovery()
292 bri->pins_default = NULL; in i2c_gpio_init_pinctrl_recovery()
293 bri->pins_gpio = NULL; in i2c_gpio_init_pinctrl_recovery()
297 if (!bri->pins_default) { in i2c_gpio_init_pinctrl_recovery()
298 bri->pins_default = pinctrl_lookup_state(p, in i2c_gpio_init_pinctrl_recovery()
300 if (IS_ERR(bri->pins_default)) { in i2c_gpio_init_pinctrl_recovery()
302 bri->pins_default = NULL; in i2c_gpio_init_pinctrl_recovery()
305 if (!bri->pins_gpio) { in i2c_gpio_init_pinctrl_recovery()
306 bri->pins_gpio = pinctrl_lookup_state(p, "gpio"); in i2c_gpio_init_pinctrl_recovery()
307 if (IS_ERR(bri->pins_gpio)) in i2c_gpio_init_pinctrl_recovery()
308 bri->pins_gpio = pinctrl_lookup_state(p, "recovery"); in i2c_gpio_init_pinctrl_recovery()
310 if (IS_ERR(bri->pins_gpio)) { in i2c_gpio_init_pinctrl_recovery()
312 bri->pins_gpio = NULL; in i2c_gpio_init_pinctrl_recovery()
317 if (bri->pins_default && bri->pins_gpio) { in i2c_gpio_init_pinctrl_recovery()
320 bri->pinctrl = NULL; in i2c_gpio_init_pinctrl_recovery()
321 bri->pins_default = NULL; in i2c_gpio_init_pinctrl_recovery()
322 bri->pins_gpio = NULL; in i2c_gpio_init_pinctrl_recovery()
328 struct i2c_bus_recovery_info *bri = adap->bus_recovery_info; in i2c_gpio_init_generic_recovery()
329 struct device *dev = &adap->dev; in i2c_gpio_init_generic_recovery()
337 if (bri->recover_bus && bri->recover_bus != i2c_generic_scl_recovery) in i2c_gpio_init_generic_recovery()
341 * pins might be taken as GPIO, so we should inform pinctrl about in i2c_gpio_init_generic_recovery()
344 if (bri->pinctrl) in i2c_gpio_init_generic_recovery()
345 pinctrl_select_state(bri->pinctrl, bri->pins_gpio); in i2c_gpio_init_generic_recovery()
351 if (!bri->scl_gpiod) { in i2c_gpio_init_generic_recovery()
353 if (PTR_ERR(gpiod) == -EPROBE_DEFER) { in i2c_gpio_init_generic_recovery()
354 ret = -EPROBE_DEFER; in i2c_gpio_init_generic_recovery()
358 bri->scl_gpiod = gpiod; in i2c_gpio_init_generic_recovery()
359 bri->recover_bus = i2c_generic_scl_recovery; in i2c_gpio_init_generic_recovery()
365 if (!bri->sda_gpiod) { in i2c_gpio_init_generic_recovery()
370 gpiod_direction_output(bri->scl_gpiod, 0); in i2c_gpio_init_generic_recovery()
376 gpiod_direction_output(bri->scl_gpiod, 1); in i2c_gpio_init_generic_recovery()
378 if (PTR_ERR(gpiod) == -EPROBE_DEFER) { in i2c_gpio_init_generic_recovery()
379 ret = -EPROBE_DEFER; in i2c_gpio_init_generic_recovery()
383 bri->sda_gpiod = gpiod; in i2c_gpio_init_generic_recovery()
387 /* change the state of the pins back to their default state */ in i2c_gpio_init_generic_recovery()
388 if (bri->pinctrl) in i2c_gpio_init_generic_recovery()
389 pinctrl_select_state(bri->pinctrl, bri->pins_default); in i2c_gpio_init_generic_recovery()
402 struct i2c_bus_recovery_info *bri = adap->bus_recovery_info; in i2c_init_recovery()
409 if (i2c_gpio_init_recovery(adap) == -EPROBE_DEFER) in i2c_init_recovery()
410 return -EPROBE_DEFER; in i2c_init_recovery()
412 if (!bri->recover_bus) { in i2c_init_recovery()
418 if (bri->scl_gpiod && bri->recover_bus == i2c_generic_scl_recovery) { in i2c_init_recovery()
419 bri->get_scl = get_scl_gpio_value; in i2c_init_recovery()
420 bri->set_scl = set_scl_gpio_value; in i2c_init_recovery()
421 if (bri->sda_gpiod) { in i2c_init_recovery()
422 bri->get_sda = get_sda_gpio_value; in i2c_init_recovery()
424 if (gpiod_get_direction(bri->sda_gpiod) == 0) in i2c_init_recovery()
425 bri->set_sda = set_sda_gpio_value; in i2c_init_recovery()
427 } else if (bri->recover_bus == i2c_generic_scl_recovery) { in i2c_init_recovery()
429 if (!bri->set_scl || !bri->get_scl) { in i2c_init_recovery()
433 if (!bri->set_sda && !bri->get_sda) { in i2c_init_recovery()
442 dev_err(&adap->dev, "Not using recovery: %s\n", err_str); in i2c_init_recovery()
444 dev_dbg(&adap->dev, "Not using recovery: %s\n", err_str); in i2c_init_recovery()
445 adap->bus_recovery_info = NULL; in i2c_init_recovery()
447 return -EINVAL; in i2c_init_recovery()
452 struct i2c_adapter *adap = client->adapter; in i2c_smbus_host_notify_to_irq()
455 if (!adap->host_notify_domain) in i2c_smbus_host_notify_to_irq()
456 return -ENXIO; in i2c_smbus_host_notify_to_irq()
458 if (client->flags & I2C_CLIENT_TEN) in i2c_smbus_host_notify_to_irq()
459 return -EINVAL; in i2c_smbus_host_notify_to_irq()
461 irq = irq_create_mapping(adap->host_notify_domain, client->addr); in i2c_smbus_host_notify_to_irq()
463 return irq > 0 ? irq : -ENXIO; in i2c_smbus_host_notify_to_irq()
476 client->irq = client->init_irq; in i2c_device_probe()
478 if (!client->irq) { in i2c_device_probe()
479 int irq = -ENOENT; in i2c_device_probe()
481 if (client->flags & I2C_CLIENT_HOST_NOTIFY) { in i2c_device_probe()
484 pm_runtime_get_sync(&client->adapter->dev); in i2c_device_probe()
486 } else if (dev->of_node) { in i2c_device_probe()
487 irq = of_irq_get_byname(dev->of_node, "irq"); in i2c_device_probe()
488 if (irq == -EINVAL || irq == -ENODATA) in i2c_device_probe()
489 irq = of_irq_get(dev->of_node, 0); in i2c_device_probe()
495 client->flags |= I2C_CLIENT_WAKE; in i2c_device_probe()
497 if (irq == -EPROBE_DEFER) { in i2c_device_probe()
505 client->irq = irq; in i2c_device_probe()
508 driver = to_i2c_driver(dev->driver); in i2c_device_probe()
514 if (!driver->id_table && in i2c_device_probe()
515 !acpi_driver_match_device(dev, dev->driver) && in i2c_device_probe()
516 !i2c_of_match_device(dev->driver->of_match_table, client)) { in i2c_device_probe()
517 status = -ENODEV; in i2c_device_probe()
521 if (client->flags & I2C_CLIENT_WAKE) { in i2c_device_probe()
524 wakeirq = of_irq_get_byname(dev->of_node, "wakeup"); in i2c_device_probe()
525 if (wakeirq == -EPROBE_DEFER) { in i2c_device_probe()
530 device_init_wakeup(&client->dev, true); in i2c_device_probe()
532 if (wakeirq > 0 && wakeirq != client->irq) in i2c_device_probe()
534 else if (client->irq > 0) in i2c_device_probe()
535 status = dev_pm_set_wake_irq(dev, client->irq); in i2c_device_probe()
540 dev_warn(&client->dev, "failed to set up wakeup irq\n"); in i2c_device_probe()
545 status = of_clk_set_defaults(dev->of_node, false); in i2c_device_probe()
550 status = dev_pm_domain_attach(&client->dev, do_power_on); in i2c_device_probe()
554 client->devres_group_id = devres_open_group(&client->dev, NULL, in i2c_device_probe()
556 if (!client->devres_group_id) { in i2c_device_probe()
557 status = -ENOMEM; in i2c_device_probe()
565 if (driver->probe_new) in i2c_device_probe()
566 status = driver->probe_new(client); in i2c_device_probe()
567 else if (driver->probe) in i2c_device_probe()
568 status = driver->probe(client, in i2c_device_probe()
569 i2c_match_id(driver->id_table, client)); in i2c_device_probe()
571 status = -EINVAL; in i2c_device_probe()
587 devres_release_group(&client->dev, client->devres_group_id); in i2c_device_probe()
589 dev_pm_domain_detach(&client->dev, do_power_on); in i2c_device_probe()
591 dev_pm_clear_wake_irq(&client->dev); in i2c_device_probe()
592 device_init_wakeup(&client->dev, false); in i2c_device_probe()
594 if (client->flags & I2C_CLIENT_HOST_NOTIFY) in i2c_device_probe()
595 pm_runtime_put_sync(&client->adapter->dev); in i2c_device_probe()
605 driver = to_i2c_driver(dev->driver); in i2c_device_remove()
606 if (driver->remove) { in i2c_device_remove()
609 driver->remove(client); in i2c_device_remove()
612 devres_release_group(&client->dev, client->devres_group_id); in i2c_device_remove()
614 dev_pm_domain_detach(&client->dev, true); in i2c_device_remove()
616 dev_pm_clear_wake_irq(&client->dev); in i2c_device_remove()
617 device_init_wakeup(&client->dev, false); in i2c_device_remove()
619 client->irq = 0; in i2c_device_remove()
620 if (client->flags & I2C_CLIENT_HOST_NOTIFY) in i2c_device_remove()
621 pm_runtime_put(&client->adapter->dev); in i2c_device_remove()
629 if (!client || !dev->driver) in i2c_device_shutdown()
631 driver = to_i2c_driver(dev->driver); in i2c_device_shutdown()
632 if (driver->shutdown) in i2c_device_shutdown()
633 driver->shutdown(client); in i2c_device_shutdown()
634 else if (client->irq > 0) in i2c_device_shutdown()
635 disable_irq(client->irq); in i2c_device_shutdown()
646 return sprintf(buf, "%s\n", dev->type == &i2c_client_type ? in name_show()
647 to_i2c_client(dev)->name : to_i2c_adapter(dev)->name); in name_show()
658 if (len != -ENODEV) in modalias_show()
661 len = acpi_device_modalias(dev, buf, PAGE_SIZE - 1); in modalias_show()
662 if (len != -ENODEV) in modalias_show()
665 return sprintf(buf, "%s%s\n", I2C_MODULE_PREFIX, client->name); in modalias_show()
695 * i2c_verify_client - return parameter as i2c_client, or NULL
701 * by wrongly treating some non-I2C device as an i2c_client.
705 return (dev->type == &i2c_client_type) in i2c_verify_client()
715 unsigned short addr = client->addr; in i2c_encode_flags_to_addr()
718 if (client->flags & I2C_CLIENT_TEN) in i2c_encode_flags_to_addr()
721 if (client->flags & I2C_CLIENT_SLAVE) in i2c_encode_flags_to_addr()
732 /* 10-bit address, all values are valid */ in i2c_check_addr_validity()
734 return -EINVAL; in i2c_check_addr_validity()
736 /* 7-bit address, reject the general call address */ in i2c_check_addr_validity()
738 return -EINVAL; in i2c_check_addr_validity()
744 * device uses a reserved address, then it shouldn't be probed. 7-bit
745 * addressing is assumed, 10-bit address devices are rare and should be
755 * 0x04-0x07 Hs-mode master code in i2c_check_7bit_addr_validity_strict()
756 * 0x78-0x7b 10-bit slave addressing in i2c_check_7bit_addr_validity_strict()
757 * 0x7c-0x7f Reserved for future purposes in i2c_check_7bit_addr_validity_strict()
760 return -EINVAL; in i2c_check_7bit_addr_validity_strict()
770 return -EBUSY; in __i2c_check_addr_busy()
780 result = device_for_each_child(&adapter->dev, &addr, in i2c_check_mux_parents()
794 if (dev->type == &i2c_adapter_type) in i2c_check_mux_children()
812 result = device_for_each_child(&adapter->dev, &addr, in i2c_check_addr_busy()
819 * i2c_adapter_lock_bus - Get exclusive access to an I2C bus segment
827 rt_mutex_lock_nested(&adapter->bus_lock, i2c_adapter_depth(adapter)); in i2c_adapter_lock_bus()
831 * i2c_adapter_trylock_bus - Try to get exclusive access to an I2C bus segment
839 return rt_mutex_trylock(&adapter->bus_lock); in i2c_adapter_trylock_bus()
843 * i2c_adapter_unlock_bus - Release exclusive access to an I2C bus segment
851 rt_mutex_unlock(&adapter->bus_lock); in i2c_adapter_unlock_bus()
858 struct acpi_device *adev = ACPI_COMPANION(&client->dev); in i2c_dev_set_name()
860 if (info && info->dev_name) { in i2c_dev_set_name()
861 dev_set_name(&client->dev, "i2c-%s", info->dev_name); in i2c_dev_set_name()
866 dev_set_name(&client->dev, "i2c-%s", acpi_dev_name(adev)); in i2c_dev_set_name()
870 dev_set_name(&client->dev, "%d-%04x", i2c_adapter_id(adap), in i2c_dev_set_name()
886 if (r->flags & IORESOURCE_BITS) { in i2c_dev_irq_from_resources()
887 irqd = irq_get_irq_data(r->start); in i2c_dev_irq_from_resources()
891 irqd_set_trigger_type(irqd, r->flags & IORESOURCE_BITS); in i2c_dev_irq_from_resources()
894 return r->start; in i2c_dev_irq_from_resources()
901 * i2c_new_client_device - instantiate an i2c device
924 return ERR_PTR(-ENOMEM); in i2c_new_client_device()
926 client->adapter = adap; in i2c_new_client_device()
928 client->dev.platform_data = info->platform_data; in i2c_new_client_device()
929 client->flags = info->flags; in i2c_new_client_device()
930 client->addr = info->addr; in i2c_new_client_device()
932 client->init_irq = info->irq; in i2c_new_client_device()
933 if (!client->init_irq) in i2c_new_client_device()
934 client->init_irq = i2c_dev_irq_from_resources(info->resources, in i2c_new_client_device()
935 info->num_resources); in i2c_new_client_device()
937 strscpy(client->name, info->type, sizeof(client->name)); in i2c_new_client_device()
939 status = i2c_check_addr_validity(client->addr, client->flags); in i2c_new_client_device()
941 dev_err(&adap->dev, "Invalid %d-bit I2C address 0x%02hx\n", in i2c_new_client_device()
942 client->flags & I2C_CLIENT_TEN ? 10 : 7, client->addr); in i2c_new_client_device()
951 client->dev.parent = &client->adapter->dev; in i2c_new_client_device()
952 client->dev.bus = &i2c_bus_type; in i2c_new_client_device()
953 client->dev.type = &i2c_client_type; in i2c_new_client_device()
954 client->dev.of_node = of_node_get(info->of_node); in i2c_new_client_device()
955 client->dev.fwnode = info->fwnode; in i2c_new_client_device()
957 device_enable_async_suspend(&client->dev); in i2c_new_client_device()
960 if (info->swnode) { in i2c_new_client_device()
961 status = device_add_software_node(&client->dev, info->swnode); in i2c_new_client_device()
963 dev_err(&adap->dev, in i2c_new_client_device()
965 client->name, status); in i2c_new_client_device()
970 status = device_register(&client->dev); in i2c_new_client_device()
974 dev_dbg(&adap->dev, "client [%s] registered with bus id %s\n", in i2c_new_client_device()
975 client->name, dev_name(&client->dev)); in i2c_new_client_device()
980 device_remove_software_node(&client->dev); in i2c_new_client_device()
982 of_node_put(info->of_node); in i2c_new_client_device()
984 dev_err(&adap->dev, in i2c_new_client_device()
986 client->name, client->addr, status); in i2c_new_client_device()
994 * i2c_unregister_device - reverse effect of i2c_new_*_device()
1003 if (client->dev.of_node) { in i2c_unregister_device()
1004 of_node_clear_flag(client->dev.of_node, OF_POPULATED); in i2c_unregister_device()
1005 of_node_put(client->dev.of_node); in i2c_unregister_device()
1008 if (ACPI_COMPANION(&client->dev)) in i2c_unregister_device()
1009 acpi_device_clear_enumerated(ACPI_COMPANION(&client->dev)); in i2c_unregister_device()
1010 device_remove_software_node(&client->dev); in i2c_unregister_device()
1011 device_unregister(&client->dev); in i2c_unregister_device()
1034 * i2c_new_dummy_device - return a new i2c device bound to a dummy driver
1067 * devm_i2c_new_dummy_device - return a new i2c device bound to a dummy driver
1073 * This is the device-managed version of @i2c_new_dummy_device. It returns the
1096 * i2c_new_ancillary_device - Helper to get the instantiated secondary address
1111 * On DT-based platforms the address is retrieved from the "reg" property entry
1112 * cell whose "reg-names" value matches the slave name.
1121 struct device_node *np = client->dev.of_node; in i2c_new_ancillary_device()
1126 i = of_property_match_string(np, "reg-names", name); in i2c_new_ancillary_device()
1131 dev_dbg(&client->adapter->dev, "Address for %s : 0x%x\n", name, addr); in i2c_new_ancillary_device()
1132 return i2c_new_dummy_device(client->adapter, addr); in i2c_new_ancillary_device()
1136 /* ------------------------------------------------------------------------- */
1138 /* I2C bus adapters -- one roots each I2C or SMBUS segment */
1143 complete(&adap->dev_released); in i2c_adapter_dev_release()
1185 return -EINVAL; in new_device_store()
1187 if (blank - buf > I2C_NAME_SIZE - 1) { in new_device_store()
1189 return -EINVAL; in new_device_store()
1191 memcpy(info.type, buf, blank - buf); in new_device_store()
1197 return -EINVAL; in new_device_store()
1201 return -EINVAL; in new_device_store()
1219 mutex_lock(&adap->userspace_clients_lock); in new_device_store()
1220 list_add_tail(&client->detected, &adap->userspace_clients); in new_device_store()
1221 mutex_unlock(&adap->userspace_clients_lock); in new_device_store()
1252 return -EINVAL; in delete_device_store()
1256 return -EINVAL; in delete_device_store()
1260 res = -ENOENT; in delete_device_store()
1261 mutex_lock_nested(&adap->userspace_clients_lock, in delete_device_store()
1263 list_for_each_entry_safe(client, next, &adap->userspace_clients, in delete_device_store()
1267 "delete_device", client->name, client->addr); in delete_device_store()
1269 list_del(&client->detected); in delete_device_store()
1275 mutex_unlock(&adap->userspace_clients_lock); in delete_device_store()
1300 * i2c_verify_adapter - return parameter as i2c_adapter or NULL
1306 * by wrongly treating some non-I2C device as an i2c_adapter.
1310 return (dev->type == &i2c_adapter_type) in i2c_verify_adapter()
1326 if (devinfo->busnum == adapter->nr && in i2c_scan_static_board_info()
1327 IS_ERR(i2c_new_client_device(adapter, &devinfo->board_info))) in i2c_scan_static_board_info()
1328 dev_err(&adapter->dev, in i2c_scan_static_board_info()
1330 devinfo->board_info.addr); in i2c_scan_static_board_info()
1357 struct irq_domain *domain = adap->host_notify_domain; in i2c_host_notify_irq_teardown()
1367 adap->host_notify_domain = NULL; in i2c_host_notify_irq_teardown()
1390 domain = irq_domain_create_linear(adap->dev.parent->fwnode, in i2c_setup_host_notify_irq_domain()
1394 return -ENOMEM; in i2c_setup_host_notify_irq_domain()
1396 adap->host_notify_domain = domain; in i2c_setup_host_notify_irq_domain()
1402 * i2c_handle_smbus_host_notify - Forward a Host Notify event to the correct
1416 return -EINVAL; in i2c_handle_smbus_host_notify()
1418 irq = irq_find_mapping(adap->host_notify_domain, addr); in i2c_handle_smbus_host_notify()
1420 return -ENXIO; in i2c_handle_smbus_host_notify()
1430 int res = -EINVAL; in i2c_register_adapter()
1434 res = -EAGAIN; in i2c_register_adapter()
1439 if (WARN(!adap->name[0], "i2c adapter has no name")) in i2c_register_adapter()
1442 if (!adap->algo) { in i2c_register_adapter()
1443 pr_err("adapter '%s': no algo supplied!\n", adap->name); in i2c_register_adapter()
1447 if (!adap->lock_ops) in i2c_register_adapter()
1448 adap->lock_ops = &i2c_adapter_lock_ops; in i2c_register_adapter()
1450 adap->locked_flags = 0; in i2c_register_adapter()
1451 rt_mutex_init(&adap->bus_lock); in i2c_register_adapter()
1452 rt_mutex_init(&adap->mux_lock); in i2c_register_adapter()
1453 mutex_init(&adap->userspace_clients_lock); in i2c_register_adapter()
1454 INIT_LIST_HEAD(&adap->userspace_clients); in i2c_register_adapter()
1457 if (adap->timeout == 0) in i2c_register_adapter()
1458 adap->timeout = HZ; in i2c_register_adapter()
1464 adap->name, res); in i2c_register_adapter()
1468 dev_set_name(&adap->dev, "i2c-%d", adap->nr); in i2c_register_adapter()
1469 adap->dev.bus = &i2c_bus_type; in i2c_register_adapter()
1470 adap->dev.type = &i2c_adapter_type; in i2c_register_adapter()
1471 res = device_register(&adap->dev); in i2c_register_adapter()
1473 pr_err("adapter '%s': can't register device (%d)\n", adap->name, res); in i2c_register_adapter()
1481 device_enable_async_suspend(&adap->dev); in i2c_register_adapter()
1482 pm_runtime_no_callbacks(&adap->dev); in i2c_register_adapter()
1483 pm_suspend_ignore_children(&adap->dev, true); in i2c_register_adapter()
1484 pm_runtime_enable(&adap->dev); in i2c_register_adapter()
1487 if (res == -EPROBE_DEFER) in i2c_register_adapter()
1490 dev_dbg(&adap->dev, "adapter [%s] registered\n", adap->name); in i2c_register_adapter()
1493 res = class_compat_create_link(i2c_adapter_compat_class, &adap->dev, in i2c_register_adapter()
1494 adap->dev.parent); in i2c_register_adapter()
1496 dev_warn(&adap->dev, in i2c_register_adapter()
1500 /* create pre-declared device nodes */ in i2c_register_adapter()
1505 if (adap->nr < __i2c_first_dynamic_bus_num) in i2c_register_adapter()
1516 init_completion(&adap->dev_released); in i2c_register_adapter()
1517 device_unregister(&adap->dev); in i2c_register_adapter()
1518 wait_for_completion(&adap->dev_released); in i2c_register_adapter()
1521 idr_remove(&i2c_adapter_idr, adap->nr); in i2c_register_adapter()
1527 * __i2c_add_numbered_adapter - i2c_add_numbered_adapter where nr is never -1
1528 * @adap: the adapter to register (with adap->nr initialized)
1538 id = idr_alloc(&i2c_adapter_idr, adap, adap->nr, adap->nr + 1, GFP_KERNEL); in __i2c_add_numbered_adapter()
1541 return id == -ENOSPC ? -EBUSY : id; in __i2c_add_numbered_adapter()
1547 * i2c_add_adapter - declare i2c adapter, use dynamic bus number
1557 * in adap->nr, and the specified adapter became available for clients.
1562 struct device *dev = &adapter->dev; in i2c_add_adapter()
1565 if (dev->of_node) { in i2c_add_adapter()
1566 id = of_alias_get_id(dev->of_node, "i2c"); in i2c_add_adapter()
1568 adapter->nr = id; in i2c_add_adapter()
1580 adapter->nr = id; in i2c_add_adapter()
1587 * i2c_add_numbered_adapter - declare i2c adapter, use static bus number
1588 * @adap: the adapter to register (with adap->nr initialized)
1592 * matters. For example, use it for I2C adapters from system-on-chip CPUs,
1596 * If the requested bus number is set to -1, then this function will behave
1599 * If no devices have pre-been declared for this bus, then be sure to
1604 * clients using the bus number provided in adap->nr. Also, the table
1605 * of I2C devices pre-declared using i2c_register_board_info() is scanned,
1611 if (adap->nr == -1) /* -1 means dynamically assign bus id */ in i2c_add_numbered_adapter()
1625 list_for_each_entry_safe(client, _n, &driver->clients, detected) { in i2c_do_del_adapter()
1626 if (client->adapter == adapter) { in i2c_do_del_adapter()
1627 dev_dbg(&adapter->dev, "Removing %s at 0x%x\n", in i2c_do_del_adapter()
1628 client->name, client->addr); in i2c_do_del_adapter()
1629 list_del(&client->detected); in i2c_do_del_adapter()
1638 if (client && strcmp(client->name, "dummy")) in __unregister_client()
1657 * i2c_del_adapter - unregister I2C adapter
1671 found = idr_find(&i2c_adapter_idr, adap->nr); in i2c_del_adapter()
1674 pr_debug("attempting to delete unregistered adapter [%s]\n", adap->name); in i2c_del_adapter()
1686 mutex_lock_nested(&adap->userspace_clients_lock, in i2c_del_adapter()
1688 list_for_each_entry_safe(client, next, &adap->userspace_clients, in i2c_del_adapter()
1690 dev_dbg(&adap->dev, "Removing %s at 0x%x\n", client->name, in i2c_del_adapter()
1691 client->addr); in i2c_del_adapter()
1692 list_del(&client->detected); in i2c_del_adapter()
1695 mutex_unlock(&adap->userspace_clients_lock); in i2c_del_adapter()
1698 * check the returned value. This is a two-pass process, because in i2c_del_adapter()
1702 device_for_each_child(&adap->dev, NULL, __unregister_client); in i2c_del_adapter()
1703 device_for_each_child(&adap->dev, NULL, __unregister_dummy); in i2c_del_adapter()
1706 class_compat_remove_link(i2c_adapter_compat_class, &adap->dev, in i2c_del_adapter()
1707 adap->dev.parent); in i2c_del_adapter()
1711 dev_dbg(&adap->dev, "adapter [%s] unregistered\n", adap->name); in i2c_del_adapter()
1713 pm_runtime_disable(&adap->dev); in i2c_del_adapter()
1724 init_completion(&adap->dev_released); in i2c_del_adapter()
1725 device_unregister(&adap->dev); in i2c_del_adapter()
1726 wait_for_completion(&adap->dev_released); in i2c_del_adapter()
1730 idr_remove(&i2c_adapter_idr, adap->nr); in i2c_del_adapter()
1735 memset(&adap->dev, 0, sizeof(adap->dev)); in i2c_del_adapter()
1745 * devm_i2c_add_adapter - device-managed variant of i2c_add_adapter()
1778 * i2c_parse_fw_timings - get I2C related timing parameters from firmware
1798 i2c_parse_timing(dev, "clock-frequency", &t->bus_freq_hz, in i2c_parse_fw_timings()
1801 d = t->bus_freq_hz <= I2C_MAX_STANDARD_MODE_FREQ ? 1000 : in i2c_parse_fw_timings()
1802 t->bus_freq_hz <= I2C_MAX_FAST_MODE_FREQ ? 300 : 120; in i2c_parse_fw_timings()
1803 i2c_parse_timing(dev, "i2c-scl-rising-time-ns", &t->scl_rise_ns, d, u); in i2c_parse_fw_timings()
1805 d = t->bus_freq_hz <= I2C_MAX_FAST_MODE_FREQ ? 300 : 120; in i2c_parse_fw_timings()
1806 i2c_parse_timing(dev, "i2c-scl-falling-time-ns", &t->scl_fall_ns, d, u); in i2c_parse_fw_timings()
1808 i2c_parse_timing(dev, "i2c-scl-internal-delay-ns", in i2c_parse_fw_timings()
1809 &t->scl_int_delay_ns, 0, u); in i2c_parse_fw_timings()
1810 i2c_parse_timing(dev, "i2c-sda-falling-time-ns", &t->sda_fall_ns, in i2c_parse_fw_timings()
1811 t->scl_fall_ns, u); in i2c_parse_fw_timings()
1812 i2c_parse_timing(dev, "i2c-sda-hold-time-ns", &t->sda_hold_ns, 0, u); in i2c_parse_fw_timings()
1813 i2c_parse_timing(dev, "i2c-digital-filter-width-ns", in i2c_parse_fw_timings()
1814 &t->digital_filter_width_ns, 0, u); in i2c_parse_fw_timings()
1815 i2c_parse_timing(dev, "i2c-analog-filter-cutoff-frequency", in i2c_parse_fw_timings()
1816 &t->analog_filter_cutoff_freq_hz, 0, u); in i2c_parse_fw_timings()
1820 /* ------------------------------------------------------------------------- */
1836 if (dev->type != &i2c_adapter_type) in __process_new_driver()
1852 return -EAGAIN; in i2c_register_driver()
1855 driver->driver.owner = owner; in i2c_register_driver()
1856 driver->driver.bus = &i2c_bus_type; in i2c_register_driver()
1857 INIT_LIST_HEAD(&driver->clients); in i2c_register_driver()
1860 * will have called probe() for all matching-but-unbound devices. in i2c_register_driver()
1862 res = driver_register(&driver->driver); in i2c_register_driver()
1866 pr_debug("driver [%s] registered\n", driver->driver.name); in i2c_register_driver()
1877 if (dev->type == &i2c_adapter_type) in __process_removed_driver()
1883 * i2c_del_driver - unregister I2C driver
1891 driver_unregister(&driver->driver); in i2c_del_driver()
1892 pr_debug("driver [%s] unregistered\n", driver->driver.name); in i2c_del_driver()
1896 /* ------------------------------------------------------------------------- */
1899 unsigned cmd; member
1909 if (!client || !client->dev.driver) in i2c_cmd()
1912 driver = to_i2c_driver(client->dev.driver); in i2c_cmd()
1913 if (driver->command) in i2c_cmd()
1914 driver->command(client, arg->cmd, arg->arg); in i2c_cmd()
1918 void i2c_clients_command(struct i2c_adapter *adap, unsigned int cmd, void *arg) in i2c_clients_command() argument
1922 cmd_arg.cmd = cmd; in i2c_clients_command()
1924 device_for_each_child(&adap->dev, &cmd_arg, i2c_cmd); in i2c_clients_command()
1946 i2c_adapter_compat_class = class_compat_register("i2c-adapter"); in i2c_init()
1948 retval = -ENOMEM; in i2c_init()
1993 /* ----------------------------------------------------
1995 * ----------------------------------------------------
2003 dev_err_ratelimited(&adap->dev, "adapter quirk: %s (addr 0x%04x, size %u, %s)\n", in i2c_quirk_error()
2004 err_msg, msg->addr, msg->len, in i2c_quirk_error()
2005 msg->flags & I2C_M_RD ? "read" : "write"); in i2c_quirk_error()
2006 return -EOPNOTSUPP; in i2c_quirk_error()
2011 const struct i2c_adapter_quirks *q = adap->quirks; in i2c_check_for_quirks()
2012 int max_num = q->max_num_msgs, i; in i2c_check_for_quirks()
2015 if (q->flags & I2C_AQ_COMB) { in i2c_check_for_quirks()
2020 if (q->flags & I2C_AQ_COMB_WRITE_FIRST && msgs[0].flags & I2C_M_RD) in i2c_check_for_quirks()
2023 if (q->flags & I2C_AQ_COMB_READ_SECOND && !(msgs[1].flags & I2C_M_RD)) in i2c_check_for_quirks()
2026 if (q->flags & I2C_AQ_COMB_SAME_ADDR && msgs[0].addr != msgs[1].addr) in i2c_check_for_quirks()
2029 if (i2c_quirk_exceeded(msgs[0].len, q->max_comb_1st_msg_len)) in i2c_check_for_quirks()
2032 if (i2c_quirk_exceeded(msgs[1].len, q->max_comb_2nd_msg_len)) in i2c_check_for_quirks()
2046 if (do_len_check && i2c_quirk_exceeded(len, q->max_read_len)) in i2c_check_for_quirks()
2049 if (q->flags & I2C_AQ_NO_ZERO_LEN_READ && len == 0) in i2c_check_for_quirks()
2052 if (do_len_check && i2c_quirk_exceeded(len, q->max_write_len)) in i2c_check_for_quirks()
2055 if (q->flags & I2C_AQ_NO_ZERO_LEN_WRITE && len == 0) in i2c_check_for_quirks()
2064 * __i2c_transfer - unlocked flavor of i2c_transfer
2073 * takes place. adap->algo->master_xfer existence isn't checked.
2081 return -EINVAL; in __i2c_transfer()
2087 if (adap->quirks && i2c_check_for_quirks(adap, msgs, num)) in __i2c_transfer()
2088 return -EOPNOTSUPP; in __i2c_transfer()
2092 * enabled. This is an efficient way of keeping the for-loop from in __i2c_transfer()
2106 for (ret = 0, try = 0; try <= adap->retries; try++) { in __i2c_transfer()
2107 if (i2c_in_atomic_xfer_mode() && adap->algo->master_xfer_atomic) in __i2c_transfer()
2108 ret = adap->algo->master_xfer_atomic(adap, msgs, num); in __i2c_transfer()
2110 ret = adap->algo->master_xfer(adap, msgs, num); in __i2c_transfer()
2112 if (ret != -EAGAIN) in __i2c_transfer()
2114 if (time_after(jiffies, orig_jiffies + adap->timeout)) in __i2c_transfer()
2131 * i2c_transfer - execute a single or combined I2C message
2146 if (!adap->algo->master_xfer) { in i2c_transfer()
2147 dev_dbg(&adap->dev, "I2C level transfers not supported\n"); in i2c_transfer()
2148 return -EOPNOTSUPP; in i2c_transfer()
2153 * - When we get an error after receiving N bytes from a slave, in i2c_transfer()
2156 * - When we get a NAK after transmitting N bytes to a slave, in i2c_transfer()
2161 * - When for example "num" is two and we successfully complete in i2c_transfer()
2179 * i2c_transfer_buffer_flags - issue a single I2C message transferring data
2193 .addr = client->addr, in i2c_transfer_buffer_flags()
2194 .flags = flags | (client->flags & I2C_M_TEN), in i2c_transfer_buffer_flags()
2199 ret = i2c_transfer(client->adapter, &msg, 1); in i2c_transfer_buffer_flags()
2210 * i2c_get_device_id - get manufacturer, part id and die revision of a device
2219 struct i2c_adapter *adap = client->adapter; in i2c_get_device_id()
2224 return -EOPNOTSUPP; in i2c_get_device_id()
2228 I2C_SMBUS_READ, client->addr << 1, in i2c_get_device_id()
2233 id->manufacturer_id = (raw_id.block[1] << 4) | (raw_id.block[2] >> 4); in i2c_get_device_id()
2234 id->part_id = ((raw_id.block[2] & 0xf) << 5) | (raw_id.block[3] >> 3); in i2c_get_device_id()
2235 id->die_revision = raw_id.block[3] & 0x7; in i2c_get_device_id()
2240 /* ----------------------------------------------------
2242 * Will not work for 10-bit addresses!
2243 * ----------------------------------------------------
2250 * write-protect some EEPROMs, so for address ranges 0x30-0x37 and 0x50-0x5f,
2264 if (addr == 0x73 && (adap->class & I2C_CLASS_HWMON) in i2c_default_probe()
2278 dev_warn(&adap->dev, "No suitable probing method supported for address 0x%02X\n", in i2c_default_probe()
2280 err = -EOPNOTSUPP; in i2c_default_probe()
2290 struct i2c_adapter *adapter = temp_client->adapter; in i2c_detect_address()
2291 int addr = temp_client->addr; in i2c_detect_address()
2297 dev_warn(&adapter->dev, "Invalid probe address 0x%02x\n", in i2c_detect_address()
2313 err = driver->detect(temp_client, &info); in i2c_detect_address()
2315 /* -ENODEV is returned if the detection fails. We catch it in i2c_detect_address()
2317 return err == -ENODEV ? 0 : err; in i2c_detect_address()
2322 dev_err(&adapter->dev, in i2c_detect_address()
2324 driver->driver.name, addr); in i2c_detect_address()
2329 if (adapter->class & I2C_CLASS_DEPRECATED) in i2c_detect_address()
2330 dev_warn(&adapter->dev, in i2c_detect_address()
2333 "Check 'Documentation/i2c/instantiating-devices.rst' for details.\n", in i2c_detect_address()
2336 dev_dbg(&adapter->dev, "Creating %s at 0x%02x\n", in i2c_detect_address()
2340 list_add_tail(&client->detected, &driver->clients); in i2c_detect_address()
2342 dev_err(&adapter->dev, "Failed creating %s at 0x%02x\n", in i2c_detect_address()
2354 address_list = driver->address_list; in i2c_detect()
2355 if (!driver->detect || !address_list) in i2c_detect()
2359 if (adapter->class == I2C_CLASS_DEPRECATED) { in i2c_detect()
2360 dev_dbg(&adapter->dev, in i2c_detect()
2361 "This adapter dropped support for I2C classes and won't auto-detect %s devices anymore. " in i2c_detect()
2362 "If you need it, check 'Documentation/i2c/instantiating-devices.rst' for alternatives.\n", in i2c_detect()
2363 driver->driver.name); in i2c_detect()
2368 if (!(adapter->class & driver->class)) in i2c_detect()
2374 return -ENOMEM; in i2c_detect()
2375 temp_client->adapter = adapter; in i2c_detect()
2378 dev_dbg(&adapter->dev, in i2c_detect()
2381 temp_client->addr = address_list[i]; in i2c_detect()
2412 dev_warn(&adap->dev, "Invalid 7-bit address 0x%02x\n", in i2c_new_scanned_device()
2419 dev_dbg(&adap->dev, in i2c_new_scanned_device()
2431 dev_dbg(&adap->dev, "Probing failed, no device found\n"); in i2c_new_scanned_device()
2432 return ERR_PTR(-ENODEV); in i2c_new_scanned_device()
2435 info->addr = addr_list[i]; in i2c_new_scanned_device()
2449 if (try_module_get(adapter->owner)) in i2c_get_adapter()
2450 get_device(&adapter->dev); in i2c_get_adapter()
2465 module_put(adap->owner); in i2c_put_adapter()
2466 /* Should be last, otherwise we risk use-after-free with 'adap' */ in i2c_put_adapter()
2467 put_device(&adap->dev); in i2c_put_adapter()
2472 * i2c_get_dma_safe_msg_buf() - get a DMA safe buffer for the given i2c_msg
2477 * Return: NULL if a DMA safe buffer was not obtained. Use msg->buf with PIO.
2485 /* also skip 0-length msgs for bogus thresholds of 0 */ in i2c_get_dma_safe_msg_buf()
2488 msg->addr); in i2c_get_dma_safe_msg_buf()
2489 if (msg->len < threshold || msg->len == 0) in i2c_get_dma_safe_msg_buf()
2492 if (msg->flags & I2C_M_DMA_SAFE) in i2c_get_dma_safe_msg_buf()
2493 return msg->buf; in i2c_get_dma_safe_msg_buf()
2496 msg->addr, msg->len); in i2c_get_dma_safe_msg_buf()
2498 if (msg->flags & I2C_M_RD) in i2c_get_dma_safe_msg_buf()
2499 return kzalloc(msg->len, GFP_KERNEL); in i2c_get_dma_safe_msg_buf()
2501 return kmemdup(msg->buf, msg->len, GFP_KERNEL); in i2c_get_dma_safe_msg_buf()
2506 * i2c_put_dma_safe_msg_buf - release DMA safe buffer and sync with i2c_msg
2513 if (!buf || buf == msg->buf) in i2c_put_dma_safe_msg_buf()
2516 if (xferred && msg->flags & I2C_M_RD) in i2c_put_dma_safe_msg_buf()
2517 memcpy(msg->buf, buf, msg->len); in i2c_put_dma_safe_msg_buf()
2523 MODULE_AUTHOR("Simon G. Vogl <simon@tk.uni-linz.ac.at>");
2524 MODULE_DESCRIPTION("I2C-Bus main module");