Commit 61684c0f authored by Gil Fine's avatar Gil Fine Committed by Mika Westerberg

thunderbolt: Fix uninitialized variable in tb_tunnel_alloc_usb3()

Currently in case of no bandwidth available for USB3 tunnel, we are left
with uninitialized variable that can lead to huge negative allocated
bandwidth.

Fix this by initializing the variable to zero. While there, fix the
kernel-doc to describe more accurately the purpose of the function
tb_tunnel_alloc_usb3().
Reported-by: default avatarDan Carpenter <dan.carpenter@linaro.org>
Closes: https://lore.kernel.org/linux-usb/6289898b-cd63-4fb8-906a-1b6977321af9@moroto.mountain/
Fixes: 25d905d2 ("thunderbolt: Allow USB3 bandwidth to be lower than maximum supported")
Signed-off-by: default avatarGil Fine <gil.fine@linux.intel.com>
Signed-off-by: default avatarMika Westerberg <mika.westerberg@linux.intel.com>
parent a3ad3a90
...@@ -2048,10 +2048,10 @@ struct tb_tunnel *tb_tunnel_discover_usb3(struct tb *tb, struct tb_port *down, ...@@ -2048,10 +2048,10 @@ struct tb_tunnel *tb_tunnel_discover_usb3(struct tb *tb, struct tb_port *down,
* @tb: Pointer to the domain structure * @tb: Pointer to the domain structure
* @up: USB3 upstream adapter port * @up: USB3 upstream adapter port
* @down: USB3 downstream adapter port * @down: USB3 downstream adapter port
* @max_up: Maximum available upstream bandwidth for the USB3 tunnel (%0 * @max_up: Maximum available upstream bandwidth for the USB3 tunnel.
* if not limited). * %0 if no available bandwidth.
* @max_down: Maximum available downstream bandwidth for the USB3 tunnel * @max_down: Maximum available downstream bandwidth for the USB3 tunnel.
* (%0 if not limited). * %0 if no available bandwidth.
* *
* Allocate an USB3 tunnel. The ports must be of type @TB_TYPE_USB3_UP and * Allocate an USB3 tunnel. The ports must be of type @TB_TYPE_USB3_UP and
* @TB_TYPE_USB3_DOWN. * @TB_TYPE_USB3_DOWN.
...@@ -2064,7 +2064,7 @@ struct tb_tunnel *tb_tunnel_alloc_usb3(struct tb *tb, struct tb_port *up, ...@@ -2064,7 +2064,7 @@ struct tb_tunnel *tb_tunnel_alloc_usb3(struct tb *tb, struct tb_port *up,
{ {
struct tb_tunnel *tunnel; struct tb_tunnel *tunnel;
struct tb_path *path; struct tb_path *path;
int max_rate; int max_rate = 0;
if (!tb_route(down->sw) && (max_up > 0 || max_down > 0)) { if (!tb_route(down->sw) && (max_up > 0 || max_down > 0)) {
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment