Received: by 10.223.176.5 with SMTP id f5csp3382280wra; Mon, 29 Jan 2018 12:23:31 -0800 (PST) X-Google-Smtp-Source: AH8x224hJ2Ff6QFBp86sFDI9G3xVhxh1qsmLAwM1996oKBw734cb3f5EbOZJD2Ur5HCo2sfb9wsX X-Received: by 10.99.96.23 with SMTP id u23mr23079390pgb.355.1517257411782; Mon, 29 Jan 2018 12:23:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517257411; cv=none; d=google.com; s=arc-20160816; b=Cax5pLEKOfQN/ZAA5l5Qd2Hm7MImN1JZUhtKw9wEv0GExTfufxYSFCZbJ4T3kB1vyn gW+g9f1MGYueyttNoT9UC5HVAkGHGcYzj3GrhU9IjzgJx1ydH+4Z4ZeWA1oHR5kYEUJV 1Aj3yE/Xh2IdywpxCyOV0iqJ17sstmO7cw6boMyIVvkb+5cyFcUb1a6uO0sMdGYkyD9f 2PlLA+kEKcXBc4CKDmZ9uSW62omFXgSc/TQ9xV6rI8FrDC3uDt9SbFzhnf7XjO9hnsdd J7P3XQEG+OadtKUJ4kbkjUJgVhdF20EmPePknMZsV164g/oYxH0OcPN8UmUfrpJ8+/eE IXdQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=dXhK4aSI3HVyrcYyYAzFXRSGoR5u37+m0Zvjpuwq050=; b=b5YGh0Pt46xe/hsElxcJGN3RLu+o97cVvYKj03PNccfDF4y5s6FVfZhCtavbjco5WH u4cS2dIo3rUr3MzHm2pD5vW85N3cOEv8WTDM/kF0X7vHaZuIe8jSAojj2ynde/kuucY3 5ISDRrhb97ddOQbnvZoit1FW17TN4z8rrupJoThae7Cm+jE+inU2bUeftNqX/e3QNygc HxttbrvLHkL/HdWVlAtiRYZY1Z5yUiOrZtQepS/ngtt3k7rqiHSI4iEyIS4T+umY6kLK 5oSnhYMqqlRXL8l8/w1nnCO6n4TJSJKmcSbz+EgZiv+b+2gdYeQ/VYlftQaqJLdO1rVi DvZA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v207si7956477pgb.47.2018.01.29.12.23.17; Mon, 29 Jan 2018 12:23:31 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754889AbeA2UWo (ORCPT + 99 others); Mon, 29 Jan 2018 15:22:44 -0500 Received: from mail.efficios.com ([167.114.142.141]:53403 "EHLO mail.efficios.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754810AbeA2UWf (ORCPT ); Mon, 29 Jan 2018 15:22:35 -0500 Received: from localhost (localhost.localdomain [127.0.0.1]) by mail.efficios.com (Postfix) with ESMTP id 720533402DE; Mon, 29 Jan 2018 20:23:07 +0000 (UTC) Received: from mail.efficios.com ([127.0.0.1]) by localhost (evm-mail-1.efficios.com [127.0.0.1]) (amavisd-new, port 10032) with ESMTP id TtrCoseho1Jq; Mon, 29 Jan 2018 20:22:53 +0000 (UTC) Received: from localhost (localhost.localdomain [127.0.0.1]) by mail.efficios.com (Postfix) with ESMTP id E98BD340111; Mon, 29 Jan 2018 20:22:42 +0000 (UTC) X-Virus-Scanned: amavisd-new at efficios.com Received: from mail.efficios.com ([127.0.0.1]) by localhost (evm-mail-1.efficios.com [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id Kk8pIConFI1k; Mon, 29 Jan 2018 20:22:42 +0000 (UTC) Received: from thinkos.internal.efficios.com (192-222-157-41.qc.cable.ebox.net [192.222.157.41]) by mail.efficios.com (Postfix) with ESMTPSA id 6F66134030B; Mon, 29 Jan 2018 20:22:42 +0000 (UTC) From: Mathieu Desnoyers To: Ingo Molnar , Peter Zijlstra , Thomas Gleixner Cc: linux-kernel@vger.kernel.org, linux-api@vger.kernel.org, Andy Lutomirski , "Paul E . McKenney" , Boqun Feng , Andrew Hunter , Maged Michael , Avi Kivity , Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman , Dave Watson , "H . Peter Anvin" , Andrea Parri , Russell King , Greg Hackmann , Will Deacon , David Sehr , Linus Torvalds , x86@kernel.org, Mathieu Desnoyers , Greg Kroah-Hartman , Alan Stern , Alice Ferrazzi , Paul Elder , linux-kselftest@vger.kernel.org, linux-arch@vger.kernel.org Subject: [PATCH for 4.16 11/11] membarrier: selftest: Test private expedited sync core cmd Date: Mon, 29 Jan 2018 15:20:20 -0500 Message-Id: <20180129202020.8515-12-mathieu.desnoyers@efficios.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20180129202020.8515-1-mathieu.desnoyers@efficios.com> References: <20180129202020.8515-1-mathieu.desnoyers@efficios.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Test the new MEMBARRIER_CMD_PRIVATE_EXPEDITED_SYNC_CORE and MEMBARRIER_CMD_REGISTER_PRIVATE_EXPEDITED_SYNC_CORE commands. Signed-off-by: Mathieu Desnoyers Acked-by: Shuah Khan Acked-by: Peter Zijlstra (Intel) CC: Greg Kroah-Hartman CC: Paul E. McKenney CC: Boqun Feng CC: Andrew Hunter CC: Maged Michael CC: Avi Kivity CC: Benjamin Herrenschmidt CC: Paul Mackerras CC: Michael Ellerman CC: Dave Watson CC: Alan Stern CC: Will Deacon CC: Andy Lutomirski CC: Alice Ferrazzi CC: Paul Elder CC: linux-kselftest@vger.kernel.org CC: linux-arch@vger.kernel.org --- .../testing/selftests/membarrier/membarrier_test.c | 73 ++++++++++++++++++++++ 1 file changed, 73 insertions(+) diff --git a/tools/testing/selftests/membarrier/membarrier_test.c b/tools/testing/selftests/membarrier/membarrier_test.c index eec39a0e1f77..22bffd55a523 100644 --- a/tools/testing/selftests/membarrier/membarrier_test.c +++ b/tools/testing/selftests/membarrier/membarrier_test.c @@ -132,6 +132,63 @@ static int test_membarrier_private_expedited_success(void) return 0; } +static int test_membarrier_private_expedited_sync_core_fail(void) +{ + int cmd = MEMBARRIER_CMD_PRIVATE_EXPEDITED_SYNC_CORE, flags = 0; + const char *test_name = "sys membarrier MEMBARRIER_CMD_PRIVATE_EXPEDITED_SYNC_CORE not registered failure"; + + if (sys_membarrier(cmd, flags) != -1) { + ksft_exit_fail_msg( + "%s test: flags = %d. Should fail, but passed\n", + test_name, flags); + } + if (errno != EPERM) { + ksft_exit_fail_msg( + "%s test: flags = %d. Should return (%d: \"%s\"), but returned (%d: \"%s\").\n", + test_name, flags, EPERM, strerror(EPERM), + errno, strerror(errno)); + } + + ksft_test_result_pass( + "%s test: flags = %d, errno = %d\n", + test_name, flags, errno); + return 0; +} + +static int test_membarrier_register_private_expedited_sync_core_success(void) +{ + int cmd = MEMBARRIER_CMD_REGISTER_PRIVATE_EXPEDITED_SYNC_CORE, flags = 0; + const char *test_name = "sys membarrier MEMBARRIER_CMD_REGISTER_PRIVATE_EXPEDITED_SYNC_CORE"; + + if (sys_membarrier(cmd, flags) != 0) { + ksft_exit_fail_msg( + "%s test: flags = %d, errno = %d\n", + test_name, flags, errno); + } + + ksft_test_result_pass( + "%s test: flags = %d\n", + test_name, flags); + return 0; +} + +static int test_membarrier_private_expedited_sync_core_success(void) +{ + int cmd = MEMBARRIER_CMD_PRIVATE_EXPEDITED, flags = 0; + const char *test_name = "sys membarrier MEMBARRIER_CMD_PRIVATE_EXPEDITED_SYNC_CORE"; + + if (sys_membarrier(cmd, flags) != 0) { + ksft_exit_fail_msg( + "%s test: flags = %d, errno = %d\n", + test_name, flags, errno); + } + + ksft_test_result_pass( + "%s test: flags = %d\n", + test_name, flags); + return 0; +} + static int test_membarrier_register_global_expedited_success(void) { int cmd = MEMBARRIER_CMD_REGISTER_GLOBAL_EXPEDITED, flags = 0; @@ -188,6 +245,22 @@ static int test_membarrier(void) status = test_membarrier_private_expedited_success(); if (status) return status; + status = sys_membarrier(MEMBARRIER_CMD_QUERY, 0); + if (status < 0) { + ksft_test_result_fail("sys_membarrier() failed\n"); + return status; + } + if (status & MEMBARRIER_CMD_PRIVATE_EXPEDITED_SYNC_CORE) { + status = test_membarrier_private_expedited_sync_core_fail(); + if (status) + return status; + status = test_membarrier_register_private_expedited_sync_core_success(); + if (status) + return status; + status = test_membarrier_private_expedited_sync_core_success(); + if (status) + return status; + } /* * It is valid to send a global membarrier from a non-registered * process. -- 2.11.0