Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp925858imm; Tue, 3 Jul 2018 02:24:41 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfzL5INYlfa9mSJlK/IMHWY6bVgB5lsdNRrP/nvkYD/Rdbx8xBaIYJcfny/1CQBLhB2MPqZ X-Received: by 2002:a17:902:42a3:: with SMTP id h32-v6mr9489306pld.72.1530609881836; Tue, 03 Jul 2018 02:24:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530609881; cv=none; d=google.com; s=arc-20160816; b=yDkP9dN7CZUigvSoFIL+TI5p68GqfTKe6Fmu9nKT2y4JA3pFAzNVSC7ajPieOa2SNB NzKJxsMC6cYiFRiAT9G+H3+/OKgYwKoRkzvDBOebzTe4x7EWSscMnc9CRoKd2H2D/Nqh C+oOUhFZjrxJmEH3LCFHJ7i6CIHZzQtM2vpdyMFPBkFYNnEh5SKf2EaI94pjKMRbdVbb a63d/4TkqAvQvQfnrTnnrwpV6ES6efowemc5Ixo+hXKNvxPvGIvYAQ3gf+/oMooLbeu4 QRDMknsJUSPIT9gXBOhW1ZR+TqTxEK4QHMAhyw6lgf/j7LBflNCdGp2CoTPUE3Sr4rMH V1PA== 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:dkim-signature:arc-authentication-results; bh=FZMlQBMhh07DmOBi2DGoVVI03OLIvxkX/Fpl6PeiGfg=; b=riYi43ty96NyjdISNSNOR1+6ptvo4zepOR6NY7Tt0VF+XiGXTgNgHpIy9ezZkSnvVe FZA0Cl4meQPvHgtWbM2hpGM3sSvwlqdW4pLaqDT2/bos6fZQTNREkyJl8n32dx//eqPO Ac0LNfV39qmzHjdUkVXpz+MK0e5g3ddu+VvneDN72MpVi14iaSFCR0gPPPtNny8jMboA AMULMlvxrgf8YQADvFu2tiVJHbvh4FAMQLYIOsVhR2VACdgt86bbOmu750P54sHQQ127 MKfPn+aven3b9tPcSbd/yxrPpwVB2fYpC6RzAJO1cP3onzpjyk/Dk/OWnvgaELIpI3w7 ph4g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=merlin.20170209 header.b=LwCtF40f; 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 o20-v6si622839pgb.614.2018.07.03.02.24.27; Tue, 03 Jul 2018 02:24:41 -0700 (PDT) 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; dkim=fail header.i=@infradead.org header.s=merlin.20170209 header.b=LwCtF40f; 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 S933614AbeGCJWm (ORCPT + 99 others); Tue, 3 Jul 2018 05:22:42 -0400 Received: from merlin.infradead.org ([205.233.59.134]:35426 "EHLO merlin.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932388AbeGCJWl (ORCPT ); Tue, 3 Jul 2018 05:22:41 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=merlin.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=FZMlQBMhh07DmOBi2DGoVVI03OLIvxkX/Fpl6PeiGfg=; b=LwCtF40fucB4YUNqiOmCD+V35 WOR3wc1m3RC4x7Kc+q7tjATzgAUZ1tQstTzAnGd0n615wRL7uTVHKLq++F/iSBiNPoWQqj4QgscKY Fd13LqUQPAD/pG9yTSTgdrY/dRUqmI6K2hngGXwKhHn06rS4ONoBAkODnNcezTvMowaj14LLfVpAg kVdvbmVi2bSZYcf+WbV+KkJA1D3VBoamwVpLEJQ3UZluvasbNEcOk49AOcT18RlxVJeLgHK+FFUoW Hy/3tlc87BPO6EaTNLlu5SAPkfx6A64TKnuSjs5lEmli1JJdVv1wUiW+7ZzHgKXq3KXSTOICnh4I8 jO2xPxuHw==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=hirez.programming.kicks-ass.net) by merlin.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1faHUq-0005UI-IE; Tue, 03 Jul 2018 09:21:16 +0000 Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id F3CDF2029F1DB; Tue, 3 Jul 2018 11:21:13 +0200 (CEST) Date: Tue, 3 Jul 2018 11:21:13 +0200 From: Peter Zijlstra To: Heiko Carstens Cc: Mathieu Desnoyers , Linus Torvalds , Andy Lutomirski , Thomas Gleixner , linux-kernel , linux-api , "Paul E. McKenney" , Boqun Feng , Dave Watson , Paul Turner , Andrew Morton , Russell King , Ingo Molnar , "H. Peter Anvin" , Andi Kleen , Chris Lameter , Ben Maurer , rostedt , Josh Triplett , Catalin Marinas , Will Deacon , Michael Kerrisk , Joel Fernandes , michal.simek@xilinx.com, Martin Schwidefsky , Vasily Gorbik Subject: Re: [RFC PATCH for 4.18] rseq: use __u64 for rseq_cs fields, validate user inputs Message-ID: <20180703092113.GV2494@hirez.programming.kicks-ass.net> References: <1959930320.10843.1530573742647.JavaMail.zimbra@efficios.com> <8B2E4CEB-3080-4602-8B62-774E400892EB@amacapital.net> <459661281.10865.1530580742205.JavaMail.zimbra@efficios.com> <858886246.10882.1530583291379.JavaMail.zimbra@efficios.com> <1776351430.10902.1530585009519.JavaMail.zimbra@efficios.com> <20180703081449.GT2494@hirez.programming.kicks-ass.net> <20180703082955.GH3704@osiris> <20180703084312.GU2494@hirez.programming.kicks-ass.net> <20180703085546.GJ3704@osiris> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180703085546.GJ3704@osiris> User-Agent: Mutt/1.10.0 (2018-05-17) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jul 03, 2018 at 10:55:46AM +0200, Heiko Carstens wrote: > > > > The problem is interrupts; we need interrupts on the CPU doing the store > > to observe either the old or the new value, not a mix. > > > > If mvcos does not guarantee that, we're having problems. Is there a > > reason get_user() cannot use a 'regular' load? > > Well, that's single instruction semantics. This is something we actually > can guarantee, since the mvcos instruction itself won't be interrupted and > copies all 1/2/4/8 bytes in a row. > > So we are talking about that single instructions are required and not > atomic accesses? rseq is strictly task local. So from that pov single-copy atomic and single instruction semantics end up being very similar. The most complicated scenario would be where we interrupt the task, schedule it out, migrate it and resume execution on another CPU. In that case the second CPU also needs to observe a 'whole' value. But note that in that example there's a fair bit of ordering provided by the scheduler to ensure all the state from the old CPU is observed by the new CPU (on s390 just the rq->lock fiddling would imply a bunch of general memory barriers). So I think you're good... But yes, you raise an interresting point.