#include <linux/bug.h>
#include <linux/device.h>
#include <linux/dma-mapping.h>
#include <linux/errno.h>
#include <linux/kstrtox.h>
#include <linux/list.h>
#include <linux/nls.h>
#include <linux/pm_runtime.h>
#include <linux/slab.h>
#include <linux/spinlock.h>
#include <linux/string.h>
#include <linux/sysfs.h>
#include <linux/types.h>
#include <linux/workqueue.h>
#include <linux/io-64-nonatomic-lo-hi.h>
#include <asm/byteorder.h>
#include "xhci.h"
#include "xhci-trace.h"
#include "xhci-dbgcap.h"
static void dbc_free_ctx(struct device *dev, struct xhci_container_ctx *ctx)
{ … }
static void dbc_ring_free(struct device *dev, struct xhci_ring *ring)
{ … }
static u32 xhci_dbc_populate_strings(struct dbc_str_descs *strings)
{ … }
static void xhci_dbc_init_contexts(struct xhci_dbc *dbc, u32 string_length)
{ … }
static void xhci_dbc_giveback(struct dbc_request *req, int status)
__releases(&dbc->lock)
__acquires(&dbc->lock)
{ … }
static void trb_to_noop(union xhci_trb *trb)
{ … }
static void xhci_dbc_flush_single_request(struct dbc_request *req)
{ … }
static void xhci_dbc_flush_endpoint_requests(struct dbc_ep *dep)
{ … }
static void xhci_dbc_flush_requests(struct xhci_dbc *dbc)
{ … }
struct dbc_request *
dbc_alloc_request(struct xhci_dbc *dbc, unsigned int direction, gfp_t flags)
{ … }
void
dbc_free_request(struct dbc_request *req)
{ … }
static void
xhci_dbc_queue_trb(struct xhci_ring *ring, u32 field1,
u32 field2, u32 field3, u32 field4)
{ … }
static int xhci_dbc_queue_bulk_tx(struct dbc_ep *dep,
struct dbc_request *req)
{ … }
static int
dbc_ep_do_queue(struct dbc_request *req)
{ … }
int dbc_ep_queue(struct dbc_request *req)
{ … }
static inline void xhci_dbc_do_eps_init(struct xhci_dbc *dbc, bool direction)
{ … }
static void xhci_dbc_eps_init(struct xhci_dbc *dbc)
{ … }
static void xhci_dbc_eps_exit(struct xhci_dbc *dbc)
{ … }
static int dbc_erst_alloc(struct device *dev, struct xhci_ring *evt_ring,
struct xhci_erst *erst, gfp_t flags)
{ … }
static void dbc_erst_free(struct device *dev, struct xhci_erst *erst)
{ … }
static struct xhci_container_ctx *
dbc_alloc_ctx(struct device *dev, gfp_t flags)
{ … }
static struct xhci_ring *
xhci_dbc_ring_alloc(struct device *dev, enum xhci_ring_type type, gfp_t flags)
{ … }
static int xhci_dbc_mem_init(struct xhci_dbc *dbc, gfp_t flags)
{ … }
static void xhci_dbc_mem_cleanup(struct xhci_dbc *dbc)
{ … }
static int xhci_do_dbc_start(struct xhci_dbc *dbc)
{ … }
static int xhci_do_dbc_stop(struct xhci_dbc *dbc)
{ … }
static int xhci_dbc_start(struct xhci_dbc *dbc)
{ … }
static void xhci_dbc_stop(struct xhci_dbc *dbc)
{ … }
static void
handle_ep_halt_changes(struct xhci_dbc *dbc, struct dbc_ep *dep, bool halted)
{ … }
static void
dbc_handle_port_status(struct xhci_dbc *dbc, union xhci_trb *event)
{ … }
static void dbc_handle_xfer_event(struct xhci_dbc *dbc, union xhci_trb *event)
{ … }
static void inc_evt_deq(struct xhci_ring *ring)
{ … }
static enum evtreturn xhci_dbc_do_handle_events(struct xhci_dbc *dbc)
{ … }
static void xhci_dbc_handle_events(struct work_struct *work)
{ … }
static const char * const dbc_state_strings[DS_MAX] = …;
static ssize_t dbc_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{ … }
static ssize_t dbc_store(struct device *dev,
struct device_attribute *attr,
const char *buf, size_t count)
{ … }
static ssize_t dbc_idVendor_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{ … }
static ssize_t dbc_idVendor_store(struct device *dev,
struct device_attribute *attr,
const char *buf, size_t size)
{ … }
static ssize_t dbc_idProduct_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{ … }
static ssize_t dbc_idProduct_store(struct device *dev,
struct device_attribute *attr,
const char *buf, size_t size)
{ … }
static ssize_t dbc_bcdDevice_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{ … }
static ssize_t dbc_bcdDevice_store(struct device *dev,
struct device_attribute *attr,
const char *buf, size_t size)
{ … }
static ssize_t dbc_bInterfaceProtocol_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{ … }
static ssize_t dbc_bInterfaceProtocol_store(struct device *dev,
struct device_attribute *attr,
const char *buf, size_t size)
{ … }
static ssize_t dbc_poll_interval_ms_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{ … }
static ssize_t dbc_poll_interval_ms_store(struct device *dev,
struct device_attribute *attr,
const char *buf, size_t size)
{ … }
static DEVICE_ATTR_RW(dbc);
static DEVICE_ATTR_RW(dbc_idVendor);
static DEVICE_ATTR_RW(dbc_idProduct);
static DEVICE_ATTR_RW(dbc_bcdDevice);
static DEVICE_ATTR_RW(dbc_bInterfaceProtocol);
static DEVICE_ATTR_RW(dbc_poll_interval_ms);
static struct attribute *dbc_dev_attrs[] = …;
ATTRIBUTE_GROUPS(…);
struct xhci_dbc *
xhci_alloc_dbc(struct device *dev, void __iomem *base, const struct dbc_driver *driver)
{ … }
void xhci_dbc_remove(struct xhci_dbc *dbc)
{ … }
int xhci_create_dbc_dev(struct xhci_hcd *xhci)
{ … }
void xhci_remove_dbc_dev(struct xhci_hcd *xhci)
{ … }
#ifdef CONFIG_PM
int xhci_dbc_suspend(struct xhci_hcd *xhci)
{ … }
int xhci_dbc_resume(struct xhci_hcd *xhci)
{ … }
#endif
int xhci_dbc_init(void)
{ … }
void xhci_dbc_exit(void)
{ … }