thunderbolt: Add support for XDomain lane bonding
authorMika Westerberg <mika.westerberg@linux.intel.com>
Sun, 13 Feb 2022 14:44:45 +0000 (16:44 +0200)
committerMika Westerberg <mika.westerberg@linux.intel.com>
Thu, 5 May 2022 06:25:23 +0000 (09:25 +0300)
commit8e1de7042596abb7cb277ea751fc13a4c2b65aea
tree62cc3e0ba5c2875011a2e95c69e1ab3372dfc40c
parent0a2e1667a73fe0c4374ddace925d85a4072d509c
thunderbolt: Add support for XDomain lane bonding

The USB4 Inter-Domain Service specification defines a protocol that can
be used to establish lane bonding between two USB4 domains (hosts). So
far we have not implemented it because the host controller DMA was not
fast enough to be able to go over 20 Gbits/s even if lanes were bonded.
However, starting from Intel Alder Lake CPUs the DMA can go over
20 Gbits/s so now it makes more sense to add this support to the driver.

Because both ends need to negotiate the bonding we add a simple state
machine that tracks the connection state and does the necessary steps
described by the USB4 Inter-Domain Service specification. We only
establish lane bonding when both sides of the link support it. Otherwise
we default to use the single lane. Also this is only done when software
connection manager is used. On systems with firmware based connection
manager, it handles the high-speed tunneling so bonding lanes is
specific to the implementation (Intel firmware based connection manager
does not support lane bonding).

Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
drivers/thunderbolt/tb.c
drivers/thunderbolt/tb_msgs.h
drivers/thunderbolt/tb_regs.h
drivers/thunderbolt/xdomain.c
include/linux/thunderbolt.h