Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2214729yba; Fri, 17 May 2019 12:37:14 -0700 (PDT) X-Google-Smtp-Source: APXvYqxCMfhFXoS6R64QS6usgGDPmxUXR0v40Q5h/ci4txrhl0m1yqgwi2DgBX3Y4BHKOLXOgBYv X-Received: by 2002:a17:902:aa45:: with SMTP id c5mr57869162plr.144.1558121834088; Fri, 17 May 2019 12:37:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558121834; cv=none; d=google.com; s=arc-20160816; b=lwjkfrVLNOjpO4KT3lS7GL9UeLnUiMsYd9/LzPBEXlZV1ntWFYpDiIrGscMQEuDYLN 6RpmMPutg1xFQXMtenAnTKnvS4HUfQe14lU9op7piElY/OWpk6ZVof4BLcwcg11qOuPA oAj2s0HPWfvUqFwtP8GSjwB3h3ydgJEEGeLSFgVuQLCZV1+rEa7AxgeSIvSxj/8ixbRk Ey7TmN7U8qWVNQCkBmVwmt3886wkOGW0blCgEAjZNp6KNf9+GYynG0zcJIb3O/JGFkjC JVJmt4VskDSlUW5ENKShyxcMysb1dGVjAAH+bsUMzJzJwsWOMyZHeITNQBa6xBDZRJQH a+hg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=1FGwj5dK1hN5fjx+AAccEqcoOuJxxLft10BcR5bfbWs=; b=DXVmj5Qa/T2yPcAA06FOwg1MlUnY/LB0OIjk1MCE9NgMFlAED02z/H9JUOdpLron9v 5TSWDDWzp3Ae5DxDmKOKE9G8NLWEKUw3faxt6F4sZz2N7I023tOnssDMEJsdifnUqmqP iIIQl3EUjsXue7X/eHYzQMTnYmJyGDxxaU71Fu7ECNFqQK/xOkHUHrhYdDnvntUy5b1I SzAc+UQsQdRhQ2ejav48n/ysQiIxzeJfKNFhb2zWjfbOBqgOpvw1d41PjcwhxrSN2PIa 7bq9ha6bBCoQ2LfrI9cUAstuO1f4rhz0Zx/k0Jrc4PAhgEMQChLBuxWKZqBkcRWE6T/6 ghYQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f88si8819381plf.397.2019.05.17.12.36.59; Fri, 17 May 2019 12:37:14 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729036AbfEQTad (ORCPT + 99 others); Fri, 17 May 2019 15:30:33 -0400 Received: from nbd.name ([46.4.11.11]:37378 "EHLO nbd.name" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728958AbfEQTa3 (ORCPT ); Fri, 17 May 2019 15:30:29 -0400 Received: from p548c8c9f.dip0.t-ipconnect.de ([84.140.140.159] helo=bertha.fritz.box) by ds12 with esmtpa (Exim 4.89) (envelope-from ) id 1hRiYl-0006cc-Km; Fri, 17 May 2019 21:30:27 +0200 From: John Crispin To: Johannes Berg Cc: linux-wireless@vger.kernel.org, John Crispin Subject: [PATCH 3/7] iw: fix memory leak inside handle_cac Date: Fri, 17 May 2019 21:29:52 +0200 Message-Id: <20190517192956.18372-4-john@phrozen.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190517192956.18372-1-john@phrozen.org> References: <20190517192956.18372-1-john@phrozen.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org Signed-off-by: John Crispin --- phy.c | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/phy.c b/phy.c index 77df7a7..a4425ea 100644 --- a/phy.c +++ b/phy.c @@ -328,12 +328,15 @@ static int handle_cac(struct nl80211_state *state, } else if (strcmp(argv[2], "freq") == 0) { err = parse_freqchan(&chandef, false, argc - 3, argv + 3, NULL); } else { - return 1; + err = 1; + goto err_out; } cac_trigger_argv = calloc(argc + 1, sizeof(char*)); - if (!cac_trigger_argv) - return -ENOMEM; + if (!cac_trigger_argv) { + err = -ENOMEM; + goto err_out; + } cac_trigger_argv[0] = argv[0]; cac_trigger_argv[1] = "cac"; @@ -341,9 +344,8 @@ static int handle_cac(struct nl80211_state *state, memcpy(&cac_trigger_argv[3], &argv[2], (argc - 2) * sizeof(char*)); err = handle_cmd(state, id, argc + 1, cac_trigger_argv); - free(cac_trigger_argv); if (err) - return err; + goto err_out; cac_event.ret = 1; cac_event.freq = chandef.control_freq; @@ -357,7 +359,13 @@ static int handle_cac(struct nl80211_state *state, while (cac_event.ret > 0) nl_recvmsgs(state->nl_sock, radar_cb); - return 0; + err = 0; +err_out: + if (radar_cb) + nl_cb_put(radar_cb); + if (cac_trigger_argv) + free(cac_trigger_argv); + return err; } TOPLEVEL(cac, "channel [NOHT|HT20|HT40+|HT40-|5MHz|10MHz|80MHz]\n" "freq [NOHT|HT20|HT40+|HT40-|5MHz|10MHz|80MHz]\n" -- 2.20.1