Lines Matching +full:mctp +full:- +full:controller
1 // SPDX-License-Identifier: GPL-2.0
3 * Management Controller Transport Protocol (MCTP)
5 * "DSP0237 Management Component Transport Protocol (MCTP) SMBus/I2C
9 * A netdev is created for each I2C bus that handles MCTP. In the case of an I2C
11 * shared between all mux I2C busses underneath. For non-mux cases an I2C client
14 * mctp-i2c-controller.yml devicetree binding has further details.
23 #include <linux/i2c-mux.h>
25 #include <net/mctp.h>
31 #define MCTP_I2C_MAXMTU (MCTP_I2C_MAXBLOCK - 1)
41 #define MCTP_I2C_OF_PROP "mctp-controller"
118 return i2c_root_adapter(&adap->dev); in mux_root_adapter()
120 /* In non-mux config all i2c adapters are root adapters */ in mux_root_adapter()
135 if (client->flags & I2C_CLIENT_TEN) { in mctp_i2c_new_client()
136 dev_err(&client->dev, "failed, MCTP requires a 7-bit I2C address, addr=0x%x\n", in mctp_i2c_new_client()
137 client->addr); in mctp_i2c_new_client()
138 rc = -EINVAL; in mctp_i2c_new_client()
142 root = mux_root_adapter(client->adapter); in mctp_i2c_new_client()
144 dev_err(&client->dev, "failed to find root adapter\n"); in mctp_i2c_new_client()
145 rc = -ENOENT; in mctp_i2c_new_client()
148 if (root != client->adapter) { in mctp_i2c_new_client()
149 dev_err(&client->dev, in mctp_i2c_new_client()
150 "A mctp-i2c-controller client cannot be placed on an I2C mux adapter.\n" in mctp_i2c_new_client()
152 " then set mctp-controller property on adapters to attach\n"); in mctp_i2c_new_client()
153 rc = -EINVAL; in mctp_i2c_new_client()
159 rc = -ENOMEM; in mctp_i2c_new_client()
162 spin_lock_init(&mcli->sel_lock); in mctp_i2c_new_client()
163 INIT_LIST_HEAD(&mcli->devs); in mctp_i2c_new_client()
164 INIT_LIST_HEAD(&mcli->list); in mctp_i2c_new_client()
165 mcli->lladdr = client->addr & 0xff; in mctp_i2c_new_client()
166 mcli->client = client; in mctp_i2c_new_client()
169 rc = i2c_slave_register(mcli->client, mctp_i2c_slave_cb); in mctp_i2c_new_client()
171 dev_err(&client->dev, "i2c register failed %d\n", rc); in mctp_i2c_new_client()
172 mcli->client = NULL; in mctp_i2c_new_client()
180 if (mcli->client) in mctp_i2c_new_client()
181 i2c_unregister_device(mcli->client); in mctp_i2c_new_client()
192 WARN_ON(!list_empty(&mcli->devs)); in mctp_i2c_free_client()
193 WARN_ON(mcli->sel); /* sanity check, no locking */ in mctp_i2c_free_client()
195 rc = i2c_slave_unregister(mcli->client); in mctp_i2c_free_client()
198 dev_err(&mcli->client->dev, "i2c unregister failed %d\n", rc); in mctp_i2c_free_client()
203 /* Switch the mctp i2c device to receive responses.
209 assert_spin_locked(&mcli->sel_lock); in __mctp_i2c_device_select()
211 dev_hold(midev->ndev); in __mctp_i2c_device_select()
212 if (mcli->sel) in __mctp_i2c_device_select()
213 dev_put(mcli->sel->ndev); in __mctp_i2c_device_select()
214 mcli->sel = midev; in __mctp_i2c_device_select()
217 /* Switch the mctp i2c device to receive responses */
223 spin_lock_irqsave(&mcli->sel_lock, flags); in mctp_i2c_device_select()
225 spin_unlock_irqrestore(&mcli->sel_lock, flags); in mctp_i2c_device_select()
236 spin_lock_irqsave(&mcli->sel_lock, flags); in mctp_i2c_slave_cb()
237 midev = mcli->sel; in mctp_i2c_slave_cb()
239 dev_hold(midev->ndev); in mctp_i2c_slave_cb()
240 spin_unlock_irqrestore(&mcli->sel_lock, flags); in mctp_i2c_slave_cb()
247 if (midev->rx_pos < MCTP_I2C_BUFSZ) { in mctp_i2c_slave_cb()
248 midev->rx_buffer[midev->rx_pos] = *val; in mctp_i2c_slave_cb()
249 midev->rx_pos++; in mctp_i2c_slave_cb()
251 midev->ndev->stats.rx_over_errors++; in mctp_i2c_slave_cb()
257 midev->rx_buffer[0] = mcli->lladdr << 1; in mctp_i2c_slave_cb()
258 midev->rx_pos = 1; in mctp_i2c_slave_cb()
267 dev_put(midev->ndev); in mctp_i2c_slave_cb()
274 struct net_device *ndev = midev->ndev; in mctp_i2c_recv()
284 if (midev->rx_pos < MCTP_I2C_MINLEN + 1) { in mctp_i2c_recv()
285 ndev->stats.rx_length_errors++; in mctp_i2c_recv()
286 return -EINVAL; in mctp_i2c_recv()
289 recvlen = midev->rx_pos - 1; in mctp_i2c_recv()
291 hdr = (void *)midev->rx_buffer; in mctp_i2c_recv()
292 if (hdr->command != MCTP_I2C_COMMANDCODE) { in mctp_i2c_recv()
293 ndev->stats.rx_dropped++; in mctp_i2c_recv()
294 return -EINVAL; in mctp_i2c_recv()
297 if (hdr->byte_count + offsetof(struct mctp_i2c_hdr, source_slave) != recvlen) { in mctp_i2c_recv()
298 ndev->stats.rx_length_errors++; in mctp_i2c_recv()
299 return -EINVAL; in mctp_i2c_recv()
302 pec = midev->rx_buffer[midev->rx_pos - 1]; in mctp_i2c_recv()
303 calc_pec = i2c_smbus_pec(0, midev->rx_buffer, recvlen); in mctp_i2c_recv()
305 ndev->stats.rx_crc_errors++; in mctp_i2c_recv()
306 return -EINVAL; in mctp_i2c_recv()
311 ndev->stats.rx_dropped++; in mctp_i2c_recv()
312 return -ENOMEM; in mctp_i2c_recv()
315 skb->protocol = htons(ETH_P_MCTP); in mctp_i2c_recv()
316 skb_put_data(skb, midev->rx_buffer, recvlen); in mctp_i2c_recv()
322 cb->halen = 1; in mctp_i2c_recv()
323 cb->haddr[0] = hdr->source_slave >> 1; in mctp_i2c_recv()
328 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_recv()
329 if (midev->allow_rx) { in mctp_i2c_recv()
330 reinit_completion(&midev->rx_done); in mctp_i2c_recv()
331 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_recv()
334 complete(&midev->rx_done); in mctp_i2c_recv()
337 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_recv()
341 ndev->stats.rx_packets++; in mctp_i2c_recv()
342 ndev->stats.rx_bytes += recvlen; in mctp_i2c_recv()
344 ndev->stats.rx_dropped++; in mctp_i2c_recv()
368 key = flow->key; in mctp_i2c_get_tx_flow_state()
372 spin_lock_irqsave(&key->lock, flags); in mctp_i2c_get_tx_flow_state()
376 if (!key->valid) { in mctp_i2c_get_tx_flow_state()
379 switch (key->dev_flow_state) { in mctp_i2c_get_tx_flow_state()
381 key->dev_flow_state = MCTP_I2C_FLOW_STATE_ACTIVE; in mctp_i2c_get_tx_flow_state()
392 spin_unlock_irqrestore(&key->lock, flags); in mctp_i2c_get_tx_flow_state()
406 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_lock_nest()
407 lock = midev->i2c_lock_count == 0; in mctp_i2c_lock_nest()
408 midev->i2c_lock_count++; in mctp_i2c_lock_nest()
409 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_lock_nest()
412 i2c_lock_bus(midev->adapter, I2C_LOCK_SEGMENT); in mctp_i2c_lock_nest()
420 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_unlock_nest()
421 if (!WARN_ONCE(midev->i2c_lock_count == 0, "lock count underflow!")) in mctp_i2c_unlock_nest()
422 midev->i2c_lock_count--; in mctp_i2c_unlock_nest()
423 unlock = midev->i2c_lock_count == 0; in mctp_i2c_unlock_nest()
424 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_unlock_nest()
427 i2c_unlock_bus(midev->adapter, I2C_LOCK_SEGMENT); in mctp_i2c_unlock_nest()
436 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_unlock_reset()
437 unlock = midev->i2c_lock_count > 0; in mctp_i2c_unlock_reset()
438 midev->i2c_lock_count = 0; in mctp_i2c_unlock_reset()
439 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_unlock_reset()
442 i2c_unlock_bus(midev->adapter, I2C_LOCK_SEGMENT); in mctp_i2c_unlock_reset()
447 struct net_device_stats *stats = &midev->ndev->stats; in mctp_i2c_xmit()
460 if (skb->len != hdr->byte_count + 3) { in mctp_i2c_xmit()
461 dev_warn_ratelimited(&midev->adapter->dev, in mctp_i2c_xmit()
463 hdr->byte_count + 3, skb->len); in mctp_i2c_xmit()
472 skb_copy_bits(skb, 0, midev->tx_scratch, skb->len); in mctp_i2c_xmit()
473 hdr = (void *)midev->tx_scratch; in mctp_i2c_xmit()
476 pecp = (void *)&hdr->source_slave + hdr->byte_count; in mctp_i2c_xmit()
477 *pecp = i2c_smbus_pec(0, (u8 *)hdr, hdr->byte_count + 3); in mctp_i2c_xmit()
478 msg.buf = (void *)&hdr->command; in mctp_i2c_xmit()
480 msg.len = 2 + hdr->byte_count + 1; in mctp_i2c_xmit()
481 msg.addr = hdr->dest_slave >> 1; in mctp_i2c_xmit()
487 mctp_i2c_device_select(midev->client, midev); in mctp_i2c_xmit()
488 rc = __i2c_transfer(midev->adapter, &msg, 1); in mctp_i2c_xmit()
497 mctp_i2c_device_select(midev->client, midev); in mctp_i2c_xmit()
502 rc = __i2c_transfer(midev->adapter, &msg, 1); in mctp_i2c_xmit()
510 dev_warn_ratelimited(&midev->adapter->dev, in mctp_i2c_xmit()
512 stats->tx_errors++; in mctp_i2c_xmit()
514 stats->tx_bytes += skb->len; in mctp_i2c_xmit()
515 stats->tx_packets++; in mctp_i2c_xmit()
524 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_flow_release()
525 if (midev->release_count > midev->i2c_lock_count) { in mctp_i2c_flow_release()
527 midev->release_count = midev->i2c_lock_count; in mctp_i2c_flow_release()
530 midev->i2c_lock_count -= midev->release_count; in mctp_i2c_flow_release()
531 unlock = midev->i2c_lock_count == 0 && midev->release_count > 0; in mctp_i2c_flow_release()
532 midev->release_count = 0; in mctp_i2c_flow_release()
533 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_flow_release()
536 i2c_unlock_bus(midev->adapter, I2C_LOCK_SEGMENT); in mctp_i2c_flow_release()
548 return -EMSGSIZE; in mctp_i2c_header_create()
557 hdr->dest_slave = (lldst << 1) & 0xff; in mctp_i2c_header_create()
558 hdr->command = MCTP_I2C_COMMANDCODE; in mctp_i2c_header_create()
559 hdr->byte_count = len + 1; in mctp_i2c_header_create()
560 hdr->source_slave = ((llsrc << 1) & 0xff) | 0x01; in mctp_i2c_header_create()
561 mhdr->ver = 0x01; in mctp_i2c_header_create()
576 spin_lock_irqsave(&midev->tx_queue.lock, flags); in mctp_i2c_tx_thread()
577 skb = __skb_dequeue(&midev->tx_queue); in mctp_i2c_tx_thread()
578 if (netif_queue_stopped(midev->ndev)) in mctp_i2c_tx_thread()
579 netif_wake_queue(midev->ndev); in mctp_i2c_tx_thread()
580 spin_unlock_irqrestore(&midev->tx_queue.lock, flags); in mctp_i2c_tx_thread()
582 if (skb == &midev->unlock_marker) { in mctp_i2c_tx_thread()
590 wait_event_idle(midev->tx_wq, in mctp_i2c_tx_thread()
591 !skb_queue_empty(&midev->tx_queue) || in mctp_i2c_tx_thread()
605 spin_lock_irqsave(&midev->tx_queue.lock, flags); in mctp_i2c_start_xmit()
606 if (skb_queue_len(&midev->tx_queue) >= MCTP_I2C_TX_WORK_LEN) { in mctp_i2c_start_xmit()
608 spin_unlock_irqrestore(&midev->tx_queue.lock, flags); in mctp_i2c_start_xmit()
613 __skb_queue_tail(&midev->tx_queue, skb); in mctp_i2c_start_xmit()
614 if (skb_queue_len(&midev->tx_queue) == MCTP_I2C_TX_WORK_LEN) in mctp_i2c_start_xmit()
616 spin_unlock_irqrestore(&midev->tx_queue.lock, flags); in mctp_i2c_start_xmit()
618 wake_up(&midev->tx_wq); in mctp_i2c_start_xmit()
626 struct mctp_i2c_dev *midev = netdev_priv(mdev->dev); in mctp_i2c_release_flow()
630 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_release_flow()
634 if (key->dev_flow_state == MCTP_I2C_FLOW_STATE_ACTIVE) { in mctp_i2c_release_flow()
635 midev->release_count++; in mctp_i2c_release_flow()
638 key->dev_flow_state = MCTP_I2C_FLOW_STATE_INVALID; in mctp_i2c_release_flow()
639 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_release_flow()
645 spin_lock(&midev->tx_queue.lock); in mctp_i2c_release_flow()
646 if (!midev->unlock_marker.next) in mctp_i2c_release_flow()
647 __skb_queue_tail(&midev->tx_queue, in mctp_i2c_release_flow()
648 &midev->unlock_marker); in mctp_i2c_release_flow()
649 spin_unlock(&midev->tx_queue.lock); in mctp_i2c_release_flow()
650 wake_up(&midev->tx_wq); in mctp_i2c_release_flow()
670 dev->type = ARPHRD_MCTP; in mctp_i2c_net_setup()
672 dev->mtu = MCTP_I2C_MAXMTU; in mctp_i2c_net_setup()
673 dev->min_mtu = MCTP_I2C_MINMTU; in mctp_i2c_net_setup()
674 dev->max_mtu = MCTP_I2C_MAXMTU; in mctp_i2c_net_setup()
675 dev->tx_queue_len = MCTP_I2C_TX_QUEUE_LEN; in mctp_i2c_net_setup()
677 dev->hard_header_len = sizeof(struct mctp_i2c_hdr); in mctp_i2c_net_setup()
678 dev->addr_len = 1; in mctp_i2c_net_setup()
680 dev->netdev_ops = &mctp_i2c_ops; in mctp_i2c_net_setup()
681 dev->header_ops = &mctp_i2c_headops; in mctp_i2c_net_setup()
694 midev->tx_thread = kthread_create(mctp_i2c_tx_thread, midev, in mctp_i2c_midev_init()
695 "%s/tx", dev->name); in mctp_i2c_midev_init()
696 if (IS_ERR(midev->tx_thread)) in mctp_i2c_midev_init()
697 return ERR_CAST(midev->tx_thread); in mctp_i2c_midev_init()
699 midev->ndev = dev; in mctp_i2c_midev_init()
700 get_device(&adap->dev); in mctp_i2c_midev_init()
701 midev->adapter = adap; in mctp_i2c_midev_init()
702 get_device(&mcli->client->dev); in mctp_i2c_midev_init()
703 midev->client = mcli; in mctp_i2c_midev_init()
704 INIT_LIST_HEAD(&midev->list); in mctp_i2c_midev_init()
705 spin_lock_init(&midev->lock); in mctp_i2c_midev_init()
706 midev->i2c_lock_count = 0; in mctp_i2c_midev_init()
707 midev->release_count = 0; in mctp_i2c_midev_init()
708 init_completion(&midev->rx_done); in mctp_i2c_midev_init()
709 complete(&midev->rx_done); in mctp_i2c_midev_init()
710 init_waitqueue_head(&midev->tx_wq); in mctp_i2c_midev_init()
711 skb_queue_head_init(&midev->tx_queue); in mctp_i2c_midev_init()
714 spin_lock_irqsave(&mcli->sel_lock, flags); in mctp_i2c_midev_init()
715 list_add(&midev->list, &mcli->devs); in mctp_i2c_midev_init()
717 if (!mcli->sel) in mctp_i2c_midev_init()
719 spin_unlock_irqrestore(&mcli->sel_lock, flags); in mctp_i2c_midev_init()
722 wake_up_process(midev->tx_thread); in mctp_i2c_midev_init()
730 struct mctp_i2c_client *mcli = midev->client; in mctp_i2c_midev_free()
733 if (midev->tx_thread) { in mctp_i2c_midev_free()
734 kthread_stop(midev->tx_thread); in mctp_i2c_midev_free()
735 midev->tx_thread = NULL; in mctp_i2c_midev_free()
742 spin_lock_irqsave(&mcli->sel_lock, flags); in mctp_i2c_midev_free()
743 list_del(&midev->list); in mctp_i2c_midev_free()
744 if (mcli->sel == midev) { in mctp_i2c_midev_free()
747 first = list_first_entry_or_null(&mcli->devs, struct mctp_i2c_dev, list); in mctp_i2c_midev_free()
750 spin_unlock_irqrestore(&mcli->sel_lock, flags); in mctp_i2c_midev_free()
752 skb_queue_purge(&midev->tx_queue); in mctp_i2c_midev_free()
753 put_device(&midev->adapter->dev); in mctp_i2c_midev_free()
754 put_device(&mcli->client->dev); in mctp_i2c_midev_free()
763 kthread_stop(midev->tx_thread); in mctp_i2c_unregister()
764 midev->tx_thread = NULL; in mctp_i2c_unregister()
767 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_unregister()
768 midev->allow_rx = false; in mctp_i2c_unregister()
769 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_unregister()
770 wait_for_completion(&midev->rx_done); in mctp_i2c_unregister()
772 mctp_unregister_netdev(midev->ndev); in mctp_i2c_unregister()
775 free_netdev(midev->ndev); in mctp_i2c_unregister()
782 /* Perform cleanup here to ensure that mcli->sel isn't holding in mctp_i2c_ndo_uninit()
795 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_ndo_open()
796 midev->allow_rx = true; in mctp_i2c_ndo_open()
797 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_ndo_open()
813 if (root != mcli->client->adapter) { in mctp_i2c_add_netdev()
814 dev_err(&mcli->client->dev, in mctp_i2c_add_netdev()
816 mcli->client->adapter->name, root->name); in mctp_i2c_add_netdev()
817 return -EINVAL; in mctp_i2c_add_netdev()
821 snprintf(namebuf, sizeof(namebuf), "mctpi2c%d", adap->nr); in mctp_i2c_add_netdev()
824 dev_err(&mcli->client->dev, "alloc netdev failed\n"); in mctp_i2c_add_netdev()
825 rc = -ENOMEM; in mctp_i2c_add_netdev()
828 dev_net_set(ndev, current->nsproxy->net_ns); in mctp_i2c_add_netdev()
829 SET_NETDEV_DEV(ndev, &adap->dev); in mctp_i2c_add_netdev()
830 dev_addr_set(ndev, &mcli->lladdr); in mctp_i2c_add_netdev()
841 dev_err(&mcli->client->dev, in mctp_i2c_add_netdev()
843 ndev->name, rc); in mctp_i2c_add_netdev()
847 spin_lock_irqsave(&midev->lock, flags); in mctp_i2c_add_netdev()
848 midev->allow_rx = false; in mctp_i2c_add_netdev()
849 spin_unlock_irqrestore(&midev->lock, flags); in mctp_i2c_add_netdev()
868 spin_lock_irqsave(&mcli->sel_lock, flags); in mctp_i2c_remove_netdev()
869 /* List size is limited by number of MCTP netdevs on a single hardware bus */ in mctp_i2c_remove_netdev()
870 list_for_each_entry(m, &mcli->devs, list) in mctp_i2c_remove_netdev()
871 if (m->adapter == adap) { in mctp_i2c_remove_netdev()
875 spin_unlock_irqrestore(&mcli->sel_lock, flags); in mctp_i2c_remove_netdev()
889 if (dev->type != &i2c_adapter_type) in mctp_i2c_get_adapter()
893 WARN_ONCE(!root, "MCTP I2C failed to find root adapter for %s\n", in mctp_i2c_get_adapter()
902 /* Determines whether a device is an i2c adapter with the "mctp-controller"
907 if (!adap->dev.of_node) in mctp_i2c_adapter_match()
909 return of_property_read_bool(adap->dev.of_node, MCTP_I2C_OF_PROP); in mctp_i2c_adapter_match()
913 * new mctp-i2c client is probed.
923 if (mcli->client->adapter != root) in mctp_i2c_client_try_attach()
925 /* Must either have mctp-controller property on the adapter, or in mctp_i2c_client_try_attach()
926 * be a root adapter if it's non-devicetree in mctp_i2c_client_try_attach()
943 /* Check for mctp-controller property on the adapter */ in mctp_i2c_notify_add()
950 if (m->client->adapter == root) { in mctp_i2c_notify_add()
959 dev_warn(dev, "Failed adding mctp-i2c net device\n"); in mctp_i2c_notify_add()
975 if (mcli->client->adapter == root) { in mctp_i2c_notify_del()
995 list_add(&mcli->list, &driver_clients); in mctp_i2c_probe()
998 /* Add a netdev for adapters that have a 'mctp-controller' property */ in mctp_i2c_probe()
1012 list_del(&mcli->list); in mctp_i2c_remove()
1014 list_for_each_entry_safe(midev, tmp, &mcli->devs, list) in mctp_i2c_remove()
1021 /* We look for a 'mctp-controller' property on I2C busses as they are
1045 { "mctp-i2c-interface", 0 },
1051 { .compatible = "mctp-i2c-controller" },
1058 .name = "mctp-i2c-interface",
1070 pr_info("MCTP I2C interface driver\n"); in mctp_i2c_mod_init()
1088 pr_warn("MCTP I2C could not unregister notifier, %d\n", rc); in mctp_i2c_mod_exit()
1095 MODULE_DESCRIPTION("MCTP I2C device");