From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-14.0 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 0922BC4743F for ; Mon, 7 Jun 2021 07:36:36 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id C2BEB61059 for ; Mon, 7 Jun 2021 07:36:35 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org C2BEB61059 Authentication-Results: mail.kernel.org; dmarc=fail (p=quarantine dis=none) header.from=microchip.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Date:CC:To:From:Subject:Message-ID:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=o1dLek7wkBHpau9Gf++sZj7xMtXSfSdAYfirYpKB4jU=; b=F1WJi2K5aUcJzH ku1nVLOuNUiQlX9r4nCIOmwsAcz5llBPMY3UcF2p0oTduDtubXRLskvlxdrC72HAc+ksrPzm7PELA qQvLlWK/ozASdptVvKsmsuPxd+qsrUhIfYH/QSBfsW5WH5LfWflQOOptbi3SwqGVjgCxHNxzeCBuy 8py4799DNIMdJEYoDeqSHcAQFIVG5zl9fjgx546potjz3MEnHM3oEwKX8Hnnco2a343i07chDf9q5 rFqa+CyCi+9KRNbOZfq1DHKw/1twA4XPu5jItkl3h+rHBzGllBqs2XGh8tvAkEYOJPMvuyGfN9AmP 5BO1fNFuLHFStvk4kSdQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1lq9mL-0025Xf-Jq; Mon, 07 Jun 2021 07:34:33 +0000 Received: from esa.microchip.iphmx.com ([68.232.154.123]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1lq9mF-0025Vs-Uc for linux-arm-kernel@lists.infradead.org; Mon, 07 Jun 2021 07:34:32 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=microchip.com; i=@microchip.com; q=dns/txt; s=mchp; t=1623051267; x=1654587267; h=message-id:subject:from:to:cc:date:in-reply-to: references:mime-version:content-transfer-encoding; bh=rOUraZ4miGFonwbmtDBoybUSd5NfVjz185H9UOStUOY=; b=wK3o7ZthCMxT9PVYlehp5cKhecpnnBmSYbcrZ9mfW8JG7RvjAHZWJFpT 9nBu6u2t0XRbF6VPL/zs41PUcjsKKE5SOYv3FgaRhhDFzkRFmvczDn/sC 4h63CymF/8Zp4Y1gmy44HOws8aac8VIUFAcaNdHIjwCt7L30GNwKwPg1X BvCpPlHPZIOyIyMqmRALxa0UyOdvUK87KZOY4SNAKFBknm6kleeSl5U4w Y64/5NEFxnHByxyzeiFGCUJye1wRgGpInVxyPrQ9DP5vQXoHN0x61j4oM 4bpNZIZYQCzypu2Armctd97uQo1HNtamaXr7p88P2ynzUlPQlGqHoDxpq A==; IronPort-SDR: Bi8UACmM/jTaB0+5EJgKekHNFR2q5yg6HIUWtidUYZhvxfzhfHhzEzK/quVAU83sF5ftLJ1Syb 8T+eZXHqbtB3fQjBO43ycJGyy9PgM6vnEfqq6SnVw6Jr7pkvVYu0ViMWwufItu81Zc17hGH6G7 Q+dtb9rHatPpDTmIYhLFo27bYh/GTYAY27AItH4AtHkakjqjgrXr7ekL7FWYjTRdb+wuBNHjDs p93vNg5xa6qSs8O7WQJX1ukWwDxZkJP7qGDAk9JBWGBYIqt0VG9wG57kcwCqICH9sysmJgfvdL aCw= X-IronPort-AV: E=Sophos;i="5.83,254,1616482800"; d="scan'208";a="58052269" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa6.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 07 Jun 2021 00:34:25 -0700 Received: from chn-vm-ex02.mchp-main.com (10.10.85.144) by chn-vm-ex01.mchp-main.com (10.10.85.143) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2176.2; Mon, 7 Jun 2021 00:34:24 -0700 Received: from den-her-m31857h.microchip.com (10.10.115.15) by chn-vm-ex02.mchp-main.com (10.10.85.144) with Microsoft SMTP Server id 15.1.2176.2 via Frontend Transport; Mon, 7 Jun 2021 00:34:21 -0700 Message-ID: Subject: Re: [PATCH net-next v3 02/10] net: sparx5: add the basic sparx5 driver From: Steen Hegelund To: Philipp Zabel , "David S. Miller" , Jakub Kicinski CC: Andrew Lunn , Russell King , Microchip Linux Driver Support , "Alexandre Belloni" , Madalin Bucur , Mark Einon , "Masahiro Yamada" , Arnd Bergmann , Simon Horman , , , , Bjarni Jonasson , Lars Povlsen Date: Mon, 7 Jun 2021 09:34:20 +0200 In-Reply-To: <6a1500fb623e6513e39a468ac53d1caf6a2cf7c5.camel@pengutronix.de> References: <20210604085600.3014532-1-steen.hegelund@microchip.com> <20210604085600.3014532-3-steen.hegelund@microchip.com> <6a1500fb623e6513e39a468ac53d1caf6a2cf7c5.camel@pengutronix.de> User-Agent: Evolution 3.36.5-0ubuntu1 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20210607_003428_140917_A572BFA2 X-CRM114-Status: GOOD ( 27.58 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi Philipp, Thanks for your comments. On Fri, 2021-06-04 at 11:28 +0200, Philipp Zabel wrote: > EXTERNAL EMAIL: Do not click links or open attachments unless you know the content is safe > > Hi Steen, > > On Fri, 2021-06-04 at 10:55 +0200, Steen Hegelund wrote: > > This adds the Sparx5 basic SwitchDev driver framework with IO range > > mapping, switch device detection and core clock configuration. > > > > Support for ports, phylink, netdev, mactable etc. are in the following > > patches. > > > > Signed-off-by: Steen Hegelund > > Signed-off-by: Bjarni Jonasson > > Signed-off-by: Lars Povlsen > > --- > > drivers/net/ethernet/microchip/Kconfig | 2 + > > drivers/net/ethernet/microchip/Makefile | 2 + > > drivers/net/ethernet/microchip/sparx5/Kconfig | 9 + > > .../net/ethernet/microchip/sparx5/Makefile | 8 + > > .../ethernet/microchip/sparx5/sparx5_main.c | 746 +++ > > .../ethernet/microchip/sparx5/sparx5_main.h | 273 + > > .../microchip/sparx5/sparx5_main_regs.h | 4642 +++++++++++++++++ > > 7 files changed, 5682 insertions(+) > > create mode 100644 drivers/net/ethernet/microchip/sparx5/Kconfig > > create mode 100644 drivers/net/ethernet/microchip/sparx5/Makefile > > create mode 100644 drivers/net/ethernet/microchip/sparx5/sparx5_main.c > > create mode 100644 drivers/net/ethernet/microchip/sparx5/sparx5_main.h > > create mode 100644 drivers/net/ethernet/microchip/sparx5/sparx5_main_regs.h > > > [...] > > diff --git a/drivers/net/ethernet/microchip/sparx5/sparx5_main.c > > b/drivers/net/ethernet/microchip/sparx5/sparx5_main.c > > new file mode 100644 > > index 000000000000..73beb85bc52d > > --- /dev/null > > +++ b/drivers/net/ethernet/microchip/sparx5/sparx5_main.c > > @@ -0,0 +1,746 @@ > [...] > > +static int mchp_sparx5_probe(struct platform_device *pdev) > > +{ > [...] > > + > > + sparx5->reset = devm_reset_control_get_shared(&pdev->dev, "switch"); > > + if (IS_ERR(sparx5->reset)) { > > Could you use devm_reset_control_get_optional_shared() instead of > ignoring this error? That would just return NULL if there's no "switch" > reset specified in the device tree. Yes. That sounds like a good idea. I assume that the devm_reset_control_get_optional_shared() would also return null if another driver has already performed the reset? > > > + dev_warn(sparx5->dev, "Could not obtain reset control: %ld\n", > > + PTR_ERR(sparx5->reset)); > > + sparx5->reset = NULL; > > + } else { > > + reset_control_reset(sparx5->reset); > > + } > > If this is the only place the reset is used, I'd remove it from struct > sparx5 and use a local variable instead. Yes. I will do that. > > regards > Philipp Best -- BR Steen -=-=-=-=-=-=-=-=-=-=-=-=-=-= steen.hegelund@microchip.com _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel