Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5100707imu; Tue, 8 Jan 2019 11:30:33 -0800 (PST) X-Google-Smtp-Source: ALg8bN5YBJsiis2CtWuvBrDw6bxFUQ4zCZkNac2YLtuy6OMlwKbckCyuOexVU+xboSjsOP5he3sX X-Received: by 2002:a62:6204:: with SMTP id w4mr3018764pfb.5.1546975833724; Tue, 08 Jan 2019 11:30:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546975833; cv=none; d=google.com; s=arc-20160816; b=l2EKx89prhZ/SvBljTgWTPuTKlFVXvY763/kAt6Y318/DEuJ9YFN7xwhXyYIR5UfDF ZDKevf/i5RHlPAS76ij2hRQhiRwvIU+3r6aRxDQdTqOKIJT80Ku/WqU3K13FLrs/DqeT 02BsGG7Zk6qqqXY3WR1+UTB7VR1AxO6a35qzbmUrNx4ctX+77l3LAoEJv346bJ22Po9s Eo3GT6xYbzkFSz6BMNAbbvUax4qSsf8E8YJrjIFpQxNN5MCQPAhBM0/HAHBbattAc4/G uU+t4EniWpwJz35pT7YsfOwn28ifMTieiqfsNN/q6+GqlZlnY7pulBlHKDVjH7pjun72 eSXg== 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 :dkim-signature; bh=tZML5QdZKISCjeVJthFLqHyvqfcsl6GWL5qY12i1mlI=; b=hgIneLigy7SKSGq2fwVIGOjqcsnNTZwrtLMySieCoJtel507GZFrtJR9o2accEzl82 31zZQ8jPcYqc+DkGf1y5xCVBVyEWEFNCMs4eeBr6EIvwy0E+n8vIKAO4uoaKxMddbShO 9kp/9udjylDToZPf2C3NXzHROqWgIdJoBFk2vU7fJKqUO8G35saop9KiPGqh4q53WY38 TBtWFo35V+DbEffwRDTdrqp+bBySR3l6jAZswS4ccY7TH+XJgzG8IcR5GVQOTNrO1SSq iLAy7Esf8z1MMQkA3nCCUGc1ns+uZAMIpY31L1JIiu9oS/oFxLE4WbQVcztaNfHh105U pjWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="V5/Y0s/Z"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g3si68005678pgi.443.2019.01.08.11.30.18; Tue, 08 Jan 2019 11:30:33 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="V5/Y0s/Z"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730084AbfAHT2f (ORCPT + 99 others); Tue, 8 Jan 2019 14:28:35 -0500 Received: from mail.kernel.org ([198.145.29.99]:35528 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730040AbfAHT21 (ORCPT ); Tue, 8 Jan 2019 14:28:27 -0500 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 766DE2176F; Tue, 8 Jan 2019 19:28:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1546975707; bh=e8IlupckPtBUD+8a3YHBDl0qfMRnd3VTioKWkHIT/ME=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=V5/Y0s/ZxGrTU0TSDkkZRcjBixf1/dUpYe7vyMZGgDRb3a3tixIdYeh0rOrNkI4+5 y/OffcEYEYu3j8pR4ZF4JW7Aqrs20CTWdXivGHf1n780jnYJopDIJTQlYxJpGHbrku 881kWoA/Yb4HlZ0gX3pDaaJMwypAEuXvQuleg/aE= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Masahiro Yamada , Sasha Levin , linux-kbuild@vger.kernel.org Subject: [PATCH AUTOSEL 4.20 068/117] kconfig: fix memory leak when EOF is encountered in quotation Date: Tue, 8 Jan 2019 14:25:36 -0500 Message-Id: <20190108192628.121270-68-sashal@kernel.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20190108192628.121270-1-sashal@kernel.org> References: <20190108192628.121270-1-sashal@kernel.org> MIME-Version: 1.0 X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Masahiro Yamada [ Upstream commit fbac5977d81cb2b2b7e37b11c459055d9585273c ] An unterminated string literal followed by new line is passed to the parser (with "multi-line strings not supported" warning shown), then handled properly there. On the other hand, an unterminated string literal at end of file is never passed to the parser, then results in memory leak. [Test Code] ----------(Kconfig begin)---------- source "Kconfig.inc" config A bool "a" -----------(Kconfig end)----------- --------(Kconfig.inc begin)-------- config B bool "b\No new line at end of file ---------(Kconfig.inc end)--------- [Summary from Valgrind] Before the fix: LEAK SUMMARY: definitely lost: 16 bytes in 1 blocks ... After the fix: LEAK SUMMARY: definitely lost: 0 bytes in 0 blocks ... Eliminate the memory leak path by handling this case. Of course, such a Kconfig file is wrong already, so I will add an error message later. Signed-off-by: Masahiro Yamada Signed-off-by: Sasha Levin --- scripts/kconfig/zconf.l | 2 ++ 1 file changed, 2 insertions(+) diff --git a/scripts/kconfig/zconf.l b/scripts/kconfig/zconf.l index eeac64ccc730..c2f577d71964 100644 --- a/scripts/kconfig/zconf.l +++ b/scripts/kconfig/zconf.l @@ -221,6 +221,8 @@ n [A-Za-z0-9_-] } <> { BEGIN(INITIAL); + yylval.string = text; + return T_WORD_QUOTE; } } -- 2.19.1