dpaa_eth: add support for DPAA Ethernet
This introduces the Freescale Data Path Acceleration Architecture (DPAA) Ethernet driver (dpaa_eth) that builds upon the DPAA QMan, BMan, PAMU and FMan drivers to deliver Ethernet connectivity on the Freescale DPAA QorIQ platforms. Signed-off-by: Madalin Bucur <madalin.bucur@nxp.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									ff86aae3b4
								
							
						
					
					
						commit
						9ad1a37493
					
				| @ -93,4 +93,6 @@ config GIANFAR | ||||
| 	  and MPC86xx family of chips, the eTSEC on LS1021A and the FEC | ||||
| 	  on the 8540. | ||||
| 
 | ||||
| source "drivers/net/ethernet/freescale/dpaa/Kconfig" | ||||
| 
 | ||||
| endif # NET_VENDOR_FREESCALE | ||||
|  | ||||
| @ -22,3 +22,4 @@ obj-$(CONFIG_UCC_GETH) += ucc_geth_driver.o | ||||
| ucc_geth_driver-objs := ucc_geth.o ucc_geth_ethtool.o | ||||
| 
 | ||||
| obj-$(CONFIG_FSL_FMAN) += fman/ | ||||
| obj-$(CONFIG_FSL_DPAA_ETH) += dpaa/ | ||||
|  | ||||
							
								
								
									
										10
									
								
								drivers/net/ethernet/freescale/dpaa/Kconfig
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								drivers/net/ethernet/freescale/dpaa/Kconfig
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | ||||
| menuconfig FSL_DPAA_ETH | ||||
| 	tristate "DPAA Ethernet" | ||||
| 	depends on FSL_SOC && FSL_DPAA && FSL_FMAN | ||||
| 	select PHYLIB | ||||
| 	select FSL_FMAN_MAC | ||||
| 	---help--- | ||||
| 	  Data Path Acceleration Architecture Ethernet driver, | ||||
| 	  supporting the Freescale QorIQ chips. | ||||
| 	  Depends on Freescale Buffer Manager and Queue Manager | ||||
| 	  driver and Frame Manager Driver. | ||||
							
								
								
									
										11
									
								
								drivers/net/ethernet/freescale/dpaa/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								drivers/net/ethernet/freescale/dpaa/Makefile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| #
 | ||||
| # Makefile for the Freescale DPAA Ethernet controllers
 | ||||
| #
 | ||||
| 
 | ||||
| # Include FMan headers
 | ||||
| FMAN        = $(srctree)/drivers/net/ethernet/freescale/fman | ||||
| ccflags-y += -I$(FMAN) | ||||
| 
 | ||||
| obj-$(CONFIG_FSL_DPAA_ETH) += fsl_dpa.o | ||||
| 
 | ||||
| fsl_dpa-objs += dpaa_eth.o | ||||
							
								
								
									
										2682
									
								
								drivers/net/ethernet/freescale/dpaa/dpaa_eth.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2682
									
								
								drivers/net/ethernet/freescale/dpaa/dpaa_eth.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										144
									
								
								drivers/net/ethernet/freescale/dpaa/dpaa_eth.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										144
									
								
								drivers/net/ethernet/freescale/dpaa/dpaa_eth.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,144 @@ | ||||
| /* Copyright 2008 - 2016 Freescale Semiconductor Inc.
 | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  *     * Redistributions of source code must retain the above copyright | ||||
|  *	 notice, this list of conditions and the following disclaimer. | ||||
|  *     * Redistributions in binary form must reproduce the above copyright | ||||
|  *	 notice, this list of conditions and the following disclaimer in the | ||||
|  *	 documentation and/or other materials provided with the distribution. | ||||
|  *     * Neither the name of Freescale Semiconductor nor the | ||||
|  *	 names of its contributors may be used to endorse or promote products | ||||
|  *	 derived from this software without specific prior written permission. | ||||
|  * | ||||
|  * ALTERNATIVELY, this software may be distributed under the terms of the | ||||
|  * GNU General Public License ("GPL") as published by the Free Software | ||||
|  * Foundation, either version 2 of that License or (at your option) any | ||||
|  * later version. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY Freescale Semiconductor ``AS IS'' AND ANY | ||||
|  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||||
|  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|  * DISCLAIMED. IN NO EVENT SHALL Freescale Semiconductor BE LIABLE FOR ANY | ||||
|  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||||
|  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||
|  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||||
|  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef __DPAA_H | ||||
| #define __DPAA_H | ||||
| 
 | ||||
| #include <linux/netdevice.h> | ||||
| #include <soc/fsl/qman.h> | ||||
| #include <soc/fsl/bman.h> | ||||
| 
 | ||||
| #include "fman.h" | ||||
| #include "mac.h" | ||||
| 
 | ||||
| #define DPAA_ETH_TXQ_NUM	NR_CPUS | ||||
| 
 | ||||
| #define DPAA_BPS_NUM 3 /* number of bpools per interface */ | ||||
| 
 | ||||
| /* More detailed FQ types - used for fine-grained WQ assignments */ | ||||
| enum dpaa_fq_type { | ||||
| 	FQ_TYPE_RX_DEFAULT = 1, /* Rx Default FQs */ | ||||
| 	FQ_TYPE_RX_ERROR,	/* Rx Error FQs */ | ||||
| 	FQ_TYPE_TX,		/* "Real" Tx FQs */ | ||||
| 	FQ_TYPE_TX_CONFIRM,	/* Tx default Conf FQ (actually an Rx FQ) */ | ||||
| 	FQ_TYPE_TX_CONF_MQ,	/* Tx conf FQs (one for each Tx FQ) */ | ||||
| 	FQ_TYPE_TX_ERROR,	/* Tx Error FQs (these are actually Rx FQs) */ | ||||
| }; | ||||
| 
 | ||||
| struct dpaa_fq { | ||||
| 	struct qman_fq fq_base; | ||||
| 	struct list_head list; | ||||
| 	struct net_device *net_dev; | ||||
| 	bool init; | ||||
| 	u32 fqid; | ||||
| 	u32 flags; | ||||
| 	u16 channel; | ||||
| 	u8 wq; | ||||
| 	enum dpaa_fq_type fq_type; | ||||
| }; | ||||
| 
 | ||||
| struct dpaa_fq_cbs { | ||||
| 	struct qman_fq rx_defq; | ||||
| 	struct qman_fq tx_defq; | ||||
| 	struct qman_fq rx_errq; | ||||
| 	struct qman_fq tx_errq; | ||||
| 	struct qman_fq egress_ern; | ||||
| }; | ||||
| 
 | ||||
| struct dpaa_bp { | ||||
| 	/* device used in the DMA mapping operations */ | ||||
| 	struct device *dev; | ||||
| 	/* current number of buffers in the buffer pool alloted to each CPU */ | ||||
| 	int __percpu *percpu_count; | ||||
| 	/* all buffers allocated for this pool have this raw size */ | ||||
| 	size_t raw_size; | ||||
| 	/* all buffers in this pool have this same usable size */ | ||||
| 	size_t size; | ||||
| 	/* the buffer pools are initialized with config_count buffers for each
 | ||||
| 	 * CPU; at runtime the number of buffers per CPU is constantly brought | ||||
| 	 * back to this level | ||||
| 	 */ | ||||
| 	u16 config_count; | ||||
| 	u8 bpid; | ||||
| 	struct bman_pool *pool; | ||||
| 	/* bpool can be seeded before use by this cb */ | ||||
| 	int (*seed_cb)(struct dpaa_bp *); | ||||
| 	/* bpool can be emptied before freeing by this cb */ | ||||
| 	void (*free_buf_cb)(const struct dpaa_bp *, struct bm_buffer *); | ||||
| 	atomic_t refs; | ||||
| }; | ||||
| 
 | ||||
| struct dpaa_napi_portal { | ||||
| 	struct napi_struct napi; | ||||
| 	struct qman_portal *p; | ||||
| 	bool down; | ||||
| }; | ||||
| 
 | ||||
| struct dpaa_percpu_priv { | ||||
| 	struct net_device *net_dev; | ||||
| 	struct dpaa_napi_portal np; | ||||
| 	struct rtnl_link_stats64 stats; | ||||
| }; | ||||
| 
 | ||||
| struct dpaa_buffer_layout { | ||||
| 	u16 priv_data_size; | ||||
| }; | ||||
| 
 | ||||
| struct dpaa_priv { | ||||
| 	struct dpaa_percpu_priv __percpu *percpu_priv; | ||||
| 	struct dpaa_bp *dpaa_bps[DPAA_BPS_NUM]; | ||||
| 	/* Store here the needed Tx headroom for convenience and speed
 | ||||
| 	 * (even though it can be computed based on the fields of buf_layout) | ||||
| 	 */ | ||||
| 	u16 tx_headroom; | ||||
| 	struct net_device *net_dev; | ||||
| 	struct mac_device *mac_dev; | ||||
| 	struct qman_fq *egress_fqs[DPAA_ETH_TXQ_NUM]; | ||||
| 	struct qman_fq *conf_fqs[DPAA_ETH_TXQ_NUM]; | ||||
| 
 | ||||
| 	u16 channel; | ||||
| 	struct list_head dpaa_fq_list; | ||||
| 
 | ||||
| 	u32 msg_enable;	/* net_device message level */ | ||||
| 
 | ||||
| 	struct { | ||||
| 		/* All egress queues to a given net device belong to one
 | ||||
| 		 * (and the same) congestion group. | ||||
| 		 */ | ||||
| 		struct qman_cgr cgr; | ||||
| 	} cgr_data; | ||||
| 	/* Use a per-port CGR for ingress traffic. */ | ||||
| 	bool use_ingress_cgr; | ||||
| 	struct qman_cgr ingress_cgr; | ||||
| 
 | ||||
| 	struct dpaa_buffer_layout buf_layout[2]; | ||||
| 	u16 rx_headroom; | ||||
| }; | ||||
| #endif	/* __DPAA_H */ | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user