From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.2 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 89C59C3A5A3 for ; Tue, 27 Aug 2019 12:14:42 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 6149B2186A for ; Tue, 27 Aug 2019 12:14:42 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="S12lkB/W" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 6149B2186A Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=arm.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date: Message-ID:From:References:To:Subject:Reply-To:Content-ID:Content-Description :Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=5i06E7BZFM3GK6uYk5VUlTzNSOeuG2fEy5Bh7I387WE=; b=S12lkB/Wk8wlqM 1F6D3UGFAz7ktiXPBL6hoqXullM5EIdXOF35EoAA2kTLFks2NUfsOFPNg1Jpnm0YNITq0tcwo6CUV daw+Gp0hzokMohv8fw35+lpKFwm2O9b8aDZ9dtOgydI78MUC4vbHU4Dm5YdV9byEJC+uDVhJMnLca XEHZbuf9ikywU9XetRrfJJE9Fwzd9HCDoiyWuRJ7j+KqE3H9RKPtiwDRepHF6Zd4Yt3MKMnIyeGym 7EDUV2I0WTUAsWLZBayiepq0dQ8EBSp0qCJe/M1VQX6AgQTz6qmnvv8KFhmL4trXeJLhEA+w8SHNg JslUsaxhvVDO38TJNVVQ==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92 #3 (Red Hat Linux)) id 1i2aMt-0002lV-Pa; Tue, 27 Aug 2019 12:14:35 +0000 Received: from foss.arm.com ([217.140.110.172]) by bombadil.infradead.org with esmtp (Exim 4.92 #3 (Red Hat Linux)) id 1i2aMq-0002kv-8i for linux-arm-kernel@lists.infradead.org; Tue, 27 Aug 2019 12:14:33 +0000 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id DF1ED28; Tue, 27 Aug 2019 05:14:30 -0700 (PDT) Received: from [10.1.197.50] (e120937-lin.cambridge.arm.com [10.1.197.50]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 067B43F718; Tue, 27 Aug 2019 05:14:29 -0700 (PDT) Subject: Re: [PATCH v3 01/11] kselftest: arm64: introduce new boilerplate code To: Dave Martin References: <20190802170300.20662-1-cristian.marussi@arm.com> <20190802170300.20662-2-cristian.marussi@arm.com> <20190813162337.GY10425@arm.com> From: Cristian Marussi Message-ID: Date: Tue, 27 Aug 2019 13:14:28 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20190813162337.GY10425@arm.com> Content-Language: en-US X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20190827_051432_394012_A91ED03A X-CRM114-Status: GOOD ( 21.94 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: andreyknvl@google.com, shuah@kernel.org, linux-arm-kernel@lists.infradead.org, linux-kselftest@vger.kernel.org Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi On 13/08/2019 17:23, Dave Martin wrote: > ^ Regarding the subject line, "boilerplate code" sounds a bit vague. > Could we say something like "Add skeleton Makefile"? > Yes of course. > On Fri, Aug 02, 2019 at 06:02:50PM +0100, Cristian Marussi wrote: >> Added a new arm64-specific empty subsystem amongst TARGETS of KSFT build >> framework; once populated with testcases, it will be possible to build >> and invoke the new KSFT TARGETS=arm64 related tests from the toplevel >> Makefile in the usual ways. >> >> Signed-off-by: Cristian Marussi >> --- >> Reviewed the build instructions reported in the README, to be more >> agnostic regarding user/device etc.. >> --- >> tools/testing/selftests/Makefile | 1 + >> tools/testing/selftests/arm64/Makefile | 51 ++++++++++++++++++++++++++ >> tools/testing/selftests/arm64/README | 43 ++++++++++++++++++++++ >> 3 files changed, 95 insertions(+) >> create mode 100644 tools/testing/selftests/arm64/Makefile >> create mode 100644 tools/testing/selftests/arm64/README >> >> diff --git a/tools/testing/selftests/Makefile b/tools/testing/selftests/Makefile >> index 25b43a8c2b15..1722dae9381a 100644 >> --- a/tools/testing/selftests/Makefile >> +++ b/tools/testing/selftests/Makefile >> @@ -1,5 +1,6 @@ >> # SPDX-License-Identifier: GPL-2.0 >> TARGETS = android >> +TARGETS += arm64 >> TARGETS += bpf >> TARGETS += breakpoints >> TARGETS += capabilities >> diff --git a/tools/testing/selftests/arm64/Makefile b/tools/testing/selftests/arm64/Makefile >> new file mode 100644 >> index 000000000000..03a0d4f71218 >> --- /dev/null >> +++ b/tools/testing/selftests/arm64/Makefile >> @@ -0,0 +1,51 @@ >> +# SPDX-License-Identifier: GPL-2.0 >> +# Copyright (C) 2019 ARM Limited >> + >> +# When ARCH not overridden for crosscompiling, lookup machine >> +ARCH ?= $(shell uname -m) >> +ARCH := $(shell echo $(ARCH) | sed -e s/aarch64/arm64/) >> + >> +ifeq ("x$(ARCH)", "xarm64") >> +SUBDIRS := >> +else >> +SUBDIRS := >> +endif >> + >> +CFLAGS := -Wall -O2 -g >> + >> +export CC >> +export CFLAGS >> + >> +all: >> + @for DIR in $(SUBDIRS); do \ >> + BUILD_TARGET=$(OUTPUT)/$$DIR; \ >> + mkdir -p $$BUILD_TARGET; \ >> + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ >> + done >> + >> +install: all >> + @for DIR in $(SUBDIRS); do \ >> + BUILD_TARGET=$(OUTPUT)/$$DIR; \ >> + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ >> + done >> + >> +run_tests: all >> + @for DIR in $(SUBDIRS); do \ >> + BUILD_TARGET=$(OUTPUT)/$$DIR; \ >> + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ >> + done >> + >> +# Avoid any output on non arm64 on emit_tests >> +emit_tests: all >> + @for DIR in $(SUBDIRS); do \ >> + BUILD_TARGET=$(OUTPUT)/$$DIR; \ >> + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ >> + done >> + >> +clean: >> + @for DIR in $(SUBDIRS); do \ >> + BUILD_TARGET=$(OUTPUT)/$$DIR; \ >> + make OUTPUT=$$BUILD_TARGET -C $$DIR $@; \ >> + done >> + >> +.PHONY: all clean install run_tests emit_tests >> diff --git a/tools/testing/selftests/arm64/README b/tools/testing/selftests/arm64/README >> new file mode 100644 >> index 000000000000..dee3306071cc >> --- /dev/null >> +++ b/tools/testing/selftests/arm64/README >> @@ -0,0 +1,43 @@ >> +KSelfTest ARM64 >> +=============== >> + >> +- These tests are arm64 specific and so not built or run but just skipped >> + completely when env-variable ARCH is found to be different than 'arm64' >> + and `uname -m` reports other than 'aarch64'. >> + >> +- Holding true the above, ARM64 KSFT tests can be run: >> + >> + + as standalone (example for signal tests) >> + >> + $ make -C tools/testing/selftest/arm64/signal \ >> + INSTALL_PATH= install >> + >> + and then launching on the target device inside the installed path: >> + >> + $ /test_arm64_signals.sh [-k | -v] >> + >> + + within the KSelfTest framework using standard Linux top-level-makefile >> + targets: >> + >> + $ make TARGETS=arm64 kselftest-clean >> + $ make TARGETS=arm64 kselftest >> + >> + Further details on building and running KFST can be found in: >> + Documentation/dev-tools/kselftest.rst > > The next two paragraphs aren't relevant yet. Can we split them out of > this patch and add them alongside the relevant code / Makefile changes? > Sure. I'm going to remove also standalone mode in V4 as elsewhere advised, so I'll drop part of this README too. >> + >> +- Tests can depend on some arch-specific definitions which can be found in a >> + standard Kernel Headers installation in $(top_srcdir)/usr/include. >> + Such Kernel Headers are automatically installed (via make headers_install) >> + by KSFT framework itself in a dedicated directory when tests are launched >> + via KSFT itself; when running standalone, instead, a Warning is issued >> + if such headers cannot be found somewhere (we try to guess a few standard >> + locations anyway) >> + >> +- Some of these tests may be related to possibly not implemented ARMv8 >> + features: depending on their implementation status on the effective HW >> + we'll expect different results. The tests' harness will take care to check >> + at run-time if the required features are supported and will act accordingly. >> + Moreover, in order to avoid any kind of compile-time dependency on the >> + toolchain (possibly due to the above mentioned not-implemented features), >> + we make strictly use of direct 'S3_ sysreg' raw-encoding while checking for >> + those features and/or lookin up sysregs. > > This last paragraph is only relevant for people adding new tests. It > probably makes sense to start "When adding new tests, try to avoid > unnecessary toolchain dependencies where possible. [...]" > > Cheers > ---Dave > Cheers Cristian _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel