Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp459218ybv; Fri, 7 Feb 2020 02:36:54 -0800 (PST) X-Google-Smtp-Source: APXvYqyx37B/f5E43l8u5Bd+XNH5JzEAl0SWiqdrorrXKqxNacqliKuwh3B5Y1hw4/8suzcZdEDp X-Received: by 2002:a05:6830:1d5b:: with SMTP id p27mr2043122oth.263.1581071813966; Fri, 07 Feb 2020 02:36:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581071813; cv=none; d=google.com; s=arc-20160816; b=LMBJE5/8ULIW+d83qQ15vjOwKi0tFLYSyK2xjQVTkChNCF0akR9TByC9lbunts7zsM MNeSh2poyd38GAVMTrgLqWy+3LUW9cBTRNbfnoDRUumy9jp/LgX8W8xicQVFgyJ2vyO2 C7hmjQt1/oN8VBwz7OQsMPtyFnzlxBiCPQREYz/21jlfNhM3l6CtrK6Cxx/74KX6asyL Q61vI953O8onshgTxIY7EgXAksnZlpdZx4xcX9PS3a2gz8ESoAz4pHZVuKvMah16t/Sk wcLx0OY1H6pQjqRqmniQHoCOesYiPq8gI8TbeO/a8PA6DZLXddUOCUfcnAujPrupF6Co 04PA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=1+MTBIq0dddTeP02GHBszdbSMO1SQaDx30ue5UHNPWs=; b=JrH2lsKSulfpY5ksDQ9p/ZBervRGWpkTn3y+1GxQq45H2DdJfYuEZAuYKnyzypYVlt PaBs3eqBYY471uz/swrFrLmmmKnP79TJnyeV0gSmyRuR+1DC8cCEwo2JXJQUbJ1L9bOA wUAs7EQ1IvdHWil1lJoGmrNQFmSi80PlIfD4IqSbXf+2P+WR8UMmx3eQVq0BT1iTyEws GrLpGqdjWtusGXYN856Ev7p+5Qer9vxhKoSvQS/Xp4wZ8X0vO/RuTWibj0H6++AnnxG+ mMBtNjoqHhTyWXGaigL6ZrOxc3e7ZLJsqQwlB/YltHDilG9Pe/RET14UbJ6dmXno8dnH p+JQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=DiBU9jLA; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r21si1383608ota.204.2020.02.07.02.36.42; Fri, 07 Feb 2020 02:36:53 -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; dkim=pass header.i=@google.com header.s=20161025 header.b=DiBU9jLA; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727041AbgBGKfd (ORCPT + 99 others); Fri, 7 Feb 2020 05:35:33 -0500 Received: from mail-oi1-f195.google.com ([209.85.167.195]:40498 "EHLO mail-oi1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726587AbgBGKfc (ORCPT ); Fri, 7 Feb 2020 05:35:32 -0500 Received: by mail-oi1-f195.google.com with SMTP id a142so1503555oii.7 for ; Fri, 07 Feb 2020 02:35:32 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=1+MTBIq0dddTeP02GHBszdbSMO1SQaDx30ue5UHNPWs=; b=DiBU9jLAkQjbewdrjbN+1qdsEGrM7DQgqmJwn78UhocpmXvfy+9CYnCnS3s/Zg1Mhe b04TsiLHoe2b2HGAKkuVJjOmgtZKPx8ffA85ExkeOeNb6xAoIsHvmOIljZOPhL+VV3eG VwqGygg5Nn89oUfUonQfqxTO+mzPwubcdtuzKQS27iIUF7K8kH3+y2HDxXxvfhGLqiE4 obHccYxYoZdexU1OkIqzOtg3dQuAp7YizUPKpI+Rd5vcjY7kOHox9L28mdqLReEdtlRq IoOsBrDnDrwSJIFHBMFJEw960ttZIx5Vpm8LQBY3TRL1jpHMYqWjaP2z8hFAoKkzjwdQ KMvg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=1+MTBIq0dddTeP02GHBszdbSMO1SQaDx30ue5UHNPWs=; b=tbEyP+Q7ZULw8scHC6sg12HeGuQQWDgOaW/38zYoBFG/u5XrUDYyHnjcxQ7Ss4598N IyPwo64CddepkCwLgdFOTAMc+YYxR3HWBBduBK+7jNr24YmJ7tnj7ZXZqTk+x0INUNfc JXUPnNpdaFebFBcjXJcLxkUk4/2ck1e2wi+pOfBh/XjSKY2QEuoVZU571qnQGBPR/CY7 aFF3G+2UjOFbBKOuYDHy3FA9/9jaoQLO7UEJASEHMBIAYPgHaK+ISz3l6UYGLMfo2n9N JHlc+4mxgMkr79yvCj6p5/JRbpTH4VR7SAc6drElMhax08vilgiol+gmmqG/oxKIGY+Z QLuw== X-Gm-Message-State: APjAAAWIWuu2iLLP19JvdZ7EP9cxBHo1+0NY7rKCYW1fCjPpFOKum7+E tvBj7+XmarECPGOWXSgc4+eULd5pJugCO581CbvKoA== X-Received: by 2002:aca:c7ca:: with SMTP id x193mr1638203oif.70.1581071732047; Fri, 07 Feb 2020 02:35:32 -0800 (PST) MIME-Version: 1.0 References: <1580841629-7102-1-git-send-email-cai@lca.pw> <20200206163844.GA432041@zx2c4.com> <453212cf-8987-9f05-ceae-42a4fc3b0876@gmail.com> In-Reply-To: <453212cf-8987-9f05-ceae-42a4fc3b0876@gmail.com> From: Marco Elver Date: Fri, 7 Feb 2020 11:35:20 +0100 Message-ID: Subject: Re: [PATCH v3] skbuff: fix a data race in skb_queue_len() To: Eric Dumazet Cc: "Jason A. Donenfeld" , Qian Cai , netdev@vger.kernel.org, LKML Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 6 Feb 2020 at 18:10, Eric Dumazet wrote: > > > > On 2/6/20 8:38 AM, Jason A. Donenfeld wrote: > > Hi Eric, > > > > On Tue, Feb 04, 2020 at 01:40:29PM -0500, Qian Cai wrote: > >> - list->qlen--; > >> + WRITE_ONCE(list->qlen, list->qlen - 1); > > > > Sorry I'm a bit late to the party here, but this immediately jumped out. > > This generates worse code with a bigger race in some sense: > > > > list->qlen-- is: > > > > 0: 83 6f 10 01 subl $0x1,0x10(%rdi) > > > > whereas WRITE_ONCE(list->qlen, list->qlen - 1) is: > > > > 0: 8b 47 10 mov 0x10(%rdi),%eax > > 3: 83 e8 01 sub $0x1,%eax > > 6: 89 47 10 mov %eax,0x10(%rdi) > > > > Are you sure that's what we want? > > > > Jason > > > > > Unfortunately we do not have ADD_ONCE() or something like that. > > Sure, on x86 we could get much better code generation. > > If we agree a READ_ONCE() was needed at the read side, > then a WRITE_ONCE() is needed as well on write sides. > > If we believe load-tearing and/or write-tearing must not ever happen, > then we must document this. Just FYI, forgot to mention: Recent KCSAN by default will forgive unannotated aligned writes up to word-size, making the assumptions these are safe. This would include things like 'var++' if there is only a single writer. This was added because of kernel-wide preferences we were told about. Since I cannot verify if this assumption is always correct, I would still prefer to mark writes if at all possible. In the end it's up to maintainers. Thanks, -- Marco