From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752715AbbDAQTi (ORCPT ); Wed, 1 Apr 2015 12:19:38 -0400 Received: from mail-bn1bn0108.outbound.protection.outlook.com ([157.56.110.108]:36153 "EHLO na01-bn1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752042AbbDAQTe (ORCPT ); Wed, 1 Apr 2015 12:19:34 -0400 Authentication-Results: spf=fail (sender IP is 192.88.168.50) smtp.mailfrom=freescale.com; freescale.mail.onmicrosoft.com; dkim=none (message not signed) header.d=none; From: Madalin Bucur To: , CC: , Madalin Bucur Subject: [PATCH RFC 00/10] introduce DPAA Ethernet driver Date: Wed, 1 Apr 2015 19:19:25 +0300 Message-ID: <1427905165-27732-1-git-send-email-madalin.bucur@freescale.com> X-Mailer: git-send-email 1.5.6.5 Reply-To: X-EOPAttributedMessage: 0 X-Forefront-Antispam-Report: CIP:192.88.168.50;CTRY:US;IPV:NLI;EFV:NLI;BMV:1;SFV:NSPM;SFS:(10019020)(6009001)(339900001)(189002)(199003)(62966003)(50226001)(77156002)(48376002)(50986999)(47776003)(85426001)(50466002)(106466001)(104016003)(86362001)(105606002)(87936001)(19580395003)(49486002)(6806004)(229853001)(15975445007)(77096005)(46102003)(36756003)(33646002)(53806999)(43066003)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:BY2PR03MB554;H:tx30smr01.am.freescale.net;FPR:;SPF:Fail;MLV:sfv;MX:1;A:1;LANG:en; MIME-Version: 1.0 Content-Type: text/plain X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY2PR03MB554; X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(5002010)(5005006);SRVR:BY2PR03MB554;BCL:0;PCL:0;RULEID:;SRVR:BY2PR03MB554; X-Forefront-PRVS: 053315510E X-OriginatorOrg: freescale.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Apr 2015 16:19:29.9643 (UTC) X-MS-Exchange-CrossTenant-Id: 710a03f5-10f6-4d38-9ff4-a80b81da590d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=710a03f5-10f6-4d38-9ff4-a80b81da590d;Ip=[192.88.168.50];Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY2PR03MB554 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is the second version of a patch series that adds the Ethernet driver for the Freescale QorIQ Data Path Acceleration Architecture (DPAA). This second version includes the changes requested by Kumar Gala. The PM ops patch was removed as the supporting FMan driver code was de-featured from the first submission of the driver to reduce the review effort. Together with the driver a managed version of alloc_percpu is provided that simplifies the release of percpu memory. The Freescale DPAA architecture consists in a series of hardware blocks that support the Ethernet connectivity. the Ethernet driver depends upon the Peripheral Access Memory Unit (PAMU), Frame Manager (FMan), Queue Manager (QMan), Buffer Manager (BMan). Drivers for these blocks are currently in the kernel or in review. The current set of RFC patches is meant to provide early access to the codebase and also provide context and aid the review of the latest FMan driver patches submitted by Igal Liberman: [RFC,v2,12/12] soc/fman: Add FMan MAC driver [RFC,v2,11/12] soc/fman: Add FMan Port Support [RFC,v2,10/12] soc/fman: Add FMan SP support [RFC,v2,09/12] soc/fman: Add FMan MAC support [RFC,v2,08/12] soc/fman: Add Frame Manager support [RFC,v2,07/12] soc/fman: Add FMan MURAM support [RFC,v2,06/12] soc/fman: Add the FMan MAC FLIB [RFC,v2,05/12] soc/fman: Add the FMan MAC FLIB headers [RFC,v2,04/12] soc/fman: Add the FMan port FLIB [RFC,v2,03/12] soc/fman: Add the FMan port FLIB headers [RFC,v2,02/12] soc/fman: Add the FMan FLIB [RFC,v2,01/12] soc/fman: Add the FMan FLIB headers https://patchwork.ozlabs.org/project/linuxppc-dev/list/?submitter=Igal.Liberman&state=*&q=RFC%2Cv2 These patches rely also on the Q/BMan drivers submitted by Emil Medve: [RFC,v3,10/10] fsl_qman: Add HOTPLUG_CPU support [RFC,v3,09/10] fsl_bman: Add HOTPLUG_CPU support [RFC,v3,08/10] fsl_qman: Add debugfs support [RFC,v3,07/10] fsl_bman: Add debugfs support [RFC,v3,06/10] fsl_qman: Add self-tester [RFC,v3,05/10] fsl_bman: Add self-tester [RFC,v3,04/10] powerpc/mpc85xx: Add platform support for the Freescale DPAA QMan [RFC,v3,03/10] powerpc/mpc85xx: Add platform support for the Freescale DPAA BMan [RFC,v3,02/10] fsl_qman: Add drivers for the Freescale DPAA QMan [RFC,v3,01/10] fsl_bman: Add drivers for the Freescale DPAA BMan https://patchwork.ozlabs.org/project/linuxppc-dev/list/?submitter=Emil+Medve&state=*&q=RFC The DPAA Ethernet driver is the result of the collaborative work of many individuals, to name a few: Andy Fleming Emil Medve Kumar Gala Ioana Radulescu Bogdan Hamciuc Madalin Bucur Cristian Sovaiala Marian Rotariu Andrei Pistirica Cristian Bercaru The current patch set is the result of a sustained clean-up and adaptation work on the QorIQ DPAA drivers released in the open source Freescale SDK. The SDK drivers differ as they offer support for advanced accelerations and other features that are not upstreamable. The SDK Ethernet driver is based on a different, non-upstreamable variant of the FMan driver. The short term goal is to provide basic Ethernet support in the vanilla kernel then to gradually increase the feature set. The SDK documentation and source code, documentation for the DPAA hardware are available from the company website. Madalin Bucur (10): devres: add devm_alloc_percpu() dpaa_eth: add support for DPAA Ethernet dpaa_eth: add configurable bpool thresholds dpaa_eth: add support for S/G frames dpaa_eth: add driver's Tx queue selection mechanism dpaa_eth: add ethtool functionality dpaa_eth: add sysfs exports dpaa_eth: add debugfs counters dpaa_eth: add debugfs entries dpaa_eth: add trace points Documentation/driver-model/devres.txt | 4 + drivers/base/devres.c | 63 + drivers/net/ethernet/freescale/Kconfig | 2 + drivers/net/ethernet/freescale/Makefile | 1 + drivers/net/ethernet/freescale/dpaa/Kconfig | 87 ++ drivers/net/ethernet/freescale/dpaa/Makefile | 17 + drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.c | 273 ++++ drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.h | 43 + drivers/net/ethernet/freescale/dpaa/dpaa_eth.c | 881 +++++++++++++ drivers/net/ethernet/freescale/dpaa/dpaa_eth.h | 495 +++++++ .../net/ethernet/freescale/dpaa/dpaa_eth_common.c | 1387 ++++++++++++++++++++ .../net/ethernet/freescale/dpaa/dpaa_eth_common.h | 130 ++ drivers/net/ethernet/freescale/dpaa/dpaa_eth_sg.c | 725 ++++++++++ .../net/ethernet/freescale/dpaa/dpaa_eth_sysfs.c | 168 +++ .../net/ethernet/freescale/dpaa/dpaa_eth_trace.h | 143 ++ drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c | 254 ++++ include/linux/device.h | 19 + 17 files changed, 4692 insertions(+) create mode 100644 drivers/net/ethernet/freescale/dpaa/Kconfig create mode 100644 drivers/net/ethernet/freescale/dpaa/Makefile create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_common.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_common.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_sg.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_sysfs.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_trace.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c -- 1.7.11.7 From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from na01-bl2-obe.outbound.protection.outlook.com (mail-bl2on0118.outbound.protection.outlook.com [65.55.169.118]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by lists.ozlabs.org (Postfix) with ESMTPS id 32A871A0058 for ; Thu, 2 Apr 2015 03:53:22 +1100 (AEDT) From: Madalin Bucur To: , Subject: [PATCH RFC 00/10] introduce DPAA Ethernet driver Date: Wed, 1 Apr 2015 19:19:25 +0300 Message-ID: <1427905165-27732-1-git-send-email-madalin.bucur@freescale.com> Reply-To: MIME-Version: 1.0 Content-Type: text/plain Cc: linux-kernel@vger.kernel.org, Madalin Bucur List-Id: Linux on PowerPC Developers Mail List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , This is the second version of a patch series that adds the Ethernet driver for the Freescale QorIQ Data Path Acceleration Architecture (DPAA). This second version includes the changes requested by Kumar Gala. The PM ops patch was removed as the supporting FMan driver code was de-featured from the first submission of the driver to reduce the review effort. Together with the driver a managed version of alloc_percpu is provided that simplifies the release of percpu memory. The Freescale DPAA architecture consists in a series of hardware blocks that support the Ethernet connectivity. the Ethernet driver depends upon the Peripheral Access Memory Unit (PAMU), Frame Manager (FMan), Queue Manager (QMan), Buffer Manager (BMan). Drivers for these blocks are currently in the kernel or in review. The current set of RFC patches is meant to provide early access to the codebase and also provide context and aid the review of the latest FMan driver patches submitted by Igal Liberman: [RFC,v2,12/12] soc/fman: Add FMan MAC driver [RFC,v2,11/12] soc/fman: Add FMan Port Support [RFC,v2,10/12] soc/fman: Add FMan SP support [RFC,v2,09/12] soc/fman: Add FMan MAC support [RFC,v2,08/12] soc/fman: Add Frame Manager support [RFC,v2,07/12] soc/fman: Add FMan MURAM support [RFC,v2,06/12] soc/fman: Add the FMan MAC FLIB [RFC,v2,05/12] soc/fman: Add the FMan MAC FLIB headers [RFC,v2,04/12] soc/fman: Add the FMan port FLIB [RFC,v2,03/12] soc/fman: Add the FMan port FLIB headers [RFC,v2,02/12] soc/fman: Add the FMan FLIB [RFC,v2,01/12] soc/fman: Add the FMan FLIB headers https://patchwork.ozlabs.org/project/linuxppc-dev/list/?submitter=Igal.Liberman&state=*&q=RFC%2Cv2 These patches rely also on the Q/BMan drivers submitted by Emil Medve: [RFC,v3,10/10] fsl_qman: Add HOTPLUG_CPU support [RFC,v3,09/10] fsl_bman: Add HOTPLUG_CPU support [RFC,v3,08/10] fsl_qman: Add debugfs support [RFC,v3,07/10] fsl_bman: Add debugfs support [RFC,v3,06/10] fsl_qman: Add self-tester [RFC,v3,05/10] fsl_bman: Add self-tester [RFC,v3,04/10] powerpc/mpc85xx: Add platform support for the Freescale DPAA QMan [RFC,v3,03/10] powerpc/mpc85xx: Add platform support for the Freescale DPAA BMan [RFC,v3,02/10] fsl_qman: Add drivers for the Freescale DPAA QMan [RFC,v3,01/10] fsl_bman: Add drivers for the Freescale DPAA BMan https://patchwork.ozlabs.org/project/linuxppc-dev/list/?submitter=Emil+Medve&state=*&q=RFC The DPAA Ethernet driver is the result of the collaborative work of many individuals, to name a few: Andy Fleming Emil Medve Kumar Gala Ioana Radulescu Bogdan Hamciuc Madalin Bucur Cristian Sovaiala Marian Rotariu Andrei Pistirica Cristian Bercaru The current patch set is the result of a sustained clean-up and adaptation work on the QorIQ DPAA drivers released in the open source Freescale SDK. The SDK drivers differ as they offer support for advanced accelerations and other features that are not upstreamable. The SDK Ethernet driver is based on a different, non-upstreamable variant of the FMan driver. The short term goal is to provide basic Ethernet support in the vanilla kernel then to gradually increase the feature set. The SDK documentation and source code, documentation for the DPAA hardware are available from the company website. Madalin Bucur (10): devres: add devm_alloc_percpu() dpaa_eth: add support for DPAA Ethernet dpaa_eth: add configurable bpool thresholds dpaa_eth: add support for S/G frames dpaa_eth: add driver's Tx queue selection mechanism dpaa_eth: add ethtool functionality dpaa_eth: add sysfs exports dpaa_eth: add debugfs counters dpaa_eth: add debugfs entries dpaa_eth: add trace points Documentation/driver-model/devres.txt | 4 + drivers/base/devres.c | 63 + drivers/net/ethernet/freescale/Kconfig | 2 + drivers/net/ethernet/freescale/Makefile | 1 + drivers/net/ethernet/freescale/dpaa/Kconfig | 87 ++ drivers/net/ethernet/freescale/dpaa/Makefile | 17 + drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.c | 273 ++++ drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.h | 43 + drivers/net/ethernet/freescale/dpaa/dpaa_eth.c | 881 +++++++++++++ drivers/net/ethernet/freescale/dpaa/dpaa_eth.h | 495 +++++++ .../net/ethernet/freescale/dpaa/dpaa_eth_common.c | 1387 ++++++++++++++++++++ .../net/ethernet/freescale/dpaa/dpaa_eth_common.h | 130 ++ drivers/net/ethernet/freescale/dpaa/dpaa_eth_sg.c | 725 ++++++++++ .../net/ethernet/freescale/dpaa/dpaa_eth_sysfs.c | 168 +++ .../net/ethernet/freescale/dpaa/dpaa_eth_trace.h | 143 ++ drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c | 254 ++++ include/linux/device.h | 19 + 17 files changed, 4692 insertions(+) create mode 100644 drivers/net/ethernet/freescale/dpaa/Kconfig create mode 100644 drivers/net/ethernet/freescale/dpaa/Makefile create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_debugfs.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_common.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_common.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_sg.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_sysfs.c create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_eth_trace.h create mode 100644 drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c -- 1.7.11.7