Commit b066a2c4 authored by Krzysztof Kozlowski's avatar Krzysztof Kozlowski Committed by Bjorn Andersson

soc: qcom: wcnss: simplify with cleanup.h

Allocate the memory with scoped/cleanup.h to reduce error handling (less
error paths) and make the code a bit simpler.
Signed-off-by: default avatarKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Link: https://lore.kernel.org/r/20240703-thermal-const-v1-5-6e59e139c65d@linaro.orgSigned-off-by: default avatarBjorn Andersson <andersson@kernel.org>
parent 0ed06fcc
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
* Copyright (c) 2016, Linaro Ltd. * Copyright (c) 2016, Linaro Ltd.
* Copyright (c) 2015, Sony Mobile Communications Inc. * Copyright (c) 2015, Sony Mobile Communications Inc.
*/ */
#include <linux/cleanup.h>
#include <linux/firmware.h> #include <linux/firmware.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/slab.h> #include <linux/slab.h>
...@@ -198,7 +199,6 @@ static int wcnss_request_version(struct wcnss_ctrl *wcnss) ...@@ -198,7 +199,6 @@ static int wcnss_request_version(struct wcnss_ctrl *wcnss)
*/ */
static int wcnss_download_nv(struct wcnss_ctrl *wcnss, bool *expect_cbc) static int wcnss_download_nv(struct wcnss_ctrl *wcnss, bool *expect_cbc)
{ {
struct wcnss_download_nv_req *req;
const struct firmware *fw; const struct firmware *fw;
struct device *dev = wcnss->dev; struct device *dev = wcnss->dev;
const char *nvbin = NVBIN_FILE; const char *nvbin = NVBIN_FILE;
...@@ -206,18 +206,19 @@ static int wcnss_download_nv(struct wcnss_ctrl *wcnss, bool *expect_cbc) ...@@ -206,18 +206,19 @@ static int wcnss_download_nv(struct wcnss_ctrl *wcnss, bool *expect_cbc)
ssize_t left; ssize_t left;
int ret; int ret;
req = kzalloc(sizeof(*req) + NV_FRAGMENT_SIZE, GFP_KERNEL); struct wcnss_download_nv_req *req __free(kfree) = kzalloc(sizeof(*req) + NV_FRAGMENT_SIZE,
GFP_KERNEL);
if (!req) if (!req)
return -ENOMEM; return -ENOMEM;
ret = of_property_read_string(dev->of_node, "firmware-name", &nvbin); ret = of_property_read_string(dev->of_node, "firmware-name", &nvbin);
if (ret < 0 && ret != -EINVAL) if (ret < 0 && ret != -EINVAL)
goto free_req; return ret;
ret = request_firmware(&fw, nvbin, dev); ret = request_firmware(&fw, nvbin, dev);
if (ret < 0) { if (ret < 0) {
dev_err(dev, "Failed to load nv file %s: %d\n", nvbin, ret); dev_err(dev, "Failed to load nv file %s: %d\n", nvbin, ret);
goto free_req; return ret;
} }
data = fw->data; data = fw->data;
...@@ -263,8 +264,6 @@ static int wcnss_download_nv(struct wcnss_ctrl *wcnss, bool *expect_cbc) ...@@ -263,8 +264,6 @@ static int wcnss_download_nv(struct wcnss_ctrl *wcnss, bool *expect_cbc)
release_fw: release_fw:
release_firmware(fw); release_firmware(fw);
free_req:
kfree(req);
return ret; return ret;
} }
......
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