diff options
author | 2024-08-22 18:48:53 +0200 | |
---|---|---|
committer | 2024-10-05 22:12:48 -0500 | |
commit | cd3a3e60ebfe6f62ccf9d2164f6455e0b1ae1884 (patch) | |
tree | ba895667f5aa43389d48243838ac58f5815c4907 | |
parent | soc: qcom: pbs: simplify locking with guard() (diff) | |
download | wireguard-linux-cd3a3e60ebfe6f62ccf9d2164f6455e0b1ae1884.tar.xz wireguard-linux-cd3a3e60ebfe6f62ccf9d2164f6455e0b1ae1884.zip |
soc: qcom: smem_state: simplify locking with guard()
Simplify error handling (less gotos) over locks with guard().
Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Link: https://lore.kernel.org/r/20240822164853.231087-4-krzysztof.kozlowski@linaro.org
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
Diffstat (limited to '')
-rw-r--r-- | drivers/soc/qcom/smem_state.c | 12 |
1 files changed, 4 insertions, 8 deletions
diff --git a/drivers/soc/qcom/smem_state.c b/drivers/soc/qcom/smem_state.c index e848cc9a3cf8..d9bfac6c54fb 100644 --- a/drivers/soc/qcom/smem_state.c +++ b/drivers/soc/qcom/smem_state.c @@ -3,6 +3,7 @@ * Copyright (c) 2015, Sony Mobile Communications Inc. * Copyright (c) 2012-2013, The Linux Foundation. All rights reserved. */ +#include <linux/cleanup.h> #include <linux/device.h> #include <linux/list.h> #include <linux/module.h> @@ -60,20 +61,15 @@ static struct qcom_smem_state *of_node_to_state(struct device_node *np) { struct qcom_smem_state *state; - mutex_lock(&list_lock); + guard(mutex)(&list_lock); list_for_each_entry(state, &smem_states, list) { if (state->of_node == np) { kref_get(&state->refcount); - goto unlock; + return state; } } - state = ERR_PTR(-EPROBE_DEFER); - -unlock: - mutex_unlock(&list_lock); - - return state; + return ERR_PTR(-EPROBE_DEFER); } /** |