aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulia Lawall <Julia.Lawall@lip6.fr>2015-10-12 16:43:15 -0400
committerAndy Gross <agross@codeaurora.org>2015-10-14 15:51:22 -0400
commit6083096d961f3cf754c4da282179053f7b85ac16 (patch)
tree154cb5ff00930b58a5cd0f3fdbad45c3e802be93
parent33e38b4f1c54f9c2d3b2034c18ef937a3c09bc66 (diff)
soc: qcom: smd: delete unneeded of_node_put
Device node iterators perform an of_node_put on each iteration, so putting an of_node_put before a continue results in a double put. A simplified version of the semantic match that finds this problem is as follows (http://coccinelle.lip6.fr): // <smpl> @@ expression root,e; local idexpression child; iterator i; @@ i(..., child, ...) { ... when != of_node_get(child) * of_node_put(child); ... * continue; } // </smpl> Signed-off-by: Julia Lawall <Julia.Lawall@lip6.fr> Signed-off-by: Andy Gross <agross@codeaurora.org>
-rw-r--r--drivers/soc/qcom/smd.c4
1 files changed, 1 insertions, 3 deletions
diff --git a/drivers/soc/qcom/smd.c b/drivers/soc/qcom/smd.c
index ef5fed6ceb21..86b598cff91a 100644
--- a/drivers/soc/qcom/smd.c
+++ b/drivers/soc/qcom/smd.c
@@ -921,10 +921,8 @@ static struct device_node *qcom_smd_match_channel(struct device_node *edge_node,
921 for_each_available_child_of_node(edge_node, child) { 921 for_each_available_child_of_node(edge_node, child) {
922 key = "qcom,smd-channels"; 922 key = "qcom,smd-channels";
923 ret = of_property_read_string(child, key, &name); 923 ret = of_property_read_string(child, key, &name);
924 if (ret) { 924 if (ret)
925 of_node_put(child);
926 continue; 925 continue;
927 }
928 926
929 if (strcmp(name, channel) == 0) 927 if (strcmp(name, channel) == 0)
930 return child; 928 return child;