Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp677260iog; Fri, 17 Jun 2022 11:03:33 -0700 (PDT) X-Google-Smtp-Source: AGRyM1syT9L14bZpK7wZB2Exyk7/PfmW3+EEYluM/H4Kj9Vmt/Rb5mdwBHMyr/XdNFLKJTEjDkt3 X-Received: by 2002:a17:90b:3b4c:b0:1e8:5e4d:ed83 with SMTP id ot12-20020a17090b3b4c00b001e85e4ded83mr22816772pjb.19.1655489013005; Fri, 17 Jun 2022 11:03:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655489012; cv=none; d=google.com; s=arc-20160816; b=ckwg+r1pz/3bOrb6OhX618A7+hFmOM5fV/Qcz8uG7BNOke00SMeqwg89he1bLtUFBk CZRblMBugF1ZECuHfKax4lqHee3+XExibKnTA3nDF16p3oYKhvmRAOGhr5anfbOtYWFQ NWzHzqEM5L6G57UriOURo8G35a6Yk6B0o4rwOq57frf4OQeBUKMV9VhBdqA6K7rCCrSC mCKdwDJ6kVvfj0KVovK+qwsqrKryHFi1mNz8tRP1GYshDL3F/E9kdYc86s3KSRBFgAeq KRgV1O53oSvnZ2rkb1eZahLHw0WZ2072ij16ncD7FnO4ifuK7eCmAnljVRi4lJlU43Gv /0fA== 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=ASCb4Utw4SsxDMfHMoiEBXRYRQGlMZIKuWMS7eT5UAA=; b=mgpqJ5mDBJ4Rc4QamssXSSP9bdbU7qAS40oUcUzyZlS+xLxKjs/b++a4QFq5ZgFYx7 QmpbmSYktB7jAzZ3/ZUkDOz4DFu1nIPcqNkW4TxRvFj0Dl8OIJj8XFo/7/L+kchHFOKr YDHcCjqMBzjosyBmLnHrNHibiEgIEKVl6D369Ic9E7JYJsKKvbYiEAJxeNfrJ4ICJd32 KFrkkfot23Q3Zc6Zm5BXQrtTmY55WPG1J+Q9nOPawiL6VmomcpNwN6wx7KWAJpOQVcjf mrMF230dwazdhr3hnrai1+uEt5C/eOgiiMgBrz/2iEPMhkD56QRseoTPvBiqrcXKFdhs R7ag== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=EvbNy2K5; 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 67-20020a630046000000b0040c702d1448si269842pga.540.2022.06.17.11.03.19; Fri, 17 Jun 2022 11:03:32 -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=EvbNy2K5; 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 S1382924AbiFQRmF (ORCPT + 99 others); Fri, 17 Jun 2022 13:42:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49626 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1382906AbiFQRmE (ORCPT ); Fri, 17 Jun 2022 13:42:04 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id B6AC53FDA1 for ; Fri, 17 Jun 2022 10:42:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1655487722; 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=ASCb4Utw4SsxDMfHMoiEBXRYRQGlMZIKuWMS7eT5UAA=; b=EvbNy2K5rB1mCEA3N+EwhtUWfOP4L1D1iHNHbRroQqF+b6Vf5TWTc6b2DV7xDsVRrdTdTP 8jmLeQoV4n5ltb8X7aTianqXVs7PduX895YCC/wuRzujb/DoekOb1F08rGfrAlVgEwTjze YgF374Xg0Nu6UlhsG5m33/KcJLnqBqc= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-56-FI45Z2-JMWW6xtneuOTCww-1; Fri, 17 Jun 2022 13:41:57 -0400 X-MC-Unique: FI45Z2-JMWW6xtneuOTCww-1 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.rdu2.redhat.com [10.11.54.2]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 362B8811E76; Fri, 17 Jun 2022 17:41:57 +0000 (UTC) Received: from [10.22.18.98] (unknown [10.22.18.98]) by smtp.corp.redhat.com (Postfix) with ESMTP id B74EE4010E4D; Fri, 17 Jun 2022 17:41:56 +0000 (UTC) Message-ID: <7499dd05-30d1-669c-66b4-5cb06452b476@redhat.com> Date: Fri, 17 Jun 2022 13:41:56 -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: Eric Dumazet Cc: Shakeel Butt , Peter Zijlstra , Eric Dumazet , Linus Torvalds , linux-kernel , Ingo Molnar , Boqun Feng , Will Deacon , Roman Penyaev References: <20220617091039.2257083-1-eric.dumazet@gmail.com> <2dd754f9-3a79-ed17-e423-6b411c3afb69@redhat.com> <2730b855-8f99-5a9e-707e-697d3bd9811d@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.2 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 11:24, Eric Dumazet wrote: > On Fri, Jun 17, 2022 at 5:00 PM Waiman Long wrote: >> 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. >> > If only tasklist_lock is problematic and needs the unfair variant, > then changing a few read_lock() for tasklist_lock will be less > invasive than ~1000 read_lock() elsewhere.... After a second thought, I think the right way is to introduce a fair variant, if needed. If an arch isn't using qrwlock, the native rwlock implementation will be unfair. In that sense, unfair rwlock is the default. We will only need to change the relevant network read_lock() calls to use the fair variant which will still be unfair if qrwlock isn't used. We are not going to touch other read_lock call that don't care about fair or unfair. Cheers, Longman