/* <:copyright-BRCM:2015:DUAL/GPL:standard Copyright (c) 2015 Broadcom 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, as published by the Free Software Foundation (the "GPL"). 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. A copy of the GPL is available at http://www.broadcom.com/licenses/GPLv2.php, or by writing to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. :> */ /* * Created on: Nov/2015 * Author: ido@broadcom.com */ #include "port.h" #include "enet.h" #include #include #include #include #include "enet_dbg.h" inline int runner_get_pkt_from_ring(int hw_q_id, rdpa_cpu_rx_info_t *info) { return rdpa_cpu_packet_get(rdpa_cpu_host, hw_q_id, info); } inline int enetxapi_queue_need_reschedule(enetx_channel *chan, int q_id) { /* If the queue got full during handling of packets, new packets will not cause * interrupt (they will be dropped without interrupt). In this case, no one * will wake up NAPI, ever. */ #ifdef XRDP /*The solution is to schedule another NAPI round * if the queue is full. */ return rdpa_cpu_queue_is_full(rdpa_cpu_host, chan->rx_q[q_id]); #else /*The solution is to schedule another NAPI round * if the queue is not empty due to ring implementation we can't get is ring is full in acceptable way. */ return rdpa_cpu_queue_not_empty(rdpa_cpu_host, chan->rx_q[q_id]); #endif } int runner_ring_create_delete(enetx_channel *chan, int q_id, int size, rdpa_cpu_rxq_cfg_t *rxq_cfg) { rxq_cfg->ring_head = NULL; /* NULL required by RDPA to create AND REMOVE rdp_ring */ return 0; }