Received: by 2002:a05:7412:a9a8:b0:f9:92ae:e617 with SMTP id o40csp111490rdh; Wed, 20 Dec 2023 18:14:29 -0800 (PST) X-Google-Smtp-Source: AGHT+IHZ9Nv4wA5/p6f6X41qcHR2K+AmtKMG3n9nYWiyCUF3SZch1arXI7DjQP9nxUMT5M0rl8qh X-Received: by 2002:a05:6214:1c84:b0:67a:a721:d77a with SMTP id ib4-20020a0562141c8400b0067aa721d77amr24023360qvb.96.1703124869610; Wed, 20 Dec 2023 18:14:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1703124869; cv=none; d=google.com; s=arc-20160816; b=MyNQ62h+zd0wJJizmLefdGi4g7c+GOxGaQiwuGPqjS6Jgy9JtVyt5WRGG/L95riAER Uhu/FDkou8nKVjvEhFIO2ZIAQp7pfKcdTMZvOPsw2jiZW920Ncu0alBeZhLsjjjv39iK RfRWQCPwUMDt3h0O898BeUGoroYeG+EduShf2G81XZaEJknofjkQ6LHyVYKU5UjvGX4n xxOc0o6gF/SOZenRWmhay1ZlcO8tsGB4KS8wuiePkjtauqQyTElV/6oY0k1iMkmdTUZe WJ+sI6NkUk2xgSq1S5zL9O17LTis5fuCdFnRbt6bNPxFkP12a0H6QLWvH6FkhCyCNaKZ /21w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=WL++AB9fEIg1cmTcH4bF69I0i+DU0llPfZn2l0Zd/Hg=; fh=SA/uMuWPRRhJUxl9QRLl1yq4eJg4Td6P0h86UYgdsTQ=; b=D80hAnNsQpbGme5VnZYtXgHvb00tB5lPYki34/7VfwbFiER6FlH7hWuvg6GFmS41w5 Ozc5mah6LtwbiVSb0U66PkOswzFWadouFd3UTDR3NSTHQkN91gcgVRsTLtg4DTkcphLj X73tXuXhgQCFH5LoCuSDAj0C5RCjxlZSdUfDbxVAROIksEJNYIMTrKNQY1aHdzukxt9C 0W3/g+0ISTNuoABXLslbxrt1k0mix4uGeOpsejb0dNQ8kWffWfJIZQHNTQ/JY13OnMo3 OtFmWW3JYQLzYGuFMxC9qOpZrvq2+rwlscAnhP/wvM7gjpKWkF09iFjPgKg8ZsQ6lvt0 yB9A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=CJdJxtyl; spf=pass (google.com: domain of linux-kernel+bounces-7746-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-7746-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id w5-20020a0c8e45000000b0067f351d0308si1071843qvb.245.2023.12.20.18.14.29 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Dec 2023 18:14:29 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-7746-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=CJdJxtyl; spf=pass (google.com: domain of linux-kernel+bounces-7746-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-7746-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 4D1C61C23812 for ; Thu, 21 Dec 2023 02:14:29 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 5AF4F23A5; Thu, 21 Dec 2023 02:14:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="CJdJxtyl" X-Original-To: linux-kernel@vger.kernel.org Received: from mail-pl1-f195.google.com (mail-pl1-f195.google.com [209.85.214.195]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6709E5239; Thu, 21 Dec 2023 02:14:18 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-pl1-f195.google.com with SMTP id d9443c01a7336-1d03f03cda9so1025585ad.0; Wed, 20 Dec 2023 18:14:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1703124858; x=1703729658; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=WL++AB9fEIg1cmTcH4bF69I0i+DU0llPfZn2l0Zd/Hg=; b=CJdJxtylFdG3wbewoQG+3LqW9frrHZE0w94JMaNb70KbkwKSVXV4v5rVLk44p4GtB2 W2+7IfjxobIERVDzFOGOUojArLxwjZ67OtssYJzpg/KXPSsWakGsO7dFrOXrFn8FU7n4 Nkrt4cgwBpQRh4RLxjJM9dQrOsRyOUPQRvxAkHzHWeuzFkNVW5MghjaPwzTvztWF7WPv yS0+FDwqfY7Pqv+2zPpFBYYX+fgKPUyYbPzDdr+hQZKow+6rlJ1Z6uVOTCKzC0u8CMDA n5DDBGXru1MUykM0Ugt8bGPLgt7jMpExhKFJCjOTD6v6V4N2AWdm0I57dD6fitxkHjd9 kF8A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1703124858; x=1703729658; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=WL++AB9fEIg1cmTcH4bF69I0i+DU0llPfZn2l0Zd/Hg=; b=IWjhl1gDSTBBSxvrPV/KNgNLCalzUQrOhiwu4YbIOAhLt53Cwn0pKSYcVSQi+iI/tD /qvuVct+1jnWE9v57baJWypYkGAdZaWKdiXKZSR/+8v4a9aN5F5cZB/RD05y27GQ7m/T SouHfj73zN9RPLjsa+SNSUCLlUbADfEUTSfABTbYXVYOQEyXpcSWpB4tm/LjdDgIKwYw 420YGjZn9aPmisFGcJ88B8VSaS8tNTkf+3R4ekt6uMgbRg0rpTs8/vXc3ReqIfg89xN0 LJTQTn9KDOdkwfQfO7f9VWr3BiAUIh7NTBbIya6k0mdgaRWA9kJQTyl2ZuFKIfNub/u0 fZoQ== X-Gm-Message-State: AOJu0YzNFXi7XX1WQ2MPDzu/D1WNl8/7ukUysPUP/KzKWK2SX73QkVLB rZH/Qjfjbk5E4g03XoUf1xE= X-Received: by 2002:a17:902:d2cb:b0:1d3:99c9:5454 with SMTP id n11-20020a170902d2cb00b001d399c95454mr17688921plc.4.1703124857671; Wed, 20 Dec 2023 18:14:17 -0800 (PST) Received: from [127.0.0.1] (061239074230.ctinets.com. [61.239.74.230]) by smtp.gmail.com with ESMTPSA id t9-20020a170902bc4900b001d3aafd228dsm397249plz.75.2023.12.20.18.14.13 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 20 Dec 2023 18:14:17 -0800 (PST) Message-ID: Date: Thu, 21 Dec 2023 10:14:09 +0800 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH] net: sched: em_text: fix possible memory leak in em_text_destroy() To: Jamal Hadi Salim Cc: xiyou.wangcong@gmail.com, jiri@resnulli.us, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, tgraf@suug.ch, netdev@vger.kernel.org, linux-kernel@vger.kernel.org References: <20231220030838.11751-1-hbh25y@gmail.com> Content-Language: en-US From: Hangyu Hua In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 21/12/2023 00:05, Jamal Hadi Salim wrote: > On Wed, Dec 20, 2023 at 6:55 AM Jamal Hadi Salim wrote: >> >> Hi Hangyu, >> While the fix looks correct - can you please describe how you came >> across this issue? Was it a tool or by inspection? Do you have a text >> case that triggered something etc, etc. I discovered this accidentally when I used gdb to debug a program that uses em_text. And I think putting the code in the commit log will will make it too bulky. >> >> On Tue, Dec 19, 2023 at 10:09 PM Hangyu Hua wrote: >>> >>> m->data needs to be freed when em_text_destroy is called. >>> >>> Fixes: d675c989ed2d ("[PKT_SCHED]: Packet classification based on textsearch (ematch)") >>> Signed-off-by: Hangyu Hua >>> --- >>> net/sched/em_text.c | 4 +++- >>> 1 file changed, 3 insertions(+), 1 deletion(-) >>> >>> diff --git a/net/sched/em_text.c b/net/sched/em_text.c >>> index 6f3c1fb2fb44..b9d5d4dca2c9 100644 >>> --- a/net/sched/em_text.c >>> +++ b/net/sched/em_text.c >>> @@ -97,8 +97,10 @@ static int em_text_change(struct net *net, void *data, int len, >>> >>> static void em_text_destroy(struct tcf_ematch *m) >>> { >>> - if (EM_TEXT_PRIV(m) && EM_TEXT_PRIV(m)->config) >>> + if (EM_TEXT_PRIV(m) && EM_TEXT_PRIV(m)->config) { >>> textsearch_destroy(EM_TEXT_PRIV(m)->config); >>> + kfree(m->data); >>> + } >>> } >>> >> > > the bot just complained about needing a cast, use this: > struct text_match * I see. I will send a v2 later. Thanks, Hangyu > > cheers, > jamal >> Acked-by: Jamal Hadi Salim >> >> cheers, >> jamal >> >>> static int em_text_dump(struct sk_buff *skb, struct tcf_ematch *m) >>> -- >>> 2.34.1 >>>