Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp2918016imm; Wed, 16 May 2018 23:40:30 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoNs7TomTKgJENYA+ln1A0R3wNIgXx5FkRfrGpP4HYtYTdk9mNpsjSrA7QZdvlW93ivoesU X-Received: by 2002:a17:902:189:: with SMTP id b9-v6mr4095524plb.204.1526539230460; Wed, 16 May 2018 23:40:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526539230; cv=none; d=google.com; s=arc-20160816; b=FjFWEAvJdGAGq3XAFn2Lvprl/EUlGyBrJ6jhpBGcgr1sUqjV/Of1VqcXb7LalDslNm VrdTwxDWNKx+f7qLF/BCOH+fYbkNW45uFRACj8SGSh+mxawS+6qUsi75iNCuOGqw4aJY RBuYyqRp/mlqqOZv5Zo0yzIl2iX4nT/QgAptxwsfycb5jmkW6+QZlRvmUR5mK/p0Fdf/ 6zpG4B5/8TbzjRkqiluaIiVl1q0IuGtrFLeOD9h/cxoYRUj8FlcXSqShkWay6css32ja 8bW78Fyp1akjaSfWNAQTD5D4psCeN2U801mzzcAhDTMICiMJ/N2iP3+wG5OyMbVtmDS4 Qgww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature:dkim-signature :arc-authentication-results; bh=hAE3SdUdYY+eUnaXT4LOjNhTXtbz4br8lvAe+BgS+2Q=; b=P2pF+InfkLuBaR/+NXXD2L8Dyrk/OZCXn23LOZXwRhCXXFDvoKLo+cnO7TzbypTtro hGar40vvaVQ/moJXA5q+IfvfjE1HMoDbxtd55FbhWYEihQ2D4pK/+U0kD6e/VXfZGngE PkzGv4mRDW045dOZ2YccHFX//xhrcoku70rMVDeBZs32F3zLsoYWskc2HnrypODgXtWA wDjkO9IB6ZJX3zv7plBLAC9jUfbBaJmILK6F0msIc3DxoK0GXlXdUh59SMDvRknfCQ8Z VXKAI914oqzx2zpXxP2AT1kAdCVvJh5mXkLiGTNEswOngZrHkF+n5q+tjyoInzxLPxa0 ztCg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@google.com header.s=20161025 header.b=uiEuUELs; dkim=fail header.i=@chromium.org header.s=google header.b=hPx1g3KK; 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=fail (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j7-v6si4698459pfh.3.2018.05.16.23.40.16; Wed, 16 May 2018 23:40:30 -0700 (PDT) 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=fail header.i=@google.com header.s=20161025 header.b=uiEuUELs; dkim=fail header.i=@chromium.org header.s=google header.b=hPx1g3KK; 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=fail (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752326AbeEQGjb (ORCPT + 99 others); Thu, 17 May 2018 02:39:31 -0400 Received: from mail-ua0-f194.google.com ([209.85.217.194]:43671 "EHLO mail-ua0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751457AbeEQGj3 (ORCPT ); Thu, 17 May 2018 02:39:29 -0400 Received: by mail-ua0-f194.google.com with SMTP id d4-v6so2210920ual.10 for ; Wed, 16 May 2018 23:39:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=hAE3SdUdYY+eUnaXT4LOjNhTXtbz4br8lvAe+BgS+2Q=; b=uiEuUELs6AACQSGIAUOfPbkSfttkF+inuTYQSb6MeUNdTSKhk/LOkdeC4O0e+sEJ++ 5omZ1viJITWaDAWxY7CjF5sfNcaNrlZL/p1gHIAiBHBerS6X+ngwCC0maZsjm9NF0Vn6 gIZ9f3G7VRNnZ4o0LKQofMwJVkq1NWGsXAi1n3N9XXxyuBxSA0ihwBHkuvhsXx6kVRL2 CM/zpS/KSK2/cyPjqBjLYISiZEf0zkhJ+vo+1XMTBCxD0afiw8a5Byr5z+wtG01A/3rE zYCDLL4aFv25N8PWvDFz3Qmbi+kgwUH7N4oB21kUxBomrW2l3eCQhPURNVJXzKtCKD/t O+0g== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=hAE3SdUdYY+eUnaXT4LOjNhTXtbz4br8lvAe+BgS+2Q=; b=hPx1g3KKIruRyXgSfw5Hm7i2d7yrqh1Z2jEn1iba0zF50KbcqIFAzE+CHlG61Ftjgw sekT4WLMevB2JLEj/IXI+lgUXYssh9vTyfd9Y21g+8tr//FGuO2kas100YTb6dU6sBkF mO5kU0FfTh0Uh6IYf2i8rnLlJqTgDuctf/kUU= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:sender:in-reply-to:references:from :date:message-id:subject:to:cc; bh=hAE3SdUdYY+eUnaXT4LOjNhTXtbz4br8lvAe+BgS+2Q=; b=VuclOwcDU0Ooay4fqOmy7gC423IaxLOB0rMYW1aK8Z1PXk7Vmc/ZstuLWoCXQV2huN rU+XyHo4qzyCrbMXI4KG8/6V8gbNxshoWVs8Ln0OhlfQAuZU0JpQv4rVKB6KT3jHWggn 39fXT5BkTKOyRnwT+U+K5zBsyvHCAY7PK7VB8Gd6awZSop4BcX7hM8Og+sIjTmEPjTmj UXcWBq185y3YcyFKhy9bAsbLPlE7F3gwNVmUTJS03cyEN6OgfU907BilmrTbjnB0gaF1 hNaKLVybRvk8CZnvhwGvD9u6saorY/VesKMnvBBLECMEveLO0UpQiG8FKu7rpuRYJCo5 NfUA== X-Gm-Message-State: ALKqPwenDv80v93dED/8aS1+FvDUB1PjEjCTHo1BP9WnNRsDut3ZNV7l dNOtS69lPmPP0pEsf8NOPpLIWNY+NWOedIG1H4Qotw== X-Received: by 2002:a9f:2823:: with SMTP id c32-v6mr3538634uac.193.1526539168728; Wed, 16 May 2018 23:39:28 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a1f:bd1:0:0:0:0:0 with HTTP; Wed, 16 May 2018 23:39:28 -0700 (PDT) In-Reply-To: <1526537830-22606-18-git-send-email-yamada.masahiro@socionext.com> References: <1526537830-22606-1-git-send-email-yamada.masahiro@socionext.com> <1526537830-22606-18-git-send-email-yamada.masahiro@socionext.com> From: Kees Cook Date: Wed, 16 May 2018 23:39:28 -0700 X-Google-Sender-Auth: UeNcHC3aJDmH-0Eew6FAOkUkpYg Message-ID: Subject: Re: [PATCH v4 17/31] kconfig: add 'filename' and 'lineno' built-in variables To: Masahiro Yamada Cc: linux-kbuild , Linus Torvalds , Sam Ravnborg , Ulf Magnusson , "Luis R . Rodriguez" , LKML , Nicholas Piggin , Emese Revfy , X86 ML Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, May 16, 2018 at 11:16 PM, Masahiro Yamada wrote: > The special variables, $(filename) and $(lineno), are expanded to a > file name and its line number being parsed, respectively. > > Suggested-by: Randy Dunlap > Signed-off-by: Masahiro Yamada Reviewed-by: Kees Cook -Kees > --- > > Changes in v4: > - Newly added > > Changes in v3: None > Changes in v2: None > > scripts/kconfig/preprocess.c | 16 ++++++++++++++++ > 1 file changed, 16 insertions(+) > > diff --git a/scripts/kconfig/preprocess.c b/scripts/kconfig/preprocess.c > index 88844a7..c39e30e 100644 > --- a/scripts/kconfig/preprocess.c > +++ b/scripts/kconfig/preprocess.c > @@ -111,6 +111,11 @@ static char *do_error(int argc, char *argv[], int old_argc, char *old_argv[]) > return NULL; > } > > +static char *do_filename(int argc, char *argv[], int old_argc, char *old_argv[]) > +{ > + return xstrdup(current_file->name); > +} > + > static char *do_if(int argc, char *argv[], int old_argc, char *old_argv[]) > { > char *cond, *p, *res; > @@ -144,6 +149,15 @@ static char *do_info(int argc, char *argv[], int old_argc, char *old_argv[]) > return xstrdup(""); > } > > +static char *do_lineno(int argc, char *argv[], int old_argc, char *old_argv[]) > +{ > + char buf[16]; > + > + sprintf(buf, "%d", yylineno); > + > + return xstrdup(buf); > +} > + > static char *do_shell(int argc, char *argv[], int old_argc, char *old_argv[]) > { > FILE *p; > @@ -194,8 +208,10 @@ static char *do_warning(int argc, char *argv[], int old_argc, char *old_argv[]) > static const struct function function_table[] = { > /* Name MIN MAX EXP? Function */ > { "error", 1, 1, true, do_error }, > + { "filename", 0, 0, false, do_filename }, > { "if", 2, 3, false, do_if }, > { "info", 1, 1, true, do_info }, > + { "lineno", 0, 0, false, do_lineno }, > { "shell", 1, 1, true, do_shell }, > { "warning", 1, 1, true, do_warning }, > }; > -- > 2.7.4 > -- Kees Cook Pixel Security