Received: by 10.223.176.5 with SMTP id f5csp2244031wra; Thu, 8 Feb 2018 10:42:19 -0800 (PST) X-Google-Smtp-Source: AH8x2259EgfKTsXXmsiETUuQkqPQPmm7aih4Kg6O6YhmL0LqOWbZv9xNIRosARRWT0KI2CP/ZZX4 X-Received: by 10.99.135.67 with SMTP id i64mr94049pge.331.1518115339388; Thu, 08 Feb 2018 10:42:19 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518115339; cv=none; d=google.com; s=arc-20160816; b=f4zJYeQMGGy/61VJXUrP6kK3mKxQsl/prkk5p+GvSawM1+xTwhuw7v/vWcXSkgMs5j t3bu9HR+viYlBnaa2SpxMOcUyj/yoF5duoeY22LyCJrA2uxtp6zocs2aDTnt2HO3V94/ k8ozlRG31Z/UKXNzfn+mQ6rIqPaXHHAesLOcH6fFNVtm5kEXE2jdKXnaeoUlElF+fdV/ TAGTFO5OA3ZGj2F0iYL1rBtoWU/BlfG/hqXw2s2utJggddFDRkvD8pQWParPngsMiU2Q 22JzdhdogNYtUOkfooeZRwN6qRz7fshKV9VWqm1p7KNuv5zJ/2M0pxIBNeewmrwahBeA evXQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=1QlZAY2vxyyAlWh26fnAmC7ass/aguQSgBvjhz5f3d4=; b=0CqYjIQxMIwJZfYX/9RRBbcQu1U2dDcceTDpQuJsv7fRg//oenZX5Pq7eQJihkKRc7 aXAiSUXo8ffsLOPniIg5zOJ4xbZJzTk9VvXl3i6TaWJQ4J1gdBzmjXvjp/49lb3CQ2mj 5otWjvbqkkdPlMOz2qnfl4Ek0x22eoG5m2cSo5QIofCJYoSdhVHtxJsSi5bLwQ7VZjpU C/S6X2o7pTo/VNrIkrJHOHfdo7EqfUMkXUhyRj24tnxHdRPU3YLxKl5PDFcw6NbUl5aw yBy2NDUoh4V5iJjfKRwNwoqAFt8TplBxArEDCxfe8vnNu0/FtW/uKeHSqwNKutMohdE8 MhfA== 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 t22-v6si316784plo.256.2018.02.08.10.42.03; Thu, 08 Feb 2018 10:42:19 -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 S1752192AbeBHSlR (ORCPT + 99 others); Thu, 8 Feb 2018 13:41:17 -0500 Received: from foss.arm.com ([217.140.101.70]:38940 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752126AbeBHSlP (ORCPT ); Thu, 8 Feb 2018 13:41:15 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 3554E80D; Thu, 8 Feb 2018 10:41:15 -0800 (PST) Received: from e110439-lin (e110439-lin.cambridge.arm.com [10.1.210.68]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id AC63A3F24D; Thu, 8 Feb 2018 10:41:12 -0800 (PST) Date: Thu, 8 Feb 2018 18:41:06 +0000 From: Patrick Bellasi To: "Paul E. McKenney" Cc: linux-kernel@vger.kernel.org, linux-arch@vger.kernel.org, stern@rowland.harvard.edu, parri.andrea@gmail.com, j.alglave@ucl.ac.uk, luc.maranget@inria.fr, boqun.feng@gmail.com, will.deacon@arm.com, peterz@infradead.org, npiggin@gmail.com, dhowells@redhat.com, elena.reshetova@intel.com, mhocko@suse.com, akiyks@gmail.com Subject: Re: [GIT PULL tools] Linux kernel memory model Message-ID: <20180208184106.GA17043@e110439-lin> References: <20180125093440.GA875@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180125093440.GA875@linux.vnet.ibm.com> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Paul, thanks to you and all the involved guys for this useful tool. I give it a try today and found that by installing herd7 by just following the instruction in herdtools7/INSTALL.md, and precisely installing it via: opam install herdtools7 it seems to give you a tool which fails to run the basic example in your README with this error: File "./linux-kernel.def", line 44, characters 29-30: unexpected '-' (in macros) As suggested by Will, by building instead herd7 HEAD (commit 44d69c2) everything works fine. Maybe it's a know issue, in case just ignore me. :) Otherwise, maybe it can be worth to add to the README a note on which minimum version of the herd7 tool is required. opma version (not working) : 7.47, Rev: exported master version (working for me) : 7.47+7(dev), Rev: 44d69c2b1b5ca0f97bd138899d31532ee5e4e084 Cheers Patrick On 25-Jan 01:34, Paul E. McKenney wrote: > Hello, Ingo, > > This pull request contains a single commit that adds a memory model to > the tools directory. This memory model can (roughly speaking) be thought > of as an automated version of memory-barriers.txt. It is written in the > "cat" language, which is executable by the externally provided "herd7" > simulator, which exhaustively explores the state space of small litmus > tests. > > This memory model is accompanied by extensive documentation on its use > and its design. Two versions have been sent to LKML and feedback > incorporated: > > 1. http://lkml.kernel.org/r/20171113184031.GA26302@linux.vnet.ibm.com > 2. http://lkml.kernel.org/r/20180119035855.GA29296@linux.vnet.ibm.com > > This model has been presented and demoed at a number of Linux gatherings, > including the 2016 LinuxCon EU, the 2016 Linux Plumbers Conference, > the 2016 Linux Kernel Summit, the 2017 linux.conf.au, and the 2017 Linux > Plumbers Conference, which featured a workshop helping a number of Linux > kernel hackers install and use the tool. > > This memory model has matured to the point where it would be good to include > it in the Linux kernel, for example, to allow it to track changes as new > hardware and use cases are added. We expect the rate of change to be similar > to that of Documentation/memory-barriers.txt. > > This memory model is available in the git repository at: > > git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu.git > > for you to fetch changes up to 1c27b644c0fdbc61e113b8faee14baeb8df32486: > > Automate memory-barriers.txt; provide Linux-kernel memory model (2018-01-24 20:53:49 -0800) > > ---------------------------------------------------------------- > Paul E. McKenney (1): > Automate memory-barriers.txt; provide Linux-kernel memory model > > tools/memory-model/Documentation/cheatsheet.txt | 30 + > tools/memory-model/Documentation/explanation.txt | 1840 ++++++++++++++++++++ > tools/memory-model/Documentation/recipes.txt | 570 ++++++ > tools/memory-model/Documentation/references.txt | 107 ++ > tools/memory-model/MAINTAINERS | 15 + > tools/memory-model/README | 220 +++ > tools/memory-model/linux-kernel.bell | 53 + > tools/memory-model/linux-kernel.cat | 124 ++ > tools/memory-model/linux-kernel.cfg | 21 + > tools/memory-model/linux-kernel.def | 108 ++ > .../litmus-tests/CoRR+poonceonce+Once.litmus | 19 + > .../litmus-tests/CoRW+poonceonce+Once.litmus | 18 + > .../litmus-tests/CoWR+poonceonce+Once.litmus | 18 + > .../litmus-tests/CoWW+poonceonce.litmus | 11 + > .../litmus-tests/IRIW+mbonceonces+OnceOnce.litmus | 35 + > .../litmus-tests/IRIW+poonceonces+OnceOnce.litmus | 33 + > .../litmus-tests/ISA2+poonceonces.litmus | 28 + > ...cerelease+poacquirerelease+poacquireonce.litmus | 28 + > .../litmus-tests/LB+ctrlonceonce+mbonceonce.litmus | 23 + > .../LB+poacquireonce+pooncerelease.litmus | 21 + > .../litmus-tests/LB+poonceonces.litmus | 21 + > .../litmus-tests/MP+onceassign+derefonce.litmus | 25 + > tools/memory-model/litmus-tests/MP+polocks.litmus | 24 + > .../litmus-tests/MP+poonceonces.litmus | 20 + > .../MP+pooncerelease+poacquireonce.litmus | 20 + > .../memory-model/litmus-tests/MP+porevlocks.litmus | 24 + > .../litmus-tests/MP+wmbonceonce+rmbonceonce.litmus | 22 + > .../memory-model/litmus-tests/R+mbonceonces.litmus | 21 + > .../memory-model/litmus-tests/R+poonceonces.litmus | 19 + > tools/memory-model/litmus-tests/README | 125 ++ > .../memory-model/litmus-tests/S+poonceonces.litmus | 19 + > .../S+wmbonceonce+poacquireonce.litmus | 20 + > .../litmus-tests/SB+mbonceonces.litmus | 23 + > .../litmus-tests/SB+poonceonces.litmus | 21 + > .../litmus-tests/WRC+poonceonces+Once.litmus | 27 + > .../WRC+pooncerelease+rmbonceonce+Once.litmus | 28 + > .../Z6.0+pooncelock+poonceLock+pombonce.litmus | 33 + > .../Z6.0+pooncelock+pooncelock+pombonce.litmus | 32 + > ...ooncerelease+poacquirerelease+mbonceonce.litmus | 28 + > tools/memory-model/lock.cat | 99 ++ > 40 files changed, 3973 insertions(+) > create mode 100644 tools/memory-model/Documentation/cheatsheet.txt > create mode 100644 tools/memory-model/Documentation/explanation.txt > create mode 100644 tools/memory-model/Documentation/recipes.txt > create mode 100644 tools/memory-model/Documentation/references.txt > create mode 100644 tools/memory-model/MAINTAINERS > create mode 100644 tools/memory-model/README > create mode 100644 tools/memory-model/linux-kernel.bell > create mode 100644 tools/memory-model/linux-kernel.cat > create mode 100644 tools/memory-model/linux-kernel.cfg > create mode 100644 tools/memory-model/linux-kernel.def > create mode 100644 tools/memory-model/litmus-tests/CoRR+poonceonce+Once.litmus > create mode 100644 tools/memory-model/litmus-tests/CoRW+poonceonce+Once.litmus > create mode 100644 tools/memory-model/litmus-tests/CoWR+poonceonce+Once.litmus > create mode 100644 tools/memory-model/litmus-tests/CoWW+poonceonce.litmus > create mode 100644 tools/memory-model/litmus-tests/IRIW+mbonceonces+OnceOnce.litmus > create mode 100644 tools/memory-model/litmus-tests/IRIW+poonceonces+OnceOnce.litmus > create mode 100644 tools/memory-model/litmus-tests/ISA2+poonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/ISA2+pooncerelease+poacquirerelease+poacquireonce.litmus > create mode 100644 tools/memory-model/litmus-tests/LB+ctrlonceonce+mbonceonce.litmus > create mode 100644 tools/memory-model/litmus-tests/LB+poacquireonce+pooncerelease.litmus > create mode 100644 tools/memory-model/litmus-tests/LB+poonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/MP+onceassign+derefonce.litmus > create mode 100644 tools/memory-model/litmus-tests/MP+polocks.litmus > create mode 100644 tools/memory-model/litmus-tests/MP+poonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/MP+pooncerelease+poacquireonce.litmus > create mode 100644 tools/memory-model/litmus-tests/MP+porevlocks.litmus > create mode 100644 tools/memory-model/litmus-tests/MP+wmbonceonce+rmbonceonce.litmus > create mode 100644 tools/memory-model/litmus-tests/R+mbonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/R+poonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/README > create mode 100644 tools/memory-model/litmus-tests/S+poonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/S+wmbonceonce+poacquireonce.litmus > create mode 100644 tools/memory-model/litmus-tests/SB+mbonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/SB+poonceonces.litmus > create mode 100644 tools/memory-model/litmus-tests/WRC+poonceonces+Once.litmus > create mode 100644 tools/memory-model/litmus-tests/WRC+pooncerelease+rmbonceonce+Once.litmus > create mode 100644 tools/memory-model/litmus-tests/Z6.0+pooncelock+poonceLock+pombonce.litmus > create mode 100644 tools/memory-model/litmus-tests/Z6.0+pooncelock+pooncelock+pombonce.litmus > create mode 100644 tools/memory-model/litmus-tests/Z6.0+pooncerelease+poacquirerelease+mbonceonce.litmus > create mode 100644 tools/memory-model/lock.cat > -- #include Patrick Bellasi