Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp242824iob; Mon, 2 May 2022 18:17:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy5bQBwRlC3yKa7OYjB8CZo9Fxad7Zi1dhK2iKDY7G6OK7PDUW7jXlqPJqABMoLQN7FKRpi X-Received: by 2002:a63:2357:0:b0:3c1:42fb:cd7f with SMTP id u23-20020a632357000000b003c142fbcd7fmr11935503pgm.468.1651540633442; Mon, 02 May 2022 18:17:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651540633; cv=none; d=google.com; s=arc-20160816; b=ih8tBYbKR4eCz1tRTrtU7ikjxiFh3eYyAdqIR65ttYpuak6ZOp1XLmxKyvS9sZzTlZ PCd1uQmLmbqwvAQzkwa/fDzktGsTlR5fMyvL/6Doph31CYoZyUvm9yi/DLHGlVgLie+V t47HKBfsmnRGVMAjLcWBIXInQDD8wO3cTao+M2/YJ2QgIfz/TdUNmTIvSmVN+0ihNGnT FYB31PfigAOzQq3Zn+p0TrtWG1waZCgK3E9+CnMHOm+JVHGaaSilj5unJ3dSla/t8iV4 /h5vimhOxwOsQWqAQ7nHCbsBlz0sb3DDZjB39BgyHQZFukVT7bVb6gY8K1vzyOpkU5gf 0VAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:subject:user-agent:mime-version:date:message-id :dkim-signature; bh=UK4UjZH71X3EUoef8c/h5m7QQlnYpArG780O4uR8mE8=; b=DCrKmF7jen2RReJg+6jVbuVERuDOmLvfHXrdcBuEt0Ib+i7+IMNdgZmAvwJDZJb3dZ 0yVNLi5eOBqNMWaNndfyTq1Qr5D6Dnz4CDJ9i6bjW0KKoRCyvwE0wBXrEBsI1Wp0tYJd 0hGvJDC0pmnVzvd9Va73Q6GstO7Lt34tJJPAYRDxG0w7Bsv+1/p8c1QWuI0xVXNGw6uS qf+i8ANsrGifuvJM8eXH8j0lDRTBUhZv8txprTdW8ipfYkOQWSwvLrITpWT3Eq1c9DzZ xw0HZ6C6BVnLj845NOHdlFSG3a7YaWGGSf2YXrSzj2K5bWu7dacfmrMqyFfIGpg/59+4 ovcw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20210112.gappssmtp.com header.s=20210112 header.b=g5RyF3wo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id i35-20020a635423000000b003822f3c78cfsi15952926pgb.683.2022.05.02.18.17.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 02 May 2022 18:17:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@bytedance-com.20210112.gappssmtp.com header.s=20210112 header.b=g5RyF3wo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id CED4249F21; Mon, 2 May 2022 17:56:50 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1382255AbiD3H15 (ORCPT + 99 others); Sat, 30 Apr 2022 03:27:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54734 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232414AbiD3H1z (ORCPT ); Sat, 30 Apr 2022 03:27:55 -0400 Received: from mail-pj1-x1029.google.com (mail-pj1-x1029.google.com [IPv6:2607:f8b0:4864:20::1029]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7C29E84EC8 for ; Sat, 30 Apr 2022 00:24:33 -0700 (PDT) Received: by mail-pj1-x1029.google.com with SMTP id a15-20020a17090ad80f00b001dc2e23ad84so340936pjv.4 for ; Sat, 30 Apr 2022 00:24:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20210112.gappssmtp.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:to:cc:references :from:in-reply-to:content-transfer-encoding; bh=UK4UjZH71X3EUoef8c/h5m7QQlnYpArG780O4uR8mE8=; b=g5RyF3woRn6ot+TgA+Jqb9YI0Svu39gOBN9h/atb0554eqK2GyDbA1nt9g5wLkjyHe MKkNFhYfu4RdLhFGsuN+pGMOFUeXSQsWKL5SC64mMWl9GJ7sROZdNuxOhFVEusZJO6tw R4K/bvVEGeWjnNO+qTIO8DE+U97d0ki8qfZCXyM4zdc2VbY+EVVAaMwW3Q5n9RP5D6E2 0F9G03ZiuICl4EpfmGxBstWKQwtvn6c4nozX4cTwffsCkAI3fZ0xYv9I+udbwkLTf688 RcRlZNtp8/LCOJt90aQtl8d+ca82uhQC/dSg9la+cEOu7nqWr5nKjJYg0avsiguXK9VN RG7g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :to:cc:references:from:in-reply-to:content-transfer-encoding; bh=UK4UjZH71X3EUoef8c/h5m7QQlnYpArG780O4uR8mE8=; b=R+J0R47FVs67RPyBeYtnUDTQA9NC3hCHb3UB1JCwY1Hs0H+Bla5EughQxEg0iGBwZ/ f3ljICgdaowIHt79hTzDsPdwAXJM1JMJNrzJ/BXpDsdIrn5r8PSsy1qdtYAMsp4/4X24 Hcf/mkm3teVPM6LNNhuT4r8uzQjFs8BpbHE1ISbkX4+2wUlp+YH2Z3RGzpz60mlDSG6q kK0IfVCSyyWZS2PbEbSr3bWCCf6iIWne7SEpQK5CJJEdVlsERNhEPzHK/S9vo1wi5eNf 5VBcBV/qsiVd/rXuf9XpcZlGp64D7fE/5vnG4AlL0z5lB7Qg3CXaICvMkD7L+gbFIisF Op2g== X-Gm-Message-State: AOAM531rGq5AfloVgyV6FFGLo53EvsE1fmibvPwcc3AhFxzjy9Z1/uCN iQUZFLdG651bnvsSJy1xDMYVjw== X-Received: by 2002:a17:90b:314d:b0:1db:c8b6:e9d0 with SMTP id ip13-20020a17090b314d00b001dbc8b6e9d0mr3014471pjb.99.1651303472649; Sat, 30 Apr 2022 00:24:32 -0700 (PDT) Received: from ?IPV6:240e:390:e65:5bb0:6169:3d99:b5ff:4a84? ([240e:390:e65:5bb0:6169:3d99:b5ff:4a84]) by smtp.gmail.com with ESMTPSA id a8-20020a17090a6d8800b001cd4c118b07sm12464784pjk.16.2022.04.30.00.24.28 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sat, 30 Apr 2022 00:24:32 -0700 (PDT) Message-ID: <9b411c72-eda8-e98f-4e03-526ea645a7db@bytedance.com> Date: Sat, 30 Apr 2022 15:24:26 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:91.0) Gecko/20100101 Thunderbird/91.8.1 Subject: Re: [External] Re: [PATCH v3 1/2] sched/core: Avoid obvious double update_rq_clock warning To: Dietmar Eggemann , mingo@redhat.com, peterz@infradead.org, juri.lelli@redhat.com, vincent.guittot@linaro.org, rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de, bristot@redhat.com Cc: linux-kernel@vger.kernel.org References: <20220427080014.18483-1-jiahao.os@bytedance.com> <20220427080014.18483-2-jiahao.os@bytedance.com> <0058249a-5f9f-9f67-db5b-f7c3c10c3729@arm.com> From: Hao Jia In-Reply-To: <0058249a-5f9f-9f67-db5b-f7c3c10c3729@arm.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-3.5 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, NICE_REPLY_A,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2022/4/29 Dietmar Eggemann wrote: > On 27/04/2022 10:00, Hao Jia wrote: > > [...] > > LGTM, comments are only nit-picks. > >> Since we directly use raw_spin_rq_lock() to acquire rq lock instead of >> rq_lock(), there is no corresponding change to rq->clock_update_flags. >> In particular, we have obtained the rq lock of other cores, > > s/cores/CPUs, with SMT, a core can have multiple (logical) CPUs. Thanks for your review comments. I will do it in patch v4. Thanks. > > [...] > >> So we need to clear RQCF_UPDATED of rq->clock_update_flags synchronously >> to avoid the WARN_DOUBLE_CLOCK warning. > > Why you mention `synchronously` here? Isn't this obvious? (1) I will do it in patch v4. Thanks. > > [...] > >> @@ -1833,6 +1833,7 @@ select_task_rq_dl(struct task_struct *p, int cpu, int flags) >> static void migrate_task_rq_dl(struct task_struct *p, int new_cpu __maybe_unused) >> { >> struct rq *rq; >> + struct rq_flags rf; > > - struct rq *rq; > struct rq_flags rf; > + struct rq *rq; > > Use reverse fir tree order for variable declarations. > (./Documentation/process/maintainer-tip.rst) I will do it in patch v4. Thanks. > > [...] > >> +#ifdef CONFIG_SCHED_DEBUG >> +/* >> + * In double_lock_balance()/double_rq_lock(), we use raw_spin_rq_lock() to acquire >> + * rq lock instead of rq_lock(). So at the end of these two functions we need to >> + * call double_rq_clock_clear_update() synchronously to clear RQCF_UPDATED of > ^^^^^^^^^^^^^ > (1) > >> + * rq->clock_update_flags to avoid the WARN_DOUBLE_CLOCK warning. >> + */ >> +static inline void double_rq_clock_clear_update(struct rq *rq1, struct rq *rq2) >> +{ >> + rq1->clock_update_flags &= (RQCF_REQ_SKIP|RQCF_ACT_SKIP); >> + /* >> + * If CONFIG_SMP is not defined, rq1 and rq2 are the same, >> + * so we just clear RQCF_UPDATED one of them. >> + */ > > Maybe shorter: > > /* rq1 == rq2 for !CONFIG_SMP, so just clear RQCF_UPDATED once. */ I will do it in patch v4. Thanks. > > [...] > >> @@ -2543,14 +2564,15 @@ static inline int _double_lock_balance(struct rq *this_rq, struct rq *busiest) >> __acquires(busiest->lock) >> __acquires(this_rq->lock) >> { >> - if (__rq_lockp(this_rq) == __rq_lockp(busiest)) >> - return 0; >> - >> - if (likely(raw_spin_rq_trylock(busiest))) >> + if (__rq_lockp(this_rq) == __rq_lockp(busiest) || >> + likely(raw_spin_rq_trylock(busiest))) { > > indention: > > if (__rq_lockp(this_rq) == __rq_lockp(busiest) || > - likely(raw_spin_rq_trylock(busiest))) { > + likely(raw_spin_rq_trylock(busiest))) { Thanks again for your review and suggestion. I will do it in patch v4. Thanks. > > [...] > > Reviewed-by: Dietmar Eggemann > > Tested on Arm64 Juno with mainline & preempt-rt (linux-5.17.y-rt).