Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp463914pxx; Wed, 28 Oct 2020 08:56:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyHAjK48ZFq6QhOYa1h33xOhbjzWVykZakgTEQNO/I7z1UvQUaEYfYjNmA8QNes+nYcPfk6 X-Received: by 2002:a17:906:1f08:: with SMTP id w8mr8155400ejj.181.1603900591953; Wed, 28 Oct 2020 08:56:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603900591; cv=none; d=google.com; s=arc-20160816; b=GMr7ABCzCAndkKOTwnzF3Ib1XaecBb1U5Xd2qRe/Vs4dWMxYn7ovVkaQ5eGKRCY+/I ynvxJ0IJNNoyTt9064xoCgb3yA8eMfFWFS19HYLzlWYVjzncLCpXbRaZUukVa+o2qtqD ke0zsFU+ViV5L+pTJMsTfZHhUQB3kDyh61UGVWoInFo5mq8Rj9o0jZp+5yWh5lKQsezr VxDQXvo+7XLJ0mhQzHxsjQUxz7FxJdN65xZ78wybgUWOP7x8SCWiOY5yGsjvadVZhjEc AdIsvib/dqRUhlsS8tc64Q76Q3O9qaWdYMaLzL/Tz9TwvhfplEgzy1mL7+qXypGgEfVM qDog== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:sender:dkim-signature; bh=nuxxs/Px/9QpRIlm7J+PyL0HWcASsbcWXqWCTDpjZLY=; b=RoWm9oa1eThL/aDigfu0iaqYa6GdaqhqqcI286ZD2Zvwe5Po+DVEXs1JucS88s1kBE SdCFoUby+k7j3LhEO3FWmWOufj8mFWD8p5y3JOL8/QdBGjubBz4A7CTObMHYwR1Vr7/N xpJReHF95/TjugdkFM96en/p+27S3eXOX05/ifuQuKjnzhFuTsrzpSXyoGL5ixZPnMTS KNzOE4X1oEK6M4XFaCvlth2arMkbVLxJFGc0yc1XbtspFV50VIFxfk3XOvmbjtNgi22f hjB5SWFmR2Vplhxm2bJiNKUHxqbSPrp5Ms6Vp/+ytyOiDr5rRZrDT0ZLj6g0lRl4op7T GSwg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=SGQLLWiB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id p17si2879649ejg.48.2020.10.28.08.56.09; Wed, 28 Oct 2020 08:56:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=SGQLLWiB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1813514AbgJ0Quh (ORCPT + 99 others); Tue, 27 Oct 2020 12:50:37 -0400 Received: from mail-pf1-f202.google.com ([209.85.210.202]:50978 "EHLO mail-pf1-f202.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1813389AbgJ0Qt5 (ORCPT ); Tue, 27 Oct 2020 12:49:57 -0400 Received: by mail-pf1-f202.google.com with SMTP id a27so1244654pfl.17 for ; Tue, 27 Oct 2020 09:49:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=sender:date:in-reply-to:message-id:mime-version:references:subject :from:to:cc; bh=nuxxs/Px/9QpRIlm7J+PyL0HWcASsbcWXqWCTDpjZLY=; b=SGQLLWiB+LUjaqR1TSdlpCpxrsi+POAiH2xjFLEZiQ/Wy8axJ7MQAwv6yJG4RQFjVH 2Bde6HUbl3/5tLJBqO2GGocfLTNhD4piiEGuFcTE3tNlCR/vOkEweNCcRo8i7U2fOu0+ UigavmfeQIAdOyfoCOq2wOlrR79bpk/B9bpd91hzS8apgFhVrwDZTlzlp/XoK5RIrc7U EgtcREjXUgluwLgZ/dBJ5fEwwxTQeMMERb5hdHFyDyg3jdX/f8TcLnKuVuBqHWDSO/Vf KMxOlowmn6ogA67Z+poRwIIIfbhDDnFdxm80hDvd3shtA5cXQWT1psAvvLBLUm4epcsX KbqQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=nuxxs/Px/9QpRIlm7J+PyL0HWcASsbcWXqWCTDpjZLY=; b=hZMceAJvmOdHlEFZUPO9kmSOEdCrtHytCGpDFZxJcdVqZWvst8YKjfKfw5gqq/g++0 qdXCfJ9OOG473rHKfSA9JhzRudTwSced5PpYONeyn9Gqegk2UHDqmPTr8qnVAecZVWuD JGDIbER8k+Dms6Sc25sA3+snDdSyD2x2lN5NUJmgQ6xaAWa6B4GXgT9FJa9kFqgbh2Hj duXhQBPSB9XQREN15oNSnSS4rGTB50UmUelItuG+KIM4G4zunON90imxcMKjo5RXNVAm uK0e3lPkBnn0eOAcTCHrLP+c3D/gPuntuQX/X2YzKANRuEUWJ0RJ5wQPoHvnzGovxlgS Dmbg== X-Gm-Message-State: AOAM530QwxRGNnUiy7ffyXMYbqYlEsDgDOY3WDj5bUOMD+LXVe8EkuaZ jReMpB/V4pSMor7w+ewQDwENLPN04WSfnkyAxey/XCx13S5aPmwqe4/9RahKR1bkPvph/4pGfMy GhIjTO3F+oiGDEEnB+6KE3SpZEybxbPKQ4/4II47LSCfjSZGcixnxmF1VXhotcx6XgWNzJT6+ Sender: "bgardon via sendgmr" X-Received: from bgardon.sea.corp.google.com ([2620:15c:100:202:f693:9fff:fef4:a293]) (user=bgardon job=sendgmr) by 2002:a62:8097:0:b029:153:ce1d:c46 with SMTP id j145-20020a6280970000b0290153ce1d0c46mr3179460pfd.68.1603817395887; Tue, 27 Oct 2020 09:49:55 -0700 (PDT) Date: Tue, 27 Oct 2020 09:49:49 -0700 In-Reply-To: <20201027164950.1057601-1-bgardon@google.com> Message-Id: <20201027164950.1057601-2-bgardon@google.com> Mime-Version: 1.0 References: <20201027164950.1057601-1-bgardon@google.com> X-Mailer: git-send-email 2.29.0.rc2.309.g374f81d7ae-goog Subject: [PATCH 2/3] sched: Add needbreak for rwlocks From: Ben Gardon To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Paolo Bonzini , Sean Christopherson , Peter Shier , Peter Zijlstra , Ingo Molnar , Will Deacon , Waiman Long , Davidlohr Bueso , Ben Gardon Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Contention awareness while holding a spin lock is essential for reducing latency when long running kernel operations can hold that lock. Add the same contention detection interface for read/write spin locks. Signed-off-by: Ben Gardon --- include/linux/sched.h | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/include/linux/sched.h b/include/linux/sched.h index 063cd120b4593..77179160ec3ab 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h @@ -1870,6 +1870,23 @@ static inline int spin_needbreak(spinlock_t *lock) #endif } +/* + * Check if a rwlock is contended. + * Returns non-zero if there is another task waiting on the rwlock. + * Returns zero if the lock is not contended or the system / underlying + * rwlock implementation does not support contention detection. + * Technically does not depend on CONFIG_PREEMPTION, but a general need + * for low latency. + */ +static inline int rwlock_needbreak(rwlock_t *lock) +{ +#ifdef CONFIG_PREEMPTION + return rwlock_is_contended(lock); +#else + return 0; +#endif +} + static __always_inline bool need_resched(void) { return unlikely(tif_need_resched()); -- 2.29.0.rc2.309.g374f81d7ae-goog