From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8307BC00140 for ; Wed, 24 Aug 2022 08:24:20 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id E63F56B0073; Wed, 24 Aug 2022 04:24:19 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id E133A6B0074; Wed, 24 Aug 2022 04:24:19 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id CB53A6B0075; Wed, 24 Aug 2022 04:24:19 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id BC5876B0073 for ; Wed, 24 Aug 2022 04:24:19 -0400 (EDT) Received: from smtpin02.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay05.hostedemail.com (Postfix) with ESMTP id 9029C40C51 for ; Wed, 24 Aug 2022 08:24:19 +0000 (UTC) X-FDA: 79833799038.02.3793AD3 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by imf30.hostedemail.com (Postfix) with ESMTP id 2ED6280037 for ; Wed, 24 Aug 2022 08:24:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1661329458; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=Alnumo20Oy3ca2IuzGzDSmL567uiguE1m7emVxPRSkQ=; b=J7HEcWEkZxu1Vu4ZsUANUZq9cuoxyGxD5N+USr1l7+lQa0Wkq8lrC9DUt1CaF0gfmXvDAx NQ7zfJDKqRNwOVkW3JJ6kVv8PuWzGAoVPIpPZqnYmY/R0fiJBG4K7d2ZFXfwURTFmvmGcu j42bsVPGdP7tDEkppRu4BP5bvDoqszA= Received: from mail-wm1-f69.google.com (mail-wm1-f69.google.com [209.85.128.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_128_GCM_SHA256) id us-mta-10-QzlOnmbMNCuCsz4FEmxhnQ-1; Wed, 24 Aug 2022 04:24:17 -0400 X-MC-Unique: QzlOnmbMNCuCsz4FEmxhnQ-1 Received: by mail-wm1-f69.google.com with SMTP id j3-20020a05600c1c0300b003a5e72421c2so1409743wms.1 for ; Wed, 24 Aug 2022 01:24:17 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:organization:from:references :cc:to:content-language:subject:user-agent:mime-version:date :message-id:x-gm-message-state:from:to:cc; bh=Alnumo20Oy3ca2IuzGzDSmL567uiguE1m7emVxPRSkQ=; b=KkYC7a5aOzY3YdWJdPepdA85uO2ffJuH18+CMJEOvn19R6NM0+X/m4DtmAteqTiGts PlB4Kph/lHKKcU8PkzhshxqXw8/P45Ca0IcASMf661+WaB1Uc8zYRvJZHo5cb1JsayPI xgg/pY4pg9PvAJgyNVL+Z3n5Ate5qL6jCLbyeMrQ4nY+6fVn61K8C4I+TEYcd5NkewCE JixMbi9P23xVwGbGEwv15OXaGlUVo7kgyI4n2cW19qZ47T8MfZk16QZuTfMMvAF3FYdf qHfiwq430vSMtQEA1ip72id9YyxG5GoXeCfP3mRh1c3NuvkMhAc/NBpXSeJbw8MiTyE1 LiXw== X-Gm-Message-State: ACgBeo3ChhJtB93Z8jKwwLQiB0GECOxbpnp1Vxz425Ynrcrvv9S38krM coNhLOIDiHHQ44f1FKLdXMvxggz6DvnKjhBO8hvlRVX10avIxWNp4bWLwoUfTWI92pGtWUi52BW +OUxwUvRSAqA= X-Received: by 2002:adf:eb4c:0:b0:220:6aaf:ef5e with SMTP id u12-20020adfeb4c000000b002206aafef5emr14863557wrn.488.1661329456457; Wed, 24 Aug 2022 01:24:16 -0700 (PDT) X-Google-Smtp-Source: AA6agR4DRt/CvtfFa7EIJB4D+MrT0BEPBR42D92q1aP42xUNrGosIyBAbzKLmB5DsyKJdDueEmCfaw== X-Received: by 2002:adf:eb4c:0:b0:220:6aaf:ef5e with SMTP id u12-20020adfeb4c000000b002206aafef5emr14863538wrn.488.1661329456139; Wed, 24 Aug 2022 01:24:16 -0700 (PDT) Received: from ?IPV6:2003:cb:c707:c500:5445:cf40:2e32:6e73? (p200300cbc707c5005445cf402e326e73.dip0.t-ipconnect.de. [2003:cb:c707:c500:5445:cf40:2e32:6e73]) by smtp.gmail.com with ESMTPSA id j30-20020a05600c1c1e00b003a31fd05e0fsm6646867wms.2.2022.08.24.01.24.15 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 24 Aug 2022 01:24:15 -0700 (PDT) Message-ID: Date: Wed, 24 Aug 2022 10:24:15 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.12.0 Subject: Re: [PATCH 2/2] mm: slince possible data races about pgdat->kswapd To: Kefeng Wang , Andrew Morton , linux-mm@kvack.org Cc: muchun.song@linux.dev, linux-kernel@vger.kernel.org References: <20220824071909.192535-1-wangkefeng.wang@huawei.com> <20220824071909.192535-2-wangkefeng.wang@huawei.com> From: David Hildenbrand Organization: Red Hat In-Reply-To: <20220824071909.192535-2-wangkefeng.wang@huawei.com> X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Language: en-US Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1661329459; a=rsa-sha256; cv=none; b=e9ZTEdaWFMCIH422cXZ8uf9fP636d/paCOuMQVr85xkr7uATRGYlzDHRk+1IQ4Z3Sdtdqm +TbUPEcxn8hPQZjnnrB9ZGlwRDgVpQidsGFiQrIsDtILbXOsNK0UNLGCV2IcECR3SaUrx8 yxzqLZ2tGaBqb8UNyT9vZuRwdR/4N44= ARC-Authentication-Results: i=1; imf30.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=J7HEcWEk; spf=pass (imf30.hostedemail.com: domain of david@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=david@redhat.com; dmarc=pass (policy=none) header.from=redhat.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1661329459; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=Alnumo20Oy3ca2IuzGzDSmL567uiguE1m7emVxPRSkQ=; b=RW/J8e8ZBoquOZ0qjJ5LAwJe2UByYxKeSelCHG8aZ4K0gdWpgQroChbHvvGeb5KIit8T6S 0Lu1F24wC7EO5j09u+fVFabvoniCfWdcRdaXdUTffJRYv3AQgUq0x2VUwiI2a728UqjPCY g7Eu0EVoUnt2z4DRYwv2JkoZzHTi+oc= X-Rspam-User: X-Rspamd-Server: rspam08 X-Rspamd-Queue-Id: 2ED6280037 Authentication-Results: imf30.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=J7HEcWEk; spf=pass (imf30.hostedemail.com: domain of david@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=david@redhat.com; dmarc=pass (policy=none) header.from=redhat.com X-Stat-Signature: med1g66sokow67dd6xy8qn5ug5zk97yb X-HE-Tag: 1661329458-485763 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On 24.08.22 09:19, Kefeng Wang wrote: > The pgdat->kswapd could be accessed concurrently by kswapd_run() and > kcompactd(), it don't be protected by any lock, which could leads to > data races, adding READ/WRITE_ONCE() to slince it. Okay, I think this patch here makes it clearer that we really just want proper synchronization instead of hacking around it. What speaks against protecting pgdat->kswapd this using some proper locking primitive? > > Signed-off-by: Kefeng Wang > --- > mm/compaction.c | 4 +++- > mm/vmscan.c | 8 ++++---- > 2 files changed, 7 insertions(+), 5 deletions(-) > > diff --git a/mm/compaction.c b/mm/compaction.c > index 640fa76228dd..aa1cfe47f046 100644 > --- a/mm/compaction.c > +++ b/mm/compaction.c > @@ -1983,7 +1983,9 @@ static inline bool is_via_compact_memory(int order) > > static bool kswapd_is_running(pg_data_t *pgdat) > { > - return pgdat->kswapd && task_is_running(pgdat->kswapd); > + struct task_struct *t = READ_ONCE(pgdat->kswapd); > + > + return t && task_is_running(t); > } > > /* > diff --git a/mm/vmscan.c b/mm/vmscan.c > index 08c6497f76c3..65b19ca8c8ee 100644 > --- a/mm/vmscan.c > +++ b/mm/vmscan.c > @@ -4644,7 +4644,7 @@ void kswapd_run(int nid) > pg_data_t *pgdat = NODE_DATA(nid); > struct task_struct *t; > > - if (pgdat->kswapd) > + if (READ_ONCE(pgdat->kswapd)) > return; > > t = kthread_run(kswapd, pgdat, "kswapd%d", nid); > @@ -4653,7 +4653,7 @@ void kswapd_run(int nid) > BUG_ON(system_state < SYSTEM_RUNNING); > pr_err("Failed to start kswapd on node %d\n", nid); > } else { > - pgdat->kswapd = t; > + WRITE_ONCE(pgdat->kswapd, t); > } > } > > @@ -4663,11 +4663,11 @@ void kswapd_run(int nid) > */ > void kswapd_stop(int nid) > { > - struct task_struct *kswapd = NODE_DATA(nid)->kswapd; > + struct task_struct *kswapd = READ_ONCE(NODE_DATA(nid)->kswapd); > > if (kswapd) { > kthread_stop(kswapd); > - NODE_DATA(nid)->kswapd = NULL; > + WRITE_ONCE(NODE_DATA(nid)->kswapd, NULL); > } > } > -- Thanks, David / dhildenb