Received: by 2002:a05:7412:3b8b:b0:fc:a2b0:25d7 with SMTP id nd11csp1687131rdb; Sat, 10 Feb 2024 12:37:56 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCVVUdytbKsFd6ryj8S+w0DhR/yJB1/Wj5+LrUNuYtQXx/jWA7ewIN6WUm5VjzEyC6fmgGvswb+4etQqZL3XYoXHVZuGMxh0fcImurTCYw== X-Google-Smtp-Source: AGHT+IErou1HFM441rBhUgyTK8v4XSh2iRR5fqdp6hfklrovF/ZgZq4vGJ9UT9SG90qJ6fmw+cK1 X-Received: by 2002:a17:903:278f:b0:1d9:a66a:1c26 with SMTP id jw15-20020a170903278f00b001d9a66a1c26mr2806940plb.20.1707597476032; Sat, 10 Feb 2024 12:37:56 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1707597476; cv=pass; d=google.com; s=arc-20160816; b=Wg8BYc1AIk1kaBLJoFiyoPDpdDxTWI54yRqTExwp+O2iQ3fME4hHvBg4bB85OPTbTo HNgShipAh2fG+S7BPS2ZP5GTyTnykZ91Gn/mBftdLm15OBDmkeA7p7E09S9DDhefsdZU r74VSrDDsTKjWh+abfnhQ5Z3Lu/XMXWRzdDuWEuJ5yNpmqDikFNKoAcAdKDtM0N1ExeM kyl1tKfBzMElNxAEbxtXboT2JLFjqAwiiT/MF2n1C2suKzmtc9vzhvsfnNj9zd1QhH0f eRbvFPegz+iMlhgM+tU9Fk53wfLkwt93fVwVV1KGgc0WpsVmTKXZm7o9egdbrp8xWqEQ wN4g== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:content-language:in-reply-to:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:user-agent:date :message-id:organization:from:references:cc:to:subject; bh=/C6A0S/OnYttyVxuKSjmZPdHrKPjAGDoCCR2G/Vz8Gc=; fh=ZAO/JfNtjGFs/KOx/8ZNNB1jtHU7wpcTnntJmYJJPLI=; b=Mxwkumh4zA0G/jMEsmYcghO2BB9/LhKN0yAV24XJZUYo78IqcaPq/bAy5tOqRRI5q0 MwbObnqw2HdI97krD+R5Sg7Hji7gi0FJpmE9dGHYuVmp16sIt3rPnXMOAd00w8As7mm6 ExjHjCflKIGJ+lYrtia4bw6SM5hXYwqHMBitaZDcftbSyMxwqW26AYSosYLs0QZOAfSM 3g+8bhqx4AVBh7/d3U9/0+kfI7BAfADDiCwo7Pv8nUd5PWgD3y0ctvuFqzk2w8qWTv5t oSYfbVpqxjNcLbgm84sfYK7/CaXxfo2JG+elS0Fjc6BAfVzl+BsN9l0K+Df1Pb23S0qO ctcw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=omp.ru); spf=pass (google.com: domain of linux-kernel+bounces-60534-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-60534-linux.lists.archive=gmail.com@vger.kernel.org" X-Forwarded-Encrypted: i=2; AJvYcCWSdD0G3J8U23Mrfg90ZpnwA7mQoB3FfWWNUviQ43Thfrd6beELPQofSAU0wVq+gDQQM3oBhzfeOXb8iDgEdnR8m07jCTuRGa1gJ1GEPw== Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [2604:1380:45e3:2400::1]) by mx.google.com with ESMTPS id nv13-20020a17090b1b4d00b00296160ca657si3840827pjb.97.2024.02.10.12.37.55 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 10 Feb 2024 12:37:56 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-60534-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) client-ip=2604:1380:45e3:2400::1; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=omp.ru); spf=pass (google.com: domain of linux-kernel+bounces-60534-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-60534-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id B17B9285ABA for ; Sat, 10 Feb 2024 20:37:55 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id A20725FB9E; Sat, 10 Feb 2024 20:37:44 +0000 (UTC) Received: from mx01.omp.ru (mx01.omp.ru [90.154.21.10]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id B9B135B1EB; Sat, 10 Feb 2024 20:37:39 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=90.154.21.10 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707597464; cv=none; b=H+d/32odrk+YEgrvn2ErOWkjCssfFQhi0nMgpSk/C4NjkMQJj+0H0Y75oJKLqRIrXoz7fVjjeMNkT1huX4ZYsGqptQ3xNmB6B2FXhqf+EdDJ1dYKFc5uVbgh2DcBPqni67wszMc8ohE0+UZ4LUTYfYYwC6FKjZfBWQpBLU8lagk= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707597464; c=relaxed/simple; bh=o3DjcLuy3LIalFk9cwJNOhs8h+B9l1E7S8qrQDbmMgk=; h=Subject:To:CC:References:From:Message-ID:Date:MIME-Version: In-Reply-To:Content-Type; b=jqfTLKSAvIHRHQxg7bvL3zR87k7soa3grm/eSFyYzzUeiagLZdSjSCZu/A/Ttu7h4HX+sKTOwYn93iyUtqzVelVv+YSuHpHVNcJGEw4+FbJEN3c86a29Vj9Az3wFoWY+u460BYtWiOkaXZRTTs0z6/Ihu5+JaGat4Dx2P1GNUKQ= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=omp.ru; spf=pass smtp.mailfrom=omp.ru; arc=none smtp.client-ip=90.154.21.10 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=omp.ru Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=omp.ru Received: from [192.168.1.105] (31.173.86.126) by msexch01.omp.ru (10.188.4.12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.2.1258.12; Sat, 10 Feb 2024 23:37:31 +0300 Subject: Re: [PATCH net-next v2 4/5] net: ravb: Do not apply RX checksum settings to hardware if the interface is down To: Biju Das , Claudiu.Beznea , "davem@davemloft.net" , "edumazet@google.com" , "kuba@kernel.org" , "pabeni@redhat.com" CC: "netdev@vger.kernel.org" , "linux-renesas-soc@vger.kernel.org" , "linux-kernel@vger.kernel.org" , Claudiu Beznea References: <20240209170459.4143861-1-claudiu.beznea.uj@bp.renesas.com> <20240209170459.4143861-5-claudiu.beznea.uj@bp.renesas.com> <6f907f89-7588-fd99-1a63-8291f9e29c81@omp.ru> From: Sergey Shtylyov Organization: Open Mobile Platform Message-ID: Date: Sat, 10 Feb 2024 23:37:31 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.10.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-ClientProxiedBy: msexch02.omp.ru (10.188.4.13) To msexch01.omp.ru (10.188.4.12) X-KSE-ServerInfo: msexch01.omp.ru, 9 X-KSE-AntiSpam-Interceptor-Info: scan successful X-KSE-AntiSpam-Version: 6.1.0, Database issued on: 02/10/2024 20:25:19 X-KSE-AntiSpam-Status: KAS_STATUS_NOT_DETECTED X-KSE-AntiSpam-Method: none X-KSE-AntiSpam-Rate: 59 X-KSE-AntiSpam-Info: Lua profiles 183344 [Feb 10 2024] X-KSE-AntiSpam-Info: Version: 6.1.0.3 X-KSE-AntiSpam-Info: Envelope from: s.shtylyov@omp.ru X-KSE-AntiSpam-Info: LuaCore: 7 0.3.7 6d6bf5bd8eea7373134f756a2fd73e9456bb7d1a X-KSE-AntiSpam-Info: {rep_avail} X-KSE-AntiSpam-Info: {Tracking_from_domain_doesnt_match_to} X-KSE-AntiSpam-Info: {relay has no DNS name} X-KSE-AntiSpam-Info: {SMTP from is not routable} X-KSE-AntiSpam-Info: {Found in DNSBL: 31.173.86.126 in (user) b.barracudacentral.org} X-KSE-AntiSpam-Info: omp.ru:7.1.1;127.0.0.199:7.1.2;d41d8cd98f00b204e9800998ecf8427e.com:7.1.1 X-KSE-AntiSpam-Info: ApMailHostAddress: 31.173.86.126 X-KSE-AntiSpam-Info: {DNS response errors} X-KSE-AntiSpam-Info: Rate: 59 X-KSE-AntiSpam-Info: Status: not_detected X-KSE-AntiSpam-Info: Method: none X-KSE-AntiSpam-Info: Auth:dmarc=temperror header.from=omp.ru;spf=temperror smtp.mailfrom=omp.ru;dkim=none X-KSE-Antiphishing-Info: Clean X-KSE-Antiphishing-ScanningType: Heuristic X-KSE-Antiphishing-Method: None X-KSE-Antiphishing-Bases: 02/10/2024 20:28:00 X-KSE-Antivirus-Interceptor-Info: scan successful X-KSE-Antivirus-Info: Clean, bases: 2/10/2024 5:04:00 PM X-KSE-Attachment-Filter-Triggered-Rules: Clean X-KSE-Attachment-Filter-Triggered-Filters: Clean X-KSE-BulkMessagesFiltering-Scan-Result: InTheLimit On 2/9/24 11:41 PM, Biju Das wrote: [...] >>> From: Claudiu Beznea >>> >>> Do not apply the RX checksum settings to hardware if the interface is >>> down. >>> In case runtime PM is enabled, and while the interface is down, the IP >>> will be in reset mode (as for some platforms disabling the clocks will >>> switch the IP to reset mode, which will lead to losing register >>> contents) and applying settings in reset mode is not an option. >>> Instead, cache the RX checksum settings and apply them in ravb_open() >>> through ravb_emac_init(). >>> This has been solved by introducing pm_runtime_active() check. The >>> device runtime PM usage counter has been incremented to avoid >>> disabling the device clocks while the check is in progress (if any). >>> >>> Commit prepares for the addition of runtime PM. >>> >>> Signed-off-by: Claudiu Beznea >> >> Reviewed-by: Sergey Shtylyov > > This will do the same job, without code duplication right? > > static int ravb_set_features(struct net_device *ndev, > netdev_features_t features) > { > struct ravb_private *priv = netdev_priv(ndev); > struct device *dev = &priv->pdev->dev; > const struct ravb_hw_info *info = priv->info; > > pm_runtime_get_noresume(dev); > if (!pm_runtime_active(dev)) { > pm_runtime_put_noidle(dev); > ndev->features = features; > return 0; > } > > return info->set_feature(ndev, features); We now leak the device reference by not calling pm_runtime_put_noidle() after this statement... The approach seems sane though -- Claudiu, please consider following it. [...] > Cheers, > Biju MBR, Sergey