Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp8281152rwb; Tue, 13 Dec 2022 04:39:26 -0800 (PST) X-Google-Smtp-Source: AA0mqf4hRLTFCfTWRB/mGpzDiBue6UxeplAc/EcTclt4DxTDpYUXkVzkvJhDv/zhOWGZW9o7Tbyl X-Received: by 2002:a17:906:4a9a:b0:7c1:2529:2760 with SMTP id x26-20020a1709064a9a00b007c125292760mr16750238eju.27.1670935166468; Tue, 13 Dec 2022 04:39:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1670935166; cv=none; d=google.com; s=arc-20160816; b=hC08zcelBEtYXuZoYg9GC0Zt8ijES9U/ke8uc2NsMSyWYidzTk4WCnT+J6BzJifUar qXBqzqqr1sdgsv09Hrt+zhbCONnhDT9kq+yIVzanY1yL7aJ3JRhtBwHc/dyK5n28B6h9 kzuJkK+/PDetnYYVGmuxH7e7hNgVm+R7aafB6jS5CVlasvH/rqFa4RI0iOLmdw3gIN+7 yxN/hkdEpQBuhOaucvNvoaRjB7kaNwDZx+nkHfnwlGnE2NnCCKDaNkQJuaY2u5WeHXrH m3J2yHebhMdoEK3F7Dca+LpH9f4ZtgMvM+dumK+8CRJZptRCSSD9kKx62s39jRo6Yqss /gkA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=rWPdzOukqJReNeGmMbblgWbKbrMGHgcUqPln9idDQR0=; b=tgAI8+UdrMc2xOHV9s6AmOaQFCUGQmq1b4rXMMDKPIjXDOnSe98Ji/3vfmBIBd2ZUm o2o5vI2kgWAOWi1rAhFNEGIWJ615rY45Z/ZyOHnjD9XCqEWZ5DwfgibpNmUz2cNYyT8Z mrJodo5cnVUE7ovgbyg/R1yXMVFhciGqbNz1E7SbK67xX9bGX9z8pRgxl0QzjfJoPT66 uvBHR/gc5zSjIanYgWiY1P5UGfvYKhw1ENBuo+1qc2SIfgmOf+ZsiFTIjKyglixR9sxG A3ksM8ezq9U0pdgTOR5ilLc6oeY7csk/0mhLYrOBXpvf9sNnWMY86QrwpLyNOiOfPvnk +m2A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id qb21-20020a1709077e9500b007c0dcc79ec2si8865521ejc.171.2022.12.13.04.39.08; Tue, 13 Dec 2022 04:39:26 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235393AbiLMLul (ORCPT + 73 others); Tue, 13 Dec 2022 06:50:41 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45068 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235355AbiLMLua (ORCPT ); Tue, 13 Dec 2022 06:50:30 -0500 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 6BEDE11820; Tue, 13 Dec 2022 03:50:29 -0800 (PST) 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 AFDF0168F; Tue, 13 Dec 2022 03:51:09 -0800 (PST) Received: from e126815.warwick.arm.com (e126815.arm.com [10.32.32.26]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 8B9243F5A1; Tue, 13 Dec 2022 03:50:27 -0800 (PST) From: James Clark To: linux-perf-users@vger.kernel.org Cc: James Clark , Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , linux-kernel@vger.kernel.org, bpf@vger.kernel.org Subject: [PATCH v2 3/4] perf test: Add mechanism for skipping attr tests on kernel versions Date: Tue, 13 Dec 2022 11:47:38 +0000 Message-Id: <20221213114739.2312862-4-james.clark@arm.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20221213114739.2312862-1-james.clark@arm.com> References: <20221213114739.2312862-1-james.clark@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The first two version numbers are used since that is where the ABI changes happen, so seems to be the most useful for now. 'Until' is exclusive and 'since' is inclusive so that the same version number can be used to mark a point where the change comes into effect. This allows keeping the tests in a state where new tests will also pass on older kernels if the existence of a new feature isn't explicitly broadcast by the kernel. For example extended user regs are currently discovered by trial and error calls to perf_event_open. Signed-off-by: James Clark --- tools/perf/tests/attr.py | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/tools/perf/tests/attr.py b/tools/perf/tests/attr.py index eceb6d022141..ccfef861e931 100644 --- a/tools/perf/tests/attr.py +++ b/tools/perf/tests/attr.py @@ -6,6 +6,7 @@ import os import sys import glob import optparse +import platform import tempfile import logging import re @@ -125,6 +126,11 @@ class Event(dict): if not data_equal(self[t], other[t]): log.warning("expected %s=%s, got %s" % (t, self[t], other[t])) +def parse_version(version): + if not version: + return None + return [int(v) for v in version.split(".")[0:2]] + # Test file description needs to have following sections: # [config] # - just single instance in file @@ -138,7 +144,9 @@ class Event(dict): # negates it. # 'auxv' - Truthy statement that is evaled in the scope of the auxv map. When false, # the test is skipped. For example 'auxv["AT_HWCAP"] == 10'. (optional) -# +# 'kernel_since' - Inclusive kernel version from which the test will start running. Only the +# first two values are supported, for example "6.1" (optional) +# 'kernel_until' - Exclusive kernel version from which the test will stop running. (optional) # [eventX:base] # - one or multiple instances in file # - expected values assignments @@ -169,6 +177,8 @@ class Test(object): self.arch = '' self.auxv = parser.get('config', 'auxv', fallback=None) + self.kernel_since = parse_version(parser.get('config', 'kernel_since', fallback=None)) + self.kernel_until = parse_version(parser.get('config', 'kernel_until', fallback=None)) self.expect = {} self.result = {} log.debug(" loading expected events"); @@ -180,6 +190,16 @@ class Test(object): else: return True + def skip_test_kernel_since(self): + if not self.kernel_since: + return False + return not self.kernel_since <= parse_version(platform.release()) + + def skip_test_kernel_until(self): + if not self.kernel_until: + return False + return not parse_version(platform.release()) < self.kernel_until + def skip_test_auxv(self): def new_auxv(a, pattern): items = list(filter(None, pattern.split(a))) @@ -257,6 +277,12 @@ class Test(object): if self.skip_test_auxv(): raise Notest(self, "auxv skip") + if self.skip_test_kernel_since(): + raise Notest(self, "old kernel skip") + + if self.skip_test_kernel_until(): + raise Notest(self, "new kernel skip") + cmd = "PERF_TEST_ATTR=%s %s %s -o %s/perf.data %s" % (tempdir, self.perf, self.command, tempdir, self.args) ret = os.WEXITSTATUS(os.system(cmd)) -- 2.25.1