Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp4130707ybg; Fri, 25 Oct 2019 13:49:11 -0700 (PDT) X-Google-Smtp-Source: APXvYqzcqa6acAYzdnwWWNXKuGFnhQ9jrSxwCy1C7K9mmZrzJTdcJlsvy8F5t6hwm2j6t10gAlPM X-Received: by 2002:a17:906:6898:: with SMTP id n24mr5446610ejr.263.1572036551826; Fri, 25 Oct 2019 13:49:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572036551; cv=none; d=google.com; s=arc-20160816; b=Hob4yBHPDWf843IuJUNeJhvXAIiv5xlGmWAl9/UcFdZV0ew1TcHRbGj4VyLPqacoFF /G2s42504a+kv7F+rphIvpAaeJ7A+lqitNVRNuIN/KWl/D4vH8JV3BV7MW9BQSBm5vAN Lq5vzXE5Qu0EYbgswjdTlA3+gNrKi/+QJfMvz/hCTXgSZmFfQZz0wtWlZ8uiW85b2IyM IwfSnhFLkLSNO2uqbngqgm/mpGhwSlYSczALXcHPPbwmYihlXmh6/WvYgWSWyXPR4Dzf 5LIAF4I8q8xYWpyKonCo02la3cdtO+aOFVyxSi9R3pgby7wMslHxA+Z51GYvRX1RDSdc hkBA== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature:dkim-filter; bh=7hGCl+P0baIDKMMzceGB2joTvpQFYOW1rsl65AwaESg=; b=FJp2YPGK6xRCAhD4gsE96TL2N7OPaUIgAV47r4LtnbnuC9uCakV1oeAf4NlliHD8Ky S48EQvqyf06mGT2WTy1VHQPYnvMsX+E8s9jSRYbCTLo/XjnHjnYU7VsInQfmB7ZLUtWw mVy/sII8qAvaVOoT8El4L2JsnN0Z5qk3euhK/sQmM3utoFnxJJx+2coHEo3Z1csd7UvQ 6P7p89aTZOtL+xZmaFd3JTN6gK4rNQ1AmrGUWLGhLN4TB2gaD1CNqkrtOdnTHr3UR8Jv DUggE6D8m4AX4X9FhVQNmLg1yT3ynMPuA0Sz5ZIxKYM4Nj4skSEfegQ/d8hEmkub0Div 9NxA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=czTwe7iE; 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=linux.microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r4si2008226ejz.77.2019.10.25.13.48.48; Fri, 25 Oct 2019 13:49:11 -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=pass header.i=@linux.microsoft.com header.s=default header.b=czTwe7iE; 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=linux.microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731248AbfJYSCr (ORCPT + 99 others); Fri, 25 Oct 2019 14:02:47 -0400 Received: from linux.microsoft.com ([13.77.154.182]:55672 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731197AbfJYSCr (ORCPT ); Fri, 25 Oct 2019 14:02:47 -0400 Received: from [10.137.112.111] (unknown [131.107.147.111]) by linux.microsoft.com (Postfix) with ESMTPSA id 35AE72010AC6; Fri, 25 Oct 2019 11:02:46 -0700 (PDT) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com 35AE72010AC6 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1572026566; bh=7hGCl+P0baIDKMMzceGB2joTvpQFYOW1rsl65AwaESg=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=czTwe7iEXiYO6JkheRJPPNMnL5Cbg61vTN7/+dfgsvKoyQ7DzcAkTVmgEHaD44Y/h jbDjF2ZBpVUKnbsyoUyslQapQJhi9p/QuR0SQXCtdREc4TW2b9zURqy/JaFZ00xmBr UuMXyYCz38KvLS+eL4dyR4/GY0NDH+IiFMK2xe2E= Subject: Re: [PATCH v9 2/8] powerpc/ima: add support to initialize ima policy rules To: Nayna Jain , Nayna Jain , linuxppc-dev@ozlabs.org, linux-efi@vger.kernel.org, linux-integrity@vger.kernel.org Cc: linux-kernel@vger.kernel.org, Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , Ard Biesheuvel , Jeremy Kerr , Matthew Garret , Mimi Zohar , Greg Kroah-Hartman , Claudio Carvalho , George Wilson , Elaine Palmer , Eric Ricther , Oliver O'Halloran , Prakhar Srivastava References: <20191024034717.70552-1-nayna@linux.ibm.com> <20191024034717.70552-3-nayna@linux.ibm.com> <27dbe08e-5473-4dd0-d2ad-2df591e23f5e@linux.vnet.ibm.com> From: Lakshmi Ramasubramanian Message-ID: <482b2f08-f810-6ed0-4b32-0d5e64246ece@linux.microsoft.com> Date: Fri, 25 Oct 2019 11:03:03 -0700 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.2.0 MIME-Version: 1.0 In-Reply-To: <27dbe08e-5473-4dd0-d2ad-2df591e23f5e@linux.vnet.ibm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/25/2019 10:02 AM, Nayna Jain wrote: >> Is there any way to not use conditional compilation in >> the above array definition? Maybe define different functions to get >> "secure_rules" for when CONFIG_MODULE_SIG_FORCE is defined and when >> it is not defined. > > How will you decide which function to be called ? Define the array in the C file: const char *const secure_rules_kernel_check[] = { "appraise func=KEXEC_KERNEL_CHECK appraise_type=imasig|modsig", NULL }; const char *const secure_rules_kernel_module_check[] = { "appraise func=KEXEC_KERNEL_CHECK appraise_type=imasig|modsig", "appraise func=MODULE_CHECK appraise_type=imasig|modsig", NULL }; And, in the header file : extern const char *const secure_rules_kernel_check; extern const char *const secure_rules_kernel_module_check; #ifdef CONFIG_MODULE_SIG_FORCE const char *secure_rules() { return secure_rules_kernel_check; } #else const char *secure_rules() { return secure_rules_kernel_module_check;} #endif // #ifdef CONFIG_MODULE_SIG_FORCE If you want to avoid duplication, secure_rules_kernel_check and secure_rules_kernel_module_check could be defined in separate C files and conditionally compiled (in Makefile). I was just trying to suggest the guidelines given in "Section 21) Conditional Compilation" in coding-style.rst. It says: Whenever possible don't use preprocessor conditionals (#ifdef, #if) in .c files;... Feel free to do what you think is appropriate. thanks, -lakshmi