Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp454821rwe; Thu, 1 Sep 2022 02:19:14 -0700 (PDT) X-Google-Smtp-Source: AA6agR48QCwR66ien1OngH5Oi+Sgk4Kjhwbl3E8IR9FXPsOYe1Ip0xOGcADLT+2kRrEgChnDRQIm X-Received: by 2002:a63:fc50:0:b0:41b:bbb8:ee36 with SMTP id r16-20020a63fc50000000b0041bbbb8ee36mr24821091pgk.20.1662023954185; Thu, 01 Sep 2022 02:19:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662023954; cv=none; d=google.com; s=arc-20160816; b=bq0NH614rb7IOjTjl8schTVi+2E4NuaYj4hK/fUyOiBkJsrRYBNS+2h2B/xBldXjmF QTcdVCjVdci2XvSN18iAXdvZ8R/2e1WNkhpCcI746fKrug+U1XSftVZ/rvQGSm1zen1C Jrxyr3Fgc1+A3abco6m23l/3OB1P+dhogkx7Y3ige3ZT1r+EMuAYolazxA70NGVZIH5v nvW1bWlXrceik8FB8kfxCxiSf1YDk2UdOMryHXAXQaMusnqLA6RvuLawdPJlZEBuaJj0 no3Ir5qIdtQYwVRjCoG2DP3nKQI0SB+MUJIma5c0ieigWqah1FKFK30E/brQY3qP/jQq 6alg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:cc:to:from :subject:organization:dkim-signature; bh=Ktasy/sEA81Y05abLwyFqQvcTxn1i+/4USQhNLHaRD4=; b=u4+Mb9UbmNcWuquI+LBRzMp/xEIfdOHh9UPSm1kglsJUhWECQTo4OHUEieif/179HB FT/NX6N417Q1GD+FQJ33BrehscSeSKdCql3Y8i2OCZ9awkEZ/iB1FvKbthGjJxrZcwig R3Xdjc0DElwQnUFtEVvCBz6h85bOC1yaSKMpVkOSehL2uf5TAJ4qXYjmo0WigPUN4sjG 6IS4vYTVkNGwmVnmdzhKnkjvDpdh6co74ib8/dDXjx/STyVQCg1bZdSRMo03xCezvbVx 56zFs9QphmyMXPjkQ1UZSSCuSEvPjdAnH0BPVb/oN0hQaFlYh1zjCk6dTyhq7QGLF3eZ PDiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=axsXwVsJ; 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 bg8-20020a056a02010800b0042bdc03cc5fsi7052786pgb.408.2022.09.01.02.19.02; Thu, 01 Sep 2022 02:19:14 -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=axsXwVsJ; 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 S233616AbiIAIH5 (ORCPT + 99 others); Thu, 1 Sep 2022 04:07:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33460 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233537AbiIAIHw (ORCPT ); Thu, 1 Sep 2022 04:07:52 -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 ESMTPS id 0B366120FBE for ; Thu, 1 Sep 2022 01:07:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1662019667; 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=Ktasy/sEA81Y05abLwyFqQvcTxn1i+/4USQhNLHaRD4=; b=axsXwVsJNXafPs837HQb/tWKPbkXqleSzgS7kB3mLkRkDMSkMWjg/mQXuBHfpPxldd3cYu r4QQCP1xdgVkgY/pTGyryzBBLk5J2QAWG5bnI9XSyDybctVzaPJVyNLBQG9Jwv1xMB5HfC sIKrQeIvt4mdG3vokKC2i2i2pn2qfKk= 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-634-qsdJlGBaObe0IXJQ7EZ25g-1; Thu, 01 Sep 2022 04:07:45 -0400 X-MC-Unique: qsdJlGBaObe0IXJQ7EZ25g-1 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.rdu2.redhat.com [10.11.54.8]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 5882210726A2; Thu, 1 Sep 2022 08:07:45 +0000 (UTC) Received: from warthog.procyon.org.uk (unknown [10.33.36.72]) by smtp.corp.redhat.com (Postfix) with ESMTP id CF81AC15BBA; Thu, 1 Sep 2022 08:07:44 +0000 (UTC) Organization: Red Hat UK Ltd. Registered Address: Red Hat UK Ltd, Amberley Place, 107-111 Peascod Street, Windsor, Berkshire, SI4 1TE, United Kingdom. Registered in England and Wales under Company Registration No. 3798903 Subject: [PATCH net 3/6] rxrpc: Fix local destruction being repeated From: David Howells To: netdev@vger.kernel.org Cc: dhowells@redhat.com, linux-afs@lists.infradead.org, linux-kernel@vger.kernel.org Date: Thu, 01 Sep 2022 09:07:44 +0100 Message-ID: <166201966425.3817988.9780080415265800940.stgit@warthog.procyon.org.uk> In-Reply-To: <166201964443.3817988.12088441548413332725.stgit@warthog.procyon.org.uk> References: <166201964443.3817988.12088441548413332725.stgit@warthog.procyon.org.uk> User-Agent: StGit/1.5 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.85 on 10.11.54.8 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, 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 If the local processor work item for the rxrpc local endpoint gets requeued by an event (such as an incoming packet) between it getting scheduled for destruction and the UDP socket being closed, the rxrpc_local_destroyer() function can get run twice. The second time it can hang because it can end up waiting for cleanup events that will never happen. Signed-off-by: David Howells --- net/rxrpc/local_object.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/net/rxrpc/local_object.c b/net/rxrpc/local_object.c index 79bb02eb67b2..38ea98ff426b 100644 --- a/net/rxrpc/local_object.c +++ b/net/rxrpc/local_object.c @@ -406,6 +406,9 @@ static void rxrpc_local_processor(struct work_struct *work) container_of(work, struct rxrpc_local, processor); bool again; + if (local->dead) + return; + trace_rxrpc_local(local->debug_id, rxrpc_local_processing, refcount_read(&local->ref), NULL);