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 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 63E02C433EF for ; Tue, 19 Oct 2021 17:25:13 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 49A6B61355 for ; Tue, 19 Oct 2021 17:25:13 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233460AbhJSR1Z (ORCPT ); Tue, 19 Oct 2021 13:27:25 -0400 Received: from mail.kernel.org ([198.145.29.99]:55486 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230158AbhJSR1Z (ORCPT ); Tue, 19 Oct 2021 13:27:25 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id D0CDE610E5; Tue, 19 Oct 2021 17:25:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1634664312; bh=P2l5Y5PDPDJcPc6k74icHUD6sRurj6ctKkCgiE7n3uE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WsbwkXO/qmrk/v9JAwsV0pEVJvp9koDVmGENazlIC9T+wGIPnXfTz5kPYwoMs9haF iVbLf6zIGxzbgI4C/c9Qkc+FuGWUrWnFD0rn/ZyOP52dnWTJdMk9snFJp+eLjQqkLZ MlOqZDlfdh4ynmFNp+4iL2j4I8lv3RpbTdyG+z/ZFzzSJBhrhpLwOXdXmytzuqehZL xRx834b+kerlxEQKReYNB/cETWcSFOy+SZ575mbkwQ7biu2c7kLmE6NQIGSQJDkEmZ TScMnlg+/Dlf2ilkfk/gxtW77K7/A4SsnJcGHW96PPAfh2MAyPlajX8PeOrcOHOdV+ M3Yxc+csrb/oQ== From: Mark Brown To: Catalin Marinas , Will Deacon , Shuah Khan , Shuah Khan Cc: Alan Hayward , Luis Machado , Salil Akerkar , Basant Kumar Dwivedi , Szabolcs Nagy , linux-arm-kernel@lists.infradead.org, linux-kselftest@vger.kernel.org, Mark Brown Subject: [PATCH v3 35/42] kselftest/arm64: sme: Add streaming SME support to vlset Date: Tue, 19 Oct 2021 18:22:40 +0100 Message-Id: <20211019172247.3045838-36-broonie@kernel.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20211019172247.3045838-1-broonie@kernel.org> References: <20211019172247.3045838-1-broonie@kernel.org> MIME-Version: 1.0 X-Developer-Signature: v=1; a=openpgp-sha256; l=1924; h=from:subject; bh=P2l5Y5PDPDJcPc6k74icHUD6sRurj6ctKkCgiE7n3uE=; b=owEBbQGS/pANAwAKASTWi3JdVIfQAcsmYgBhbv7fOiCWCuqdEhEwDeB0fuhFIzO/DqyGIULZWFjy SmyMmrCJATMEAAEKAB0WIQSt5miqZ1cYtZ/in+ok1otyXVSH0AUCYW7+3wAKCRAk1otyXVSH0AbEB/ 4wiSw4QF0STLnihM/cKX/8WtrMDjW6lQxmoTH8WFcyCZKPLBZU7f8ztUV9O9swZsc2dhC+ag1wmvDK 44AhudbH2nnjIexEI0zX3Bx3bHHFkJ6JWACmRAZnzALJiEAGLFHB++itxKkFmzsCXoMU+yh7m64TpH ZdsoVlMSrDs8oOaSS8f8p4fQdAJMmUUe4LbfN3AynJpLTROdfLRLdhNb1LHVj27laLVij4E1ozT2lx jCQFfJqJ813PRjET6+kMh+/qTDaXSqW4gckM4ZNGlixy1Q+OdWysnL/Kr2KmMjSnrSqCkfR487nJpa 46AcDbo0jJxPEJIay5iG1vvOYMfoWF X-Developer-Key: i=broonie@kernel.org; a=openpgp; fpr=3F2568AAC26998F9E813A1C5C3F436CA30F5D8EB Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kselftest@vger.kernel.org The Scalable Matrix Extenions (SME) introduces additional register state with configurable vector lengths, similar to SVE but configured separately. Extend vlset to support configuring this state with a --sme or -s command line option. Signed-off-by: Mark Brown --- tools/testing/selftests/arm64/fp/vlset.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/tools/testing/selftests/arm64/fp/vlset.c b/tools/testing/selftests/arm64/fp/vlset.c index 308d27a68226..76912a581a95 100644 --- a/tools/testing/selftests/arm64/fp/vlset.c +++ b/tools/testing/selftests/arm64/fp/vlset.c @@ -22,12 +22,15 @@ static int inherit = 0; static int no_inherit = 0; static int force = 0; static unsigned long vl; +static int set_ctl = PR_SVE_SET_VL; +static int get_ctl = PR_SVE_GET_VL; static const struct option options[] = { { "force", no_argument, NULL, 'f' }, { "inherit", no_argument, NULL, 'i' }, { "max", no_argument, NULL, 'M' }, { "no-inherit", no_argument, &no_inherit, 1 }, + { "sme", no_argument, NULL, 's' }, { "help", no_argument, NULL, '?' }, {} }; @@ -50,6 +53,9 @@ static int parse_options(int argc, char **argv) case 'M': vl = SVE_VL_MAX; break; case 'f': force = 1; break; case 'i': inherit = 1; break; + case 's': set_ctl = PR_SME_SET_VL; + get_ctl = PR_SME_GET_VL; + break; case 0: break; default: goto error; } @@ -125,14 +131,14 @@ int main(int argc, char **argv) if (inherit) flags |= PR_SVE_VL_INHERIT; - t = prctl(PR_SVE_SET_VL, vl | flags); + t = prctl(set_ctl, vl | flags); if (t < 0) { fprintf(stderr, "%s: PR_SVE_SET_VL: %s\n", program_name, strerror(errno)); goto error; } - t = prctl(PR_SVE_GET_VL); + t = prctl(get_ctl); if (t == -1) { fprintf(stderr, "%s: PR_SVE_GET_VL: %s\n", program_name, strerror(errno)); -- 2.30.2 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 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 396EAC433F5 for ; Tue, 19 Oct 2021 17:51:33 +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 EA315610CC for ; Tue, 19 Oct 2021 17:51:32 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org EA315610CC Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-Id:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=8VC8NwV8Ucm15QPvbHnflhpTFjIxqLhy8BSPfQNADTc=; b=qI34P+NR1azKzH unsrG03MRKjb6pBC7+9wXWxpPdpzIjqnqHiyIRsWznnFKWVevV6plqphfzooe3qV4zNCw9NrP1TQB 80+d5zJ5GESw6IZ3fQG1ND8YJrtEIN820F3HKvj6pwLMRrdFA6n/eYg3xg+ssNqM7vbb8yigeNa3z fLMePW46y0Z0WD8oUSZvkgGiWufELiXte+8IG93ZLxiqenDXNzNUZlA9UwRLP7ItXxyEf0ER/8dqX ChhUV3zWp6ExlPF10CsXd/1E3AHbLNEmJJZavYpAIT3SU4nzH8R/BiwPwb7i51mAG2e65Fz1VtwGK T9nlNweNsnKJ5+Sfy+bQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1mctF8-002FQf-28; Tue, 19 Oct 2021 17:49:42 +0000 Received: from mail.kernel.org ([198.145.29.99]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1mcsrQ-0025ZY-O8 for linux-arm-kernel@lists.infradead.org; Tue, 19 Oct 2021 17:25:14 +0000 Received: by mail.kernel.org (Postfix) with ESMTPSA id D0CDE610E5; Tue, 19 Oct 2021 17:25:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1634664312; bh=P2l5Y5PDPDJcPc6k74icHUD6sRurj6ctKkCgiE7n3uE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WsbwkXO/qmrk/v9JAwsV0pEVJvp9koDVmGENazlIC9T+wGIPnXfTz5kPYwoMs9haF iVbLf6zIGxzbgI4C/c9Qkc+FuGWUrWnFD0rn/ZyOP52dnWTJdMk9snFJp+eLjQqkLZ MlOqZDlfdh4ynmFNp+4iL2j4I8lv3RpbTdyG+z/ZFzzSJBhrhpLwOXdXmytzuqehZL xRx834b+kerlxEQKReYNB/cETWcSFOy+SZ575mbkwQ7biu2c7kLmE6NQIGSQJDkEmZ TScMnlg+/Dlf2ilkfk/gxtW77K7/A4SsnJcGHW96PPAfh2MAyPlajX8PeOrcOHOdV+ M3Yxc+csrb/oQ== From: Mark Brown To: Catalin Marinas , Will Deacon , Shuah Khan , Shuah Khan Cc: Alan Hayward , Luis Machado , Salil Akerkar , Basant Kumar Dwivedi , Szabolcs Nagy , linux-arm-kernel@lists.infradead.org, linux-kselftest@vger.kernel.org, Mark Brown Subject: [PATCH v3 35/42] kselftest/arm64: sme: Add streaming SME support to vlset Date: Tue, 19 Oct 2021 18:22:40 +0100 Message-Id: <20211019172247.3045838-36-broonie@kernel.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20211019172247.3045838-1-broonie@kernel.org> References: <20211019172247.3045838-1-broonie@kernel.org> MIME-Version: 1.0 X-Developer-Signature: v=1; a=openpgp-sha256; l=1924; h=from:subject; bh=P2l5Y5PDPDJcPc6k74icHUD6sRurj6ctKkCgiE7n3uE=; b=owEBbQGS/pANAwAKASTWi3JdVIfQAcsmYgBhbv7fOiCWCuqdEhEwDeB0fuhFIzO/DqyGIULZWFjy SmyMmrCJATMEAAEKAB0WIQSt5miqZ1cYtZ/in+ok1otyXVSH0AUCYW7+3wAKCRAk1otyXVSH0AbEB/ 4wiSw4QF0STLnihM/cKX/8WtrMDjW6lQxmoTH8WFcyCZKPLBZU7f8ztUV9O9swZsc2dhC+ag1wmvDK 44AhudbH2nnjIexEI0zX3Bx3bHHFkJ6JWACmRAZnzALJiEAGLFHB++itxKkFmzsCXoMU+yh7m64TpH ZdsoVlMSrDs8oOaSS8f8p4fQdAJMmUUe4LbfN3AynJpLTROdfLRLdhNb1LHVj27laLVij4E1ozT2lx jCQFfJqJ813PRjET6+kMh+/qTDaXSqW4gckM4ZNGlixy1Q+OdWysnL/Kr2KmMjSnrSqCkfR487nJpa 46AcDbo0jJxPEJIay5iG1vvOYMfoWF X-Developer-Key: i=broonie@kernel.org; a=openpgp; fpr=3F2568AAC26998F9E813A1C5C3F436CA30F5D8EB X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20211019_102512_892031_DE0243A3 X-CRM114-Status: GOOD ( 12.75 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org The Scalable Matrix Extenions (SME) introduces additional register state with configurable vector lengths, similar to SVE but configured separately. Extend vlset to support configuring this state with a --sme or -s command line option. Signed-off-by: Mark Brown --- tools/testing/selftests/arm64/fp/vlset.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/tools/testing/selftests/arm64/fp/vlset.c b/tools/testing/selftests/arm64/fp/vlset.c index 308d27a68226..76912a581a95 100644 --- a/tools/testing/selftests/arm64/fp/vlset.c +++ b/tools/testing/selftests/arm64/fp/vlset.c @@ -22,12 +22,15 @@ static int inherit = 0; static int no_inherit = 0; static int force = 0; static unsigned long vl; +static int set_ctl = PR_SVE_SET_VL; +static int get_ctl = PR_SVE_GET_VL; static const struct option options[] = { { "force", no_argument, NULL, 'f' }, { "inherit", no_argument, NULL, 'i' }, { "max", no_argument, NULL, 'M' }, { "no-inherit", no_argument, &no_inherit, 1 }, + { "sme", no_argument, NULL, 's' }, { "help", no_argument, NULL, '?' }, {} }; @@ -50,6 +53,9 @@ static int parse_options(int argc, char **argv) case 'M': vl = SVE_VL_MAX; break; case 'f': force = 1; break; case 'i': inherit = 1; break; + case 's': set_ctl = PR_SME_SET_VL; + get_ctl = PR_SME_GET_VL; + break; case 0: break; default: goto error; } @@ -125,14 +131,14 @@ int main(int argc, char **argv) if (inherit) flags |= PR_SVE_VL_INHERIT; - t = prctl(PR_SVE_SET_VL, vl | flags); + t = prctl(set_ctl, vl | flags); if (t < 0) { fprintf(stderr, "%s: PR_SVE_SET_VL: %s\n", program_name, strerror(errno)); goto error; } - t = prctl(PR_SVE_GET_VL); + t = prctl(get_ctl); if (t == -1) { fprintf(stderr, "%s: PR_SVE_GET_VL: %s\n", program_name, strerror(errno)); -- 2.30.2 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel