#ifndef _VNIC_WQ_H_
#define _VNIC_WQ_H_
#include <linux/pci.h>
#include "vnic_dev.h"
#include "vnic_cq.h"
struct vnic_wq_ctrl { … };
struct vnic_wq_buf { … };
#define VNIC_WQ_BUF_MIN_BLK_ENTRIES …
#define VNIC_WQ_BUF_DFLT_BLK_ENTRIES …
#define VNIC_WQ_BUF_BLK_ENTRIES(entries) …
#define VNIC_WQ_BUF_BLK_SZ(entries) …
#define VNIC_WQ_BUF_BLKS_NEEDED(entries) …
#define VNIC_WQ_BUF_BLKS_MAX …
struct vnic_wq { … };
struct devcmd2_controller { … };
static inline unsigned int vnic_wq_desc_avail(struct vnic_wq *wq)
{ … }
static inline unsigned int vnic_wq_desc_used(struct vnic_wq *wq)
{ … }
static inline void *vnic_wq_next_desc(struct vnic_wq *wq)
{ … }
static inline void vnic_wq_doorbell(struct vnic_wq *wq)
{ … }
static inline void vnic_wq_post(struct vnic_wq *wq,
void *os_buf, dma_addr_t dma_addr,
unsigned int len, int sop, int eop,
uint8_t desc_skip_cnt, uint8_t cq_entry,
uint8_t compressed_send, uint64_t wrid)
{ … }
static inline void vnic_wq_service(struct vnic_wq *wq,
struct cq_desc *cq_desc, u16 completed_index,
void (*buf_service)(struct vnic_wq *wq,
struct cq_desc *cq_desc, struct vnic_wq_buf *buf, void *opaque),
void *opaque)
{ … }
void vnic_wq_free(struct vnic_wq *wq);
int vnic_wq_alloc(struct vnic_dev *vdev, struct vnic_wq *wq, unsigned int index,
unsigned int desc_count, unsigned int desc_size);
void vnic_wq_init(struct vnic_wq *wq, unsigned int cq_index,
unsigned int error_interrupt_enable,
unsigned int error_interrupt_offset);
unsigned int vnic_wq_error_status(struct vnic_wq *wq);
void vnic_wq_enable(struct vnic_wq *wq);
int vnic_wq_disable(struct vnic_wq *wq);
void vnic_wq_clean(struct vnic_wq *wq,
void (*buf_clean)(struct vnic_wq *wq, struct vnic_wq_buf *buf));
int enic_wq_devcmd2_alloc(struct vnic_dev *vdev, struct vnic_wq *wq,
unsigned int desc_count, unsigned int desc_size);
void enic_wq_init_start(struct vnic_wq *wq, unsigned int cq_index,
unsigned int fetch_index, unsigned int posted_index,
unsigned int error_interrupt_enable,
unsigned int error_interrupt_offset);
#endif