thunderbolt: Fix minimum allocated USB 3.x and PCIe bandwidth
authorGil Fine <gil.fine@linux.intel.com>
Thu, 30 Nov 2023 16:17:13 +0000 (18:17 +0200)
committerMika Westerberg <mika.westerberg@linux.intel.com>
Fri, 8 Dec 2023 07:03:49 +0000 (09:03 +0200)
commitf0b94c1c5c7994a74e487f43c91cfc922105a423
tree72d4ee47d61b2d875cfa942fc042a083f3e36468
parentac43c9122e4287bbdbe91e980fc2528acb72cc1e
thunderbolt: Fix minimum allocated USB 3.x and PCIe bandwidth

With the current bandwidth allocation we end up reserving too much for the USB
3.x and PCIe tunnels that leads to reduced capabilities for the second
DisplayPort tunnel.

Fix this by decreasing the USB 3.x allocation to 900 Mb/s which then allows
both tunnels to get the maximum HBR2 bandwidth.  This way, the reserved
bandwidth for USB 3.x and PCIe, would be 1350 Mb/s (taking weights of USB 3.x
and PCIe into account). So bandwidth allocations on a link are:
USB 3.x + PCIe tunnels => 1350 Mb/s
DisplayPort tunnel #1  => 17280 Mb/s
DisplayPort tunnel #2  => 17280 Mb/s

Total consumed bandwidth is 35910 Mb/s. So that all the above can be tunneled
on a Gen 3 link (which allows maximum of 36000 Mb/s).

Fixes: 582e70b0d3a4 ("thunderbolt: Change bandwidth reservations to comply USB4 v2")
Signed-off-by: Gil Fine <gil.fine@linux.intel.com>
Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
drivers/thunderbolt/usb4.c