Received: by 2002:ac0:e350:0:0:0:0:0 with SMTP id g16csp2645566imn; Tue, 2 Aug 2022 10:30:37 -0700 (PDT) X-Google-Smtp-Source: AA6agR7hIJzt2joPeCfYKRzMbPbPw+DA7sUa8vC2PjVvzMA+OKW/MHAhssLlscS8xm6LAT7VuTRU X-Received: by 2002:a05:6402:34c6:b0:43d:8cea:76c0 with SMTP id w6-20020a05640234c600b0043d8cea76c0mr12836936edc.268.1659461437523; Tue, 02 Aug 2022 10:30:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659461437; cv=none; d=google.com; s=arc-20160816; b=jqu2K6FO/eifnkmhB6xgEOht/JBt1Ce/D/ZYDHUCdfwf8/FXLv1vMAHMJyWN5QGI8b N79wed3vVC2jdOoHp7z3P3g4tDhVhwzwvM8c0WNgbZMa3LbpTfVaAUB84+TwzLGMWZFf fiDnCWo/Vc4tAuntZharfX1k+2KUGBqqq3a2LefrsWBrDkAa5efLU3KEKrnc0Pkw93ye 8Q6ho0dsl9zF9vWws+MEIAmXd6dphK1kS+g0AtHvikjRZVH9mgqvQ/DuP448o/pEke2F KkpRoL4mb6tHPM+pbBT7FcLtXqjjpXRsPJDvb4qMmS64T72p5bz/r8JH2pW1jc+vohFE RCDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:content-transfer-encoding :content-id:mime-version:subject:cc:to:references:in-reply-to:from :organization:dkim-signature; bh=vlhiUUm/2R9OZ4dkUwKfWDfhVhDGEpgB2ljUziEmU/8=; b=YDA/GNwyX+HVLn0BEZYUBALVDp2jlrBhXUkoB15k2l7LA5KP7JywkY/DkMi1rTyGTC CMn142stk4v2JW8SkalsOGh7YgH53ctmM0wj5x+Zi8tftrxrKPGtevp98JEsBcqRF4DJ lyjEbUabnwOiYeF5gk14IsIng6AxRCKgOuLcUlSPrHiGg9YmzSc3q4H41lE0Ce9bhZPg MYWx+adLvRR1mb7RnCIp2Dfl7WFIOfEedSgFRhJeCqQjJOjdqpKeOLsAcKKtcaSHgHpt Qy7eX9jcT6bUK58fgQfKe2XYJBab7ZKnpZFbqnwovDSqF48ZAqinfjDWnCkOFxT0soiK pFvg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="EbCq/L9Y"; 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 hy24-20020a1709068a7800b0073060ad1583si2275174ejc.884.2022.08.02.10.30.12; Tue, 02 Aug 2022 10:30:37 -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="EbCq/L9Y"; 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 S232904AbiHBROY (ORCPT + 99 others); Tue, 2 Aug 2022 13:14:24 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45110 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229499AbiHBROX (ORCPT ); Tue, 2 Aug 2022 13:14:23 -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 B0FCC3A4A7 for ; Tue, 2 Aug 2022 10:14:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1659460461; 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=vlhiUUm/2R9OZ4dkUwKfWDfhVhDGEpgB2ljUziEmU/8=; b=EbCq/L9YX2LKjdnVpogFML7w8wBs3YuIcGx7hIUW9HtrHWBUstfiZXM97ldh0qmAy5Tph5 imq33TeaekrMflEiQqck3TO+zT4ouM5V2zPidvgR/6g3k2z536UeBSh70saizYv0qazjGb P5cwGyEF9+1rODXy6AFTBm7W8n2zymE= 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-587-k-YzkfN-MGGMiRIedld4nw-1; Tue, 02 Aug 2022 13:14:18 -0400 X-MC-Unique: k-YzkfN-MGGMiRIedld4nw-1 Received: from smtp.corp.redhat.com (int-mx09.intmail.prod.int.rdu2.redhat.com [10.11.54.9]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 3671F802D1C; Tue, 2 Aug 2022 17:14:18 +0000 (UTC) Received: from warthog.procyon.org.uk (unknown [10.33.36.10]) by smtp.corp.redhat.com (Postfix) with ESMTP id 94638492CA2; Tue, 2 Aug 2022 17:14:17 +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 From: David Howells In-Reply-To: References: <165911277121.3745403.18238096564862303683.stgit@warthog.procyon.org.uk> <165911278430.3745403.16526310736054780645.stgit@warthog.procyon.org.uk> To: Marc Dionne Cc: dhowells@redhat.com, linux-afs@lists.infradead.org, linux-fsdevel@vger.kernel.org, Linux Kernel Mailing List Subject: Re: [PATCH 2/2] afs: Fix access after dec in put functions MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-ID: <3733971.1659460456.1@warthog.procyon.org.uk> Content-Transfer-Encoding: quoted-printable Date: Tue, 02 Aug 2022 18:14:16 +0100 Message-ID: <3733972.1659460456@warthog.procyon.org.uk> X-Scanned-By: MIMEDefang 2.85 on 10.11.54.9 X-Spam-Status: No, score=-3.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_NONE 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 Marc Dionne wrote: > > - trace_afs_server(server, r - 1, atomic_read(&server->active), = reason); > > + trace_afs_server(server->debug_id, r - 1, a, reason); > = > Don't you also want to copy server->debug_id into a local variable here? Okay, how about the attached change? David --- diff --git a/fs/afs/server.c b/fs/afs/server.c index bca4b4c55c14..4981baf97835 100644 --- a/fs/afs/server.c +++ b/fs/afs/server.c @@ -399,7 +399,7 @@ struct afs_server *afs_use_server(struct afs_server *s= erver, enum afs_server_tra void afs_put_server(struct afs_net *net, struct afs_server *server, enum afs_server_trace reason) { - unsigned int a; + unsigned int a, debug_id =3D server->debug_id; bool zero; int r; = @@ -408,7 +408,7 @@ void afs_put_server(struct afs_net *net, struct afs_se= rver *server, = a =3D atomic_inc_return(&server->active); zero =3D __refcount_dec_and_test(&server->ref, &r); - trace_afs_server(server->debug_id, r - 1, a, reason); + trace_afs_server(debug_id, r - 1, a, reason); if (unlikely(zero)) __afs_put_server(net, server); }