Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp523576iog; Fri, 17 Jun 2022 08:04:45 -0700 (PDT) X-Google-Smtp-Source: AGRyM1vi5t4kdIx7vCuvS9yGIyF4ynm2eP4ODX4Ccm2HiGbkT7J3CnPzI/k98gU/tEX2qexfjKZr X-Received: by 2002:a05:6402:11d1:b0:433:4a09:3f49 with SMTP id j17-20020a05640211d100b004334a093f49mr12820330edw.357.1655478285089; Fri, 17 Jun 2022 08:04:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655478285; cv=none; d=google.com; s=arc-20160816; b=JvWNHaVrt9TSHMbUlCLDtk5uSNXK6/druz2FyIE72rXz4xyBC3wlWTBOl0rIMrGhBB 2XvFnicl8/N2LGrxzCQgYj32pBcAF3jqiXDsL4NnzI4rNZ5F3foTeZv0e8hgS3eSPdZ1 cFXJCKoWWQJsRmtY3I7dFLIR2pdfnInJKBjEFMb6fF+Grimknk2LEmE5dE5T/jutNP0e dzVpLhDJEMf6lZbyfHhnuWhCMiCyii/exkpDWvqJDJm78pouK1y2tSneAmP9JP8TCjJ0 bU6MVp/fyKcNb9fYc7Agm94PrxanwjuIl90dgcD7ByBe2/3hJt5ghcQTe2p96R8SSVgo t4Xw== 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:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=ONdx8UrD/iFgfBJOk2FUQJlKyfF0Fn1r/7hliPk7HK0=; b=gpTty12T+8TZbPGzitSvRDZ+ZeCW9tKasroZDVJ+8jVsAmfhaGSF8aOISek82GBXYy 2Qglom/Uzfv65Df3UmVeUQoG8N+af/G+NK2gbAsonVQns23AtFjxF6A5Xdva5nEiNxL6 Mwi3r44jn4OpRdGgni4HSDaJL5tsorMHoKeES+IeYPg6PIJtHyI09WcQXhsD99Fv1ha4 067ufmLL4W572d4g92+4Nr9R2Hp9+WEbOpeX/sCZmWqXvDIjd1BvsxJynynNIjipW7Fq NgzbvC2WMUlOstuav23G4IeCQgU7h1IHy/fxupzt3/FcbCfEeZLLw/PsGLD9fvTY5Eq5 6Pig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KSGaJBw2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id m10-20020a056402430a00b0042aac548ac8si86785edc.405.2022.06.17.08.04.18; Fri, 17 Jun 2022 08:04:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KSGaJBw2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1382784AbiFQPAm (ORCPT + 99 others); Fri, 17 Jun 2022 11:00:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33508 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1381652AbiFQPAl (ORCPT ); Fri, 17 Jun 2022 11:00:41 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 7C17B3B552 for ; Fri, 17 Jun 2022 08:00:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1655478039; 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=ONdx8UrD/iFgfBJOk2FUQJlKyfF0Fn1r/7hliPk7HK0=; b=KSGaJBw2XkfBG6L63aEoILl3XFFjEJfE3LQ1Oyi+Fir+QpPrHFJz9jHNf66WO89Pwe3HvU SZgbpVOWkqTjINd+PsUqY7aQ0sVib5qEB49LmIjnT6e9yUkQYlaosQiC9/tCr+JMRZGrGW TjqwmGmse+GYIS0DZGi2w8EjOf2RROk= Received: from mimecast-mx02.redhat.com (mx3-rdu2.redhat.com [66.187.233.73]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-547-hVOxLB2yNgenoGphNrK42w-1; Fri, 17 Jun 2022 11:00:28 -0400 X-MC-Unique: hVOxLB2yNgenoGphNrK42w-1 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.rdu2.redhat.com [10.11.54.1]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 4B8D93810D20; Fri, 17 Jun 2022 15:00:28 +0000 (UTC) Received: from [10.22.18.98] (unknown [10.22.18.98]) by smtp.corp.redhat.com (Postfix) with ESMTP id D18FD40CFD0A; Fri, 17 Jun 2022 15:00:27 +0000 (UTC) Message-ID: <2730b855-8f99-5a9e-707e-697d3bd9811d@redhat.com> Date: Fri, 17 Jun 2022 11:00:27 -0400 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.9.1 Subject: Re: [PATCH] locking/rwlocks: do not starve writers Content-Language: en-US To: Shakeel Butt Cc: Peter Zijlstra , Eric Dumazet , Linus Torvalds , linux-kernel , Eric Dumazet , Ingo Molnar , Boqun Feng , Will Deacon , Roman Penyaev References: <20220617091039.2257083-1-eric.dumazet@gmail.com> <2dd754f9-3a79-ed17-e423-6b411c3afb69@redhat.com> From: Waiman Long In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.84 on 10.11.54.1 X-Spam-Status: No, score=-5.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_LOW,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham 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 6/17/22 10:57, Shakeel Butt wrote: > On Fri, Jun 17, 2022 at 7:43 AM Waiman Long wrote: >> On 6/17/22 08:07, Peter Zijlstra wrote: >>> On Fri, Jun 17, 2022 at 02:10:39AM -0700, Eric Dumazet wrote: >>>> --- a/kernel/locking/qrwlock.c >>>> +++ b/kernel/locking/qrwlock.c >>>> @@ -23,16 +23,6 @@ void queued_read_lock_slowpath(struct qrwlock *lock) >>>> /* >>>> * Readers come here when they cannot get the lock without waiting >>>> */ >>>> - if (unlikely(in_interrupt())) { >>>> - /* >>>> - * Readers in interrupt context will get the lock immediately >>>> - * if the writer is just waiting (not holding the lock yet), >>>> - * so spin with ACQUIRE semantics until the lock is available >>>> - * without waiting in the queue. >>>> - */ >>>> - atomic_cond_read_acquire(&lock->cnts, !(VAL & _QW_LOCKED)); >>>> - return; >>>> - } >>>> atomic_sub(_QR_BIAS, &lock->cnts); >>>> >>>> trace_contention_begin(lock, LCB_F_SPIN | LCB_F_READ); >>> This is known to break tasklist_lock. >>> >> We certainly can't break the current usage of tasklist_lock. >> >> I am aware of this problem with networking code and is thinking about >> either relaxing the check to exclude softirq or provide a >> read_lock_unfair() variant for networking use. > read_lock_unfair() for networking use or tasklist_lock use? I mean to say read_lock_fair(), but it could also be the other way around. Thanks for spotting that. Cheers, Longman