Received: by 2002:ac0:8c9a:0:0:0:0:0 with SMTP id r26csp190781ima; Thu, 31 Jan 2019 14:47:19 -0800 (PST) X-Google-Smtp-Source: ALg8bN5IsyBVyd/I0LXJYLd94v79Hq0o/S0gWHNVX+StAwNYjHh94yCWrf7w+Z9Wlao/ZpcB1WhC X-Received: by 2002:a63:5b48:: with SMTP id l8mr33403233pgm.80.1548974838858; Thu, 31 Jan 2019 14:47:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548974838; cv=none; d=google.com; s=arc-20160816; b=d4ujdReDRW9O6HZe90PoZ1AKyWavWf1z7l4QP6bS0ctvgFZ3trY5esvwE0z487vKg1 +LXQnI973Vq6a6H/F4zXiynKUR83VZk04qmAVeyslDli+g6+BBo+2SEvARyKZ2P79T5x OT/QRIknbKskSuoT32RolnjDbGaprfHXP8m17WVlQbq5/peETVloXDEhohHVWcEsAZYW /kphiKJTXu8voqZAd8jMXmbm2NArkmeZ0Xp0bBfvpdwS/vokWq1tr6ghqsHTaeMwhOBO NiA+AJ53DGpVuJ/TGfXQ6ElsMljUv0h3XyL4ZSRT8EgtC4JjfH6ZsLnjLJjFP+EcS5si JlBw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=zBtANhfwlHrkA9s4uLMxxoXbJiZYcxP3YKb55Uu2Jkk=; b=Fns2CVkWwSYBmCYSP2xU/Cj0ISkWtGsviyXStZXRVcAxnOh7qaDZ2hUq/RuEH140+a 83Eo4c/hYEKzrzwYNDPQ24CFG2B4oAAeJNHo5KSDsPgIuursVWAbA7w4QJplGclAdRND Pvmguq/ZCecUWKLe7gh2UA8OQpWd1WDwjHWfmV9YiZuZzXSXTLZbjE5rzS3KL22vR0yV 6UVxU3p0F7KU/4GaEBRiJ5W6yhYkdx/FB0Oe9DGRrFB50hZ+VoYn22NWOa4z3a2U5yvk 0+6iadv0YODYVGcisi2aAD95ya3UlGGAL8o+aHf0+BJa2tkOUeg7zfGZotKgQGS5kUD7 nyKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ettus-com.20150623.gappssmtp.com header.s=20150623 header.b=ETNHltkH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e25si4863447pgv.486.2019.01.31.14.47.02; Thu, 31 Jan 2019 14:47:18 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@ettus-com.20150623.gappssmtp.com header.s=20150623 header.b=ETNHltkH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727454AbfAaVdi (ORCPT + 99 others); Thu, 31 Jan 2019 16:33:38 -0500 Received: from mail-pg1-f193.google.com ([209.85.215.193]:41118 "EHLO mail-pg1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726976AbfAaVdh (ORCPT ); Thu, 31 Jan 2019 16:33:37 -0500 Received: by mail-pg1-f193.google.com with SMTP id m1so1909791pgq.8 for ; Thu, 31 Jan 2019 13:33:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ettus-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id; bh=zBtANhfwlHrkA9s4uLMxxoXbJiZYcxP3YKb55Uu2Jkk=; b=ETNHltkHvzs2m8RnUOBZVmg23iuDjb1uvwnJlQ9lbyBGMqiXDcluNAjVoh2i7hMi5M YztEneoQ6+i3A/ZmhhVctTHkoru5rxZdOcDvaaaSUPrrebf2G1c3C79p0OH7z7RnSX4y 9t++hEC7kUYMKMsnoDocGHt5b8l+ydEaZcSoqXs8DGLPAGWkegsXrdd9a8VPO8CFMI1I qoKArtHYOnGPVHIFR8TiQi7LKPg5Gl5DMZ0PJHdJvm2y6WMJzsgtrDKPoLT9dYzlJ8vh W3LRV1ftunJVoUZ4tiOPBAr6vNUhJistn82pJZ+BUpO0ym/Bz5RqDt9+qVfplsYchNWX tBSQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=zBtANhfwlHrkA9s4uLMxxoXbJiZYcxP3YKb55Uu2Jkk=; b=B+N9Hr0wOmOlGOgKmJT3aJKRZUpNXDRLewnE7xLxZjRz/l7vXAwJuRUwbXPEB1znz4 tNn5PYuEYVxTbahGzv5iLPJW3Og6rJ0rrR0S+9SQYWIDS42lNjQ4lnIEcDQCGkf8qBJE aBMWpB8eSmBjjjFVukVRAEK7fdEdMezQTxGQ/0/E4zDXOjcSH/tqSfschVtEN9bsACei XXKV000uLk0HvLAD4wuG13fSUp3JgEJx3vQxDno4c9XIRe1lBN2wdavnwX6pHawRTanR kWVHsB/W2ZGQ3tAXlco8qWQDEB+Fio4xdT/Zr1wmo38Kd/JdkVvdtkKF01gQcj5KUm0W LsXA== X-Gm-Message-State: AJcUuke/LAxliotsEBFzsJ0jEyqggzMmxoRNlGebk9CwD/2YBHaYzXeJ y8EcNmIpAovZXJtlqURwk6ob7Q== X-Received: by 2002:a62:444b:: with SMTP id r72mr37032456pfa.184.1548970416495; Thu, 31 Jan 2019 13:33:36 -0800 (PST) Received: from localhost.localdomain (cpe-76-176-152-96.san.res.rr.com. [76.176.152.96]) by smtp.gmail.com with ESMTPSA id n21sm7513227pfg.84.2019.01.31.13.33.34 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 31 Jan 2019 13:33:35 -0800 (PST) From: alex.williams@ettus.com To: davem@davemloft.net Cc: robh+dt@kernel.org, mark.rutland@arm.com, mdf@kernel.org, mcgrof@kernel.org, keescook@chromium.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Alex Williams Subject: [PATCH v2 net-next 1/2] net: nixge: Separate ctrl and dma resources Date: Thu, 31 Jan 2019 13:33:27 -0800 Message-Id: <20190131213328.11236-1-alex.williams@ettus.com> X-Mailer: git-send-email 2.14.5 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Alex Williams The DMA engine is a separate entity altogether, and this allows the DMA controller's address to float elsewhere in the FPGA's map. Signed-off-by: Alex Williams --- drivers/net/ethernet/ni/nixge.c | 74 ++++++++++++++++++++++++++++++++--------- 1 file changed, 58 insertions(+), 16 deletions(-) diff --git a/drivers/net/ethernet/ni/nixge.c b/drivers/net/ethernet/ni/nixge.c index 1e408d1a9b5f..73a98bd2fcd2 100644 --- a/drivers/net/ethernet/ni/nixge.c +++ b/drivers/net/ethernet/ni/nixge.c @@ -105,6 +105,12 @@ #define NIXGE_MAX_JUMBO_FRAME_SIZE \ (NIXGE_JUMBO_MTU + NIXGE_HDR_SIZE + NIXGE_TRL_SIZE) +enum nixge_version { + NIXGE_V2, + NIXGE_V3, + NIXGE_VERSION_COUNT +}; + struct nixge_hw_dma_bd { u32 next_lo; u32 next_hi; @@ -1225,11 +1231,59 @@ static void *nixge_get_nvmem_address(struct device *dev) return mac; } +/* Match table for of_platform binding */ +static const struct of_device_id nixge_dt_ids[] = { + { .compatible = "ni,xge-enet-2.00", .data = (void *)NIXGE_V2 }, + { .compatible = "ni,xge-enet-3.00", .data = (void *)NIXGE_V3 }, + {}, +}; +MODULE_DEVICE_TABLE(of, nixge_dt_ids); + +static int nixge_of_get_resources(struct platform_device *pdev) +{ + const struct of_device_id *of_id; + enum nixge_version version; + struct resource *ctrlres; + struct resource *dmares; + struct net_device *ndev; + struct nixge_priv *priv; + + ndev = platform_get_drvdata(pdev); + priv = netdev_priv(ndev); + of_id = of_match_node(nixge_dt_ids, pdev->dev.of_node); + if (!of_id) + return -ENODEV; + + version = (enum nixge_version)of_id->data; + if (version <= NIXGE_V2) + dmares = platform_get_resource(pdev, IORESOURCE_MEM, 0); + else + dmares = platform_get_resource_byname(pdev, IORESOURCE_MEM, + "dma"); + + priv->dma_regs = devm_ioremap_resource(&pdev->dev, dmares); + if (IS_ERR(priv->dma_regs)) { + netdev_err(ndev, "failed to map dma regs\n"); + return PTR_ERR(priv->dma_regs); + } + if (version <= NIXGE_V2) { + priv->ctrl_regs = priv->dma_regs + NIXGE_REG_CTRL_OFFSET; + } else { + ctrlres = platform_get_resource_byname(pdev, IORESOURCE_MEM, + "ctrl"); + priv->ctrl_regs = devm_ioremap_resource(&pdev->dev, ctrlres); + } + if (IS_ERR(priv->ctrl_regs)) { + netdev_err(ndev, "failed to map ctrl regs\n"); + return PTR_ERR(priv->ctrl_regs); + } + return 0; +} + static int nixge_probe(struct platform_device *pdev) { struct nixge_priv *priv; struct net_device *ndev; - struct resource *dmares; const u8 *mac_addr; int err; @@ -1261,14 +1315,9 @@ static int nixge_probe(struct platform_device *pdev) priv->dev = &pdev->dev; netif_napi_add(ndev, &priv->napi, nixge_poll, NAPI_POLL_WEIGHT); - - dmares = platform_get_resource(pdev, IORESOURCE_MEM, 0); - priv->dma_regs = devm_ioremap_resource(&pdev->dev, dmares); - if (IS_ERR(priv->dma_regs)) { - netdev_err(ndev, "failed to map dma regs\n"); - return PTR_ERR(priv->dma_regs); - } - priv->ctrl_regs = priv->dma_regs + NIXGE_REG_CTRL_OFFSET; + err = nixge_of_get_resources(pdev); + if (err) + return err; __nixge_hw_set_mac_address(ndev); priv->tx_irq = platform_get_irq_byname(pdev, "tx"); @@ -1337,13 +1386,6 @@ static int nixge_remove(struct platform_device *pdev) return 0; } -/* Match table for of_platform binding */ -static const struct of_device_id nixge_dt_ids[] = { - { .compatible = "ni,xge-enet-2.00", }, - {}, -}; -MODULE_DEVICE_TABLE(of, nixge_dt_ids); - static struct platform_driver nixge_driver = { .probe = nixge_probe, .remove = nixge_remove, -- 2.14.5