| /* Copyright (c) 2017, The Linux Foundation. All rights reserved. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 and |
| * only version 2 as published by the Free Software Foundation. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| * This file contain content copied from Synopsis driver, |
| * provided under the license below |
| */ |
| /* ========================================================================= |
| * The Synopsys DWC ETHER QOS Software Driver and documentation (hereinafter |
| * "Software") is an unsupported proprietary work of Synopsys, Inc. unless |
| * otherwise expressly agreed to in writing between Synopsys and you. |
| * |
| * The Software IS NOT an item of Licensed Software or Licensed Product under |
| * any End User Software License Agreement or Agreement for Licensed Product |
| * with Synopsys or any supplement thereto. Permission is hereby granted, |
| * free of charge, to any person obtaining a copy of this software annotated |
| * with this license and the Software, to deal in the Software without |
| * restriction, including without limitation the rights to use, copy, modify, |
| * merge, publish, distribute, sublicense, and/or sell copies of the Software, |
| * and to permit persons to whom the Software is furnished to do so, subject |
| * to the following conditions: |
| * |
| * The above copyright notice and this permission notice shall be included in |
| * all copies or substantial portions of the Software. |
| * |
| * THIS SOFTWARE IS BEING DISTRIBUTED BY SYNOPSYS SOLELY ON AN "AS IS" BASIS |
| * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| * ARE HEREBY DISCLAIMED. IN NO EVENT SHALL SYNOPSYS 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 __DWC_ETH_QOS_DRV_H__ |
| |
| #define __DWC_ETH_QOS_DRV_H__ |
| |
| static int DWC_ETH_QOS_open(struct net_device *); |
| |
| static int DWC_ETH_QOS_close(struct net_device *); |
| |
| static void DWC_ETH_QOS_set_rx_mode(struct net_device *); |
| |
| static int DWC_ETH_QOS_start_xmit(struct sk_buff *, struct net_device *); |
| |
| static void DWC_ETH_QOS_tx_interrupt(struct net_device *, |
| struct DWC_ETH_QOS_prv_data *, UINT); |
| |
| static struct net_device_stats *DWC_ETH_QOS_get_stats(struct net_device *); |
| |
| #ifdef CONFIG_NET_POLL_CONTROLLER |
| static void DWC_ETH_QOS_poll_controller(struct net_device *); |
| #endif /*end of CONFIG_NET_POLL_CONTROLLER */ |
| |
| static int DWC_ETH_QOS_set_features( |
| struct net_device *dev, netdev_features_t features); |
| |
| static netdev_features_t DWC_ETH_QOS_fix_features( |
| struct net_device *dev, netdev_features_t features); |
| |
| INT DWC_ETH_QOS_configure_remotewakeup(struct net_device *dev, |
| struct ifr_data_struct *req); |
| |
| static void DWC_ETH_QOS_program_dcb_algorithm( |
| struct DWC_ETH_QOS_prv_data *pdata, struct ifr_data_struct *req); |
| |
| static void DWC_ETH_QOS_program_avb_algorithm( |
| struct DWC_ETH_QOS_prv_data *pdata, struct ifr_data_struct *req); |
| |
| static void DWC_ETH_QOS_config_tx_pbl(struct DWC_ETH_QOS_prv_data *pdata, |
| UINT tx_pbl, UINT ch_no); |
| static void DWC_ETH_QOS_config_rx_pbl(struct DWC_ETH_QOS_prv_data *pdata, |
| UINT rx_pbl, UINT ch_no); |
| |
| static int DWC_ETH_QOS_handle_prv_ioctl(struct DWC_ETH_QOS_prv_data *pdata, |
| struct ifr_data_struct *req); |
| |
| static int DWC_ETH_QOS_handle_prv_ioctl_ipa(struct DWC_ETH_QOS_prv_data *pdata, |
| struct ifreq *ifr); |
| |
| static int DWC_ETH_QOS_ioctl(struct net_device *, struct ifreq *, int); |
| |
| static INT DWC_ETH_QOS_change_mtu(struct net_device *dev, INT new_mtu); |
| |
| static int DWC_ETH_QOS_clean_split_hdr_rx_irq( |
| struct DWC_ETH_QOS_prv_data *pdata, int quota, UINT); |
| |
| static int DWC_ETH_QOS_clean_jumbo_rx_irq(struct DWC_ETH_QOS_prv_data *pdata, |
| int quota, UINT); |
| |
| static int DWC_ETH_QOS_clean_rx_irq(struct DWC_ETH_QOS_prv_data *pdata, |
| int quota, UINT); |
| |
| static void DWC_ETH_QOS_consume_page(struct DWC_ETH_QOS_rx_buffer *buffer, |
| struct sk_buff *skb, |
| u16 length, u16 buf2_len); |
| |
| static void DWC_ETH_QOS_receive_skb(struct DWC_ETH_QOS_prv_data *pdata, |
| struct net_device *dev, |
| struct sk_buff *skb, |
| UINT); |
| |
| static void DWC_ETH_QOS_configure_rx_fun_ptr(struct DWC_ETH_QOS_prv_data |
| *pdata); |
| |
| static int DWC_ETH_QOS_alloc_split_hdr_rx_buf( |
| struct DWC_ETH_QOS_prv_data *pdata, |
| struct DWC_ETH_QOS_rx_buffer *buffer, |
| UINT qinx, gfp_t gfp); |
| |
| static int DWC_ETH_QOS_alloc_jumbo_rx_buf(struct DWC_ETH_QOS_prv_data *pdata, |
| struct DWC_ETH_QOS_rx_buffer *buffer, UINT qinx, |
| gfp_t gfp); |
| |
| static int DWC_ETH_QOS_alloc_rx_buf(struct DWC_ETH_QOS_prv_data *pdata, |
| struct DWC_ETH_QOS_rx_buffer *buffer, UINT qinx, |
| gfp_t gfp); |
| |
| static void DWC_ETH_QOS_default_common_confs(struct DWC_ETH_QOS_prv_data |
| *pdata); |
| static void DWC_ETH_QOS_default_tx_confs(struct DWC_ETH_QOS_prv_data *pdata); |
| static void DWC_ETH_QOS_default_tx_confs_single_q(struct DWC_ETH_QOS_prv_data |
| *pdata, UINT); |
| static void DWC_ETH_QOS_default_rx_confs(struct DWC_ETH_QOS_prv_data *pdata); |
| static void DWC_ETH_QOS_default_rx_confs_single_q(struct DWC_ETH_QOS_prv_data |
| *pdata, UINT); |
| |
| int DWC_ETH_QOS_poll(struct DWC_ETH_QOS_prv_data *pdata, int budget, int qinx); |
| |
| static void DWC_ETH_QOS_mmc_setup(struct DWC_ETH_QOS_prv_data *pdata); |
| inline unsigned int DWC_ETH_QOS_reg_read(volatile ULONG * ptr); |
| |
| #ifdef DWC_ETH_QOS_QUEUE_SELECT_ALGO |
| u16 DWC_ETH_QOS_select_queue(struct net_device *dev, struct sk_buff *skb, |
| void *accel_priv, select_queue_fallback_t fallback); |
| #endif |
| |
| static int DWC_ETH_QOS_vlan_rx_add_vid( |
| struct net_device *dev, __be16 proto, u16 vid); |
| static int DWC_ETH_QOS_vlan_rx_kill_vid(struct net_device *dev, |
| __be16 proto, u16 vid); |
| #endif |