Commit e2e4b93e authored by Navid Emamdoost's avatar Navid Emamdoost Committed by Kelsey Skunberg

ath9k_htc: release allocated buffer if timed out

BugLink: https://bugs.launchpad.net/bugs/1892822

[ Upstream commit 853acf7c ]

In htc_config_pipe_credits, htc_setup_complete, and htc_connect_service
if time out happens, the allocated buffer needs to be released.
Otherwise there will be memory leak.
Signed-off-by: default avatarNavid Emamdoost <navid.emamdoost@gmail.com>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
Signed-off-by: default avatarIan May <ian.may@canonical.com>
Signed-off-by: default avatarKelsey Skunberg <kelsey.skunberg@canonical.com>
parent 870d4a34
...@@ -175,6 +175,7 @@ static int htc_config_pipe_credits(struct htc_target *target) ...@@ -175,6 +175,7 @@ static int htc_config_pipe_credits(struct htc_target *target)
time_left = wait_for_completion_timeout(&target->cmd_wait, HZ); time_left = wait_for_completion_timeout(&target->cmd_wait, HZ);
if (!time_left) { if (!time_left) {
dev_err(target->dev, "HTC credit config timeout\n"); dev_err(target->dev, "HTC credit config timeout\n");
kfree_skb(skb);
return -ETIMEDOUT; return -ETIMEDOUT;
} }
...@@ -211,6 +212,7 @@ static int htc_setup_complete(struct htc_target *target) ...@@ -211,6 +212,7 @@ static int htc_setup_complete(struct htc_target *target)
time_left = wait_for_completion_timeout(&target->cmd_wait, HZ); time_left = wait_for_completion_timeout(&target->cmd_wait, HZ);
if (!time_left) { if (!time_left) {
dev_err(target->dev, "HTC start timeout\n"); dev_err(target->dev, "HTC start timeout\n");
kfree_skb(skb);
return -ETIMEDOUT; return -ETIMEDOUT;
} }
...@@ -284,6 +286,7 @@ int htc_connect_service(struct htc_target *target, ...@@ -284,6 +286,7 @@ int htc_connect_service(struct htc_target *target,
if (!time_left) { if (!time_left) {
dev_err(target->dev, "Service connection timeout for: %d\n", dev_err(target->dev, "Service connection timeout for: %d\n",
service_connreq->service_id); service_connreq->service_id);
kfree_skb(skb);
return -ETIMEDOUT; return -ETIMEDOUT;
} }
......
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