Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp11238798ybl; Fri, 27 Dec 2019 10:06:25 -0800 (PST) X-Google-Smtp-Source: APXvYqwGPHnifosAy2Y4zWbMa0FfF2crh+xi3gcEjwIBFZTYy+qmn+3AiZSPWqrqzHgyc2i7claa X-Received: by 2002:a9d:754a:: with SMTP id b10mr59027481otl.273.1577469984922; Fri, 27 Dec 2019 10:06:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1577469984; cv=none; d=google.com; s=arc-20160816; b=NLflWcABDi/qAOqFM2zs3NkinACG6s4HAX4mPf9YR9RU94ImhG0t4W2ho9xMHWrEgb 90ANqK5d+C0Ap9WB1aaSvf+Kkex1adtv0oKUgz2hf0N3WcmViX+zWL+h8T4vhfAm25Dl Zzd04LF05nomGetv6rm73XBrsDDuDTn5ZyN1MiGBXq9bXHqMBf3F+zujhFG5BgCwLZPz troRvAuXqluWcTGQ9nW/XkGlF6lY6VyyPQR9R5TeJOcbcpDy/XfPiQ0NJBBWliUVxKtZ Rbps8tSi8y6Jhfoq9WWf66zA5RYix9KdFlECqRC4SqjVGy/1/23Rs7WnPCcaXU7s3qTq ZdWw== 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=ZToriIl5QGFjqEnVzjeamNxNqdfJVdo6wpYKvQepsG4=; b=SkX92SX9DSRzx936QpYtsZI0qJZ0aKPsX9SLuVZuvO+uEAW2cT5zl5gdRZyUPbAUgq d/hr1ey2E+7H2/GEnWqwxR3ypxv3md7WvY+UZX1VkRQQtqii+k5ROkGNFKERqgfv8x3O 2+i/f3TYrbAz+O6BnPXVSJJ97tx+QmMGGDU5yB34nZxAN1loWmxq2JNUFc/YSKn9MW+4 0BiC37HK9Q2e+Xa1drLfGe7NWz/nOx1foT1LRM6RiDOQExPMOb81rnp7uw/A3kbgQFmv D3RXwFE/5H7770o7eMxC+rpgIIkENDQwltY4b21AgpWM4Wn8tuKeAJfiH0S8JUjOIByS kvEg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@synopsys.com header.s=mail header.b="ASV7Z7+/"; 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=synopsys.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m25si18237569otn.208.2019.12.27.10.06.12; Fri, 27 Dec 2019 10:06:24 -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=@synopsys.com header.s=mail header.b="ASV7Z7+/"; 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=synopsys.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727662AbfL0SEE (ORCPT + 99 others); Fri, 27 Dec 2019 13:04:04 -0500 Received: from sv2-smtprelay2.synopsys.com ([149.117.73.133]:38874 "EHLO smtprelay-out1.synopsys.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727805AbfL0SEA (ORCPT ); Fri, 27 Dec 2019 13:04:00 -0500 Received: from mailhost.synopsys.com (mdc-mailhost2.synopsys.com [10.225.0.210]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) (No client certificate requested) by smtprelay-out1.synopsys.com (Postfix) with ESMTPS id 209E442CED; Fri, 27 Dec 2019 18:03:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=synopsys.com; s=mail; t=1577469839; bh=Hes0n05dCzlQLemBmu3FmAF+1sPDQGmnFX0t0kYnTls=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ASV7Z7+/bOTCx7iaXWb8kPRRMQDHN2iF8A+EXxt8yQe455/l85/eYsGGdM6y9xq7P Khj+fsn70hej3Cnzc7fpw/KC1sFBrd8hrsMKCsXP3WeUP3wWoo++0hHlrd6Cjaqnci sW1HVG88AC6BhS1g8z2JN71Su/lPbeC+bW++pglfEPS+zlvU3/r2SAtSURIgWBmC9N 8YPRz7rRfqwwNR1PPmX5RW6kJjjAcaVY5pPqSuKSIm2CeevuvxUJFaDYxKVDkXFGGT +21PJnTVCJe58+ALzkZ+8BqkvRl1H8UsjXlUduvSuXZEV6zVjf8rXxxguV2iUAhovV RwLAGsbMvLGEQ== Received: from paltsev-e7480.internal.synopsys.com (unknown [10.121.8.65]) by mailhost.synopsys.com (Postfix) with ESMTP id 6B1CBA0067; Fri, 27 Dec 2019 18:03:56 +0000 (UTC) From: Eugeniy Paltsev To: linux-snps-arc@lists.infradead.org, Vineet Gupta Cc: linux-kernel@vger.kernel.org, Alexey Brodkin , Eugeniy Paltsev Subject: [PATCH 2/5] ARC: add helpers to sanitize config options Date: Fri, 27 Dec 2019 21:03:44 +0300 Message-Id: <20191227180347.3579-3-Eugeniy.Paltsev@synopsys.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20191227180347.3579-1-Eugeniy.Paltsev@synopsys.com> References: <20191227180347.3579-1-Eugeniy.Paltsev@synopsys.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We'll use this macro in coming patches extensively. Signed-off-by: Eugeniy Paltsev --- arch/arc/kernel/setup.c | 29 ++++++++++++++++------------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/arch/arc/kernel/setup.c b/arch/arc/kernel/setup.c index 7ee89dc61f6e..edb55b6ee278 100644 --- a/arch/arc/kernel/setup.c +++ b/arch/arc/kernel/setup.c @@ -389,11 +389,23 @@ static char *arc_extn_mumbojumbo(int cpu_id, char *buf, int len) return buf; } +static void chk_opt_strict(char *opt_name, bool hw_exists, bool opt_ena) +{ + if (hw_exists && !opt_ena) + pr_warn(" ! Enable %s for working apps\n", opt_name); + else if (!hw_exists && opt_ena) + panic("Disable %s, hardware NOT present\n", opt_name); +} + +#define CHK_OPT_STRICT(opt_name, hw_exists) \ +({ \ + chk_opt_strict(#opt_name, hw_exists, IS_ENABLED(opt_name)); \ +}) + static void arc_chk_core_config(void) { struct cpuinfo_arc *cpu = &cpuinfo_arc700[smp_processor_id()]; - int saved = 0, present = 0; - char *opt_nm = NULL; + int present = 0; if (!cpu->extn.timer0) panic("Timer0 is not present!\n"); @@ -425,23 +437,14 @@ static void arc_chk_core_config(void) */ if (is_isa_arcompact()) { - opt_nm = "CONFIG_ARC_FPU_SAVE_RESTORE"; - saved = IS_ENABLED(CONFIG_ARC_FPU_SAVE_RESTORE); - /* only DPDP checked since SP has no arch visible regs */ present = cpu->extn.fpu_dp; + CHK_OPT_STRICT(CONFIG_ARC_FPU_SAVE_RESTORE, present); } else { - opt_nm = "CONFIG_ARC_HAS_ACCL_REGS"; - saved = IS_ENABLED(CONFIG_ARC_HAS_ACCL_REGS); - /* Accumulator Low:High pair (r58:59) present if DSP MPY or FPU */ present = cpu->extn_mpy.dsp | cpu->extn.fpu_sp | cpu->extn.fpu_dp; + CHK_OPT_STRICT(CONFIG_ARC_HAS_ACCL_REGS, present); } - - if (present && !saved) - pr_warn("Enable %s for working apps\n", opt_nm); - else if (!present && saved) - panic("Disable %s, hardware NOT present\n", opt_nm); } /* -- 2.21.0