Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp783038ybp; Fri, 11 Oct 2019 04:24:34 -0700 (PDT) X-Google-Smtp-Source: APXvYqxOSiIx1zqJtdMaF3BOp91iKaSPY0Dk3NML8tuwJeaPRo6Va0Fn1yx4z6dkSK8lXzCuCT35 X-Received: by 2002:a17:906:4a97:: with SMTP id x23mr12801919eju.218.1570793074371; Fri, 11 Oct 2019 04:24:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570793074; cv=none; d=google.com; s=arc-20160816; b=mfr7nxD/OIbaQ56QJsJM2Dn5YN93IoYCveXAyDdaUA9x8cLJxpNeQ6dA9yoYJeMEEx /3XEbzBaQWTrKunXc1qTzeNqD7TXb41GE5cgcGg6xACHIhM6hw9CPbw1QhPHkafIuj61 2vW8c6L4izeJ/3imuGa0JEnk1bLeqmDADD9imzX9Z8FcljuZJTjuzHUZrBSmnDVYVnU2 zzx1zzx26Q67wNtAmy/MPzLgxN97iEUsG0G4LSNHLVjj9FPPMNoO1jKgWzQRyL+dXP34 aCYEjds9kgVOi0L3pho+FCce0I8xBNJSFkA3/qNpbkrxgPZ6zGGOFVJCWSUjt1hEo9IA q76Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=fPvm5aKUo3m6VNUgMDaYDplQQ9+Y7qvr7iXnVapNqxw=; b=OEWRHAFMqPYhTQhGuWO5qSqcEAqbz2Z7TVduVC30eQEN3DSfoTHCOBWtxCoGIcG5uK sCMN3x2zol3MwOwk+LW/4+lbU3dDw7DFshO7FKBr/+o7uA1s30+fttCv1wkRJsFufEjw bBsbR2xpYCa61F6+qQUqQ5n1dd60SxStjAgFaX5ZgAJnm4MwxyGZ8o8WecbMRBV2uiX5 kiHTQMo0WEjzbciGL40BwpXqH2/My+merCreos2oMekqhk2T5AXKP1CHgixtGpEkgi4t INYFAGceegnbei7Uwtn49C4pvI2fy8HYDaJddPLys5+TBJDCUWomSXvLuNPmLV3e8Tlk y/Jg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@colorfullife-com.20150623.gappssmtp.com header.s=20150623 header.b=0QpWmJT3; 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 k6si5079473eji.137.2019.10.11.04.24.10; Fri, 11 Oct 2019 04:24:34 -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=pass header.i=@colorfullife-com.20150623.gappssmtp.com header.s=20150623 header.b=0QpWmJT3; 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 S1727892AbfJKLUU (ORCPT + 99 others); Fri, 11 Oct 2019 07:20:20 -0400 Received: from mail-wm1-f67.google.com ([209.85.128.67]:54357 "EHLO mail-wm1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727226AbfJKLUT (ORCPT ); Fri, 11 Oct 2019 07:20:19 -0400 Received: by mail-wm1-f67.google.com with SMTP id p7so10022189wmp.4 for ; Fri, 11 Oct 2019 04:20:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=colorfullife-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=fPvm5aKUo3m6VNUgMDaYDplQQ9+Y7qvr7iXnVapNqxw=; b=0QpWmJT3DMoGSvj9aESlR0hwdw5Ii86mJL9w/2qZ8Gp/B0PfF59v1jfPslInshWm+c +eF0+aK+OK7KiQIimaFgI5ZkvO/PK5agOuk2isVINYlpfgFD3SdOhUqG9UemAQGn9mj0 lJE6aDaOMTCyp+1k6FndB/evKKVh2Kyfv/7IgL7tw3ya+UlmIRQeruFrQ6p1CYFWldoQ op2v4O6trr+9rhU8tQyMPeWQSkTa1MIBOpDCMuF6AFr2gNRlsle7Cf5R1Fvjpl2HvjZH sV7X/fZHfcHXw0uddKP/3F8eVg18qfx0d+GcO4nuvzFEWoFJph2YK0Yiay3CXMruaxz9 /EVQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=fPvm5aKUo3m6VNUgMDaYDplQQ9+Y7qvr7iXnVapNqxw=; b=HhLat8gbHqiY1GxzpG7EqsU9O7Uboyavo6ipUyuqdscVRr6HuajUUg49pLls/Ok9Sn P6YYoPlSxrXCGoAs9WABDVpA4eVZsu4rux1EPZQf3GdoBgT/CBUSq2B7EFDSzmjGKQln vu15Fkd0H76v61Gv5EOKNWREEOhDZBjcdVZR57DMvaOGJYIsBodQ69hOJwPFCO3z/ym+ C2ebHtq3w1/Xxvu+dRs631XSaNBiqWJvBhsnxSivpjXuxZmFaiiw39XC4eE/TY+u5xeL fznqCTkgfTgUin3yi1W7+lT+4ou5LwUauZ5wXuY18ThPSLOIBNSEZyjCIOb9hZPVxwjP Mt0Q== X-Gm-Message-State: APjAAAVe0PCys9Exa7alilQQ1ft+UtKD9h51eT26R4Yf3ZP7MHKyboy3 vbOQLk1ZQ685XVIxSVn2YcpWIPPe81c= X-Received: by 2002:a05:600c:34b:: with SMTP id u11mr2725338wmd.172.1570792817334; Fri, 11 Oct 2019 04:20:17 -0700 (PDT) Received: from linux.fritz.box (p200300D99705BE00E22045ECB41D901D.dip0.t-ipconnect.de. [2003:d9:9705:be00:e220:45ec:b41d:901d]) by smtp.googlemail.com with ESMTPSA id 63sm12781226wri.25.2019.10.11.04.20.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Oct 2019 04:20:16 -0700 (PDT) From: Manfred Spraul To: LKML , Davidlohr Bueso , Waiman Long Cc: 1vier1@web.de, Andrew Morton , Peter Zijlstra , Jonathan Corbet , Manfred Spraul Subject: [PATCH 1/5] wake_q: Cleanup + Documentation update. Date: Fri, 11 Oct 2019 13:20:05 +0200 Message-Id: <20191011112009.2365-2-manfred@colorfullife.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20191011112009.2365-1-manfred@colorfullife.com> References: <20191011112009.2365-1-manfred@colorfullife.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 1) wake_q_add() contains a memory barrier, and callers such as ipc/mqueue.c rely on this barrier. Unfortunately, this is documented in ipc/mqueue.c, and not in the description of wake_q_add(). Therefore: Update the documentation. Removing/updating ipc/mqueue.c will happen with the next patch in the series. 2) wake_up_q() relies on the memory barrier in try_to_wake_up(). Add a comment, to simplify searching. 3) wake_q.next is accessed without synchroniyation by wake_q_add(), using cmpxchg_relaxed(), and by wake_up_q(). Therefore: Use WRITE_ONCE in wake_up_q(), to ensure that the compiler doesn't perform any tricks. Signed-off-by: Manfred Spraul Cc: Davidlohr Bueso --- kernel/sched/core.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/kernel/sched/core.c b/kernel/sched/core.c index dd05a378631a..2cf3f7321303 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -440,8 +440,11 @@ static bool __wake_q_add(struct wake_q_head *head, struct task_struct *task) * @task: the task to queue for 'later' wakeup * * Queue a task for later wakeup, most likely by the wake_up_q() call in the - * same context, _HOWEVER_ this is not guaranteed, the wakeup can come - * instantly. + * same context, _HOWEVER_ this is not guaranteed. Especially, the wakeup + * may happen before the function returns. + * + * What is guaranteed is that there is a memory barrier before the wakeup, + * callers may rely on this barrier. * * This function must be used as-if it were wake_up_process(); IOW the task * must be ready to be woken at this location. @@ -486,11 +489,14 @@ void wake_up_q(struct wake_q_head *head) BUG_ON(!task); /* Task can safely be re-inserted now: */ node = node->next; - task->wake_q.next = NULL; + + WRITE_ONCE(task->wake_q.next, NULL); /* * wake_up_process() executes a full barrier, which pairs with * the queueing in wake_q_add() so as not to miss wakeups. + * The barrier is the smp_mb__after_spinlock() in + * try_to_wake_up(). */ wake_up_process(task); put_task_struct(task); -- 2.21.0