/* * Copyright (C) 2003-2008 Takahiro Hirofuchi * * This is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This 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. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, * USA. */ #ifndef __USBIP_STUB_H #define __USBIP_STUB_H #include #include #include #include #include #include #define STUB_BUSID_OTHER 0 #define STUB_BUSID_REMOV 1 #define STUB_BUSID_ADDED 2 #define STUB_BUSID_ALLOC 3 struct stub_device { struct usb_device *udev; struct usbip_device ud; __u32 devid; /* * stub_priv preserves private data of each urb. * It is allocated as stub_priv_cache and assigned to urb->context. * * stub_priv is always linked to any one of 3 lists; * priv_init: linked to this until the comletion of a urb. * priv_tx : linked to this after the completion of a urb. * priv_free: linked to this after the sending of the result. * * Any of these list operations should be locked by priv_lock. */ spinlock_t priv_lock; struct list_head priv_init; struct list_head priv_tx; struct list_head priv_free; /* see comments for unlinking in stub_rx.c */ struct list_head unlink_tx; struct list_head unlink_free; wait_queue_head_t tx_waitq; }; /* private data into urb->priv */ struct stub_priv { unsigned long seqnum; struct list_head list; struct stub_device *sdev; struct urb *urb; int unlinking; }; struct stub_unlink { unsigned long seqnum; struct list_head list; __u32 status; }; /* same as SYSFS_BUS_ID_SIZE */ #define BUSID_SIZE 32 struct bus_id_priv { char name[BUSID_SIZE]; char status; int interf_count; struct stub_device *sdev; struct usb_device *udev; char shutdown_busid; }; /* stub_priv is allocated from stub_priv_cache */ extern struct kmem_cache *stub_priv_cache; /* stub_dev.c */ extern struct usb_device_driver stub_driver; /* stub_main.c */ struct bus_id_priv *get_busid_priv(const char *busid); int del_match_busid(char *busid); void stub_device_cleanup_urbs(struct stub_device *sdev); /* stub_rx.c */ int stub_rx_loop(void *data); /* stub_tx.c */ void stub_enqueue_ret_unlink(struct stub_device *sdev, __u32 seqnum, __u32 status); void stub_complete(struct urb *urb); int stub_tx_loop(void *data); #endif /* __USBIP_STUB_H */ 8c05e74cfa7e59'>root/drivers
diff options
context:
space:
mode:
authorMichael Chan <michael.chan@broadcom.com>2017-02-06 16:55:36 -0500
committerDavid S. Miller <davem@davemloft.net>2017-02-07 13:30:58 -0500
commitc61fb99cae51958a9096d8540c8c05e74cfa7e59 (patch)
treecc6709a1220c71163a11029b7c0b61d0217e39a2 /drivers
parentb3dba77cf0acb6e44b368979026df975658332bc (diff)
bnxt_en: Add RX page mode support.
This mode is to support XDP. In this mode, each rx ring is configured with page sized buffers for linear placement of each packet. MTU will be restricted to what the page sized buffers can support. Signed-off-by: Michael Chan <michael.chan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/ethernet/broadcom/bnxt/bnxt.c135
-rw-r--r--drivers/net/ethernet/broadcom/bnxt/bnxt.h7
2 files changed, 124 insertions, 18 deletions
diff --git a/drivers/net/ethernet/broadcom/bnxt/bnxt.c b/drivers/net/ethernet/broadcom/bnxt/bnxt.c