mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-09 23:34:42 +08:00
e6550b3ee1
Based on the normalized pattern: this program is free software you may redistribute it and/or modify it under the terms of the gnu general public license as published by the free software foundation version 2 of the license the software is provided as is without warranty of any kind express or implied including but not limited to the warranties of merchantability fitness for a particular purpose and noninfringement in no event shall the authors or copyright holders be liable for any claim damages or other liability whether in an action of contract tort or otherwise arising from out of or in connection with the software or the use or other dealings in the software extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
68 lines
1.8 KiB
C
68 lines
1.8 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright 2008 Cisco Systems, Inc. All rights reserved.
|
|
* Copyright 2007 Nuova Systems, Inc. All rights reserved.
|
|
*/
|
|
#ifndef _FNIC_IO_H_
|
|
#define _FNIC_IO_H_
|
|
|
|
#include <scsi/fc/fc_fcp.h>
|
|
|
|
#define FNIC_DFLT_SG_DESC_CNT 32
|
|
#define FNIC_MAX_SG_DESC_CNT 256 /* Maximum descriptors per sgl */
|
|
#define FNIC_SG_DESC_ALIGN 16 /* Descriptor address alignment */
|
|
|
|
struct host_sg_desc {
|
|
__le64 addr;
|
|
__le32 len;
|
|
u32 _resvd;
|
|
};
|
|
|
|
struct fnic_dflt_sgl_list {
|
|
struct host_sg_desc sg_desc[FNIC_DFLT_SG_DESC_CNT];
|
|
};
|
|
|
|
struct fnic_sgl_list {
|
|
struct host_sg_desc sg_desc[FNIC_MAX_SG_DESC_CNT];
|
|
};
|
|
|
|
enum fnic_sgl_list_type {
|
|
FNIC_SGL_CACHE_DFLT = 0, /* cache with default size sgl */
|
|
FNIC_SGL_CACHE_MAX, /* cache with max size sgl */
|
|
FNIC_SGL_NUM_CACHES /* number of sgl caches */
|
|
};
|
|
|
|
enum fnic_ioreq_state {
|
|
FNIC_IOREQ_NOT_INITED = 0,
|
|
FNIC_IOREQ_CMD_PENDING,
|
|
FNIC_IOREQ_ABTS_PENDING,
|
|
FNIC_IOREQ_ABTS_COMPLETE,
|
|
FNIC_IOREQ_CMD_COMPLETE,
|
|
};
|
|
|
|
struct fnic_io_req {
|
|
struct host_sg_desc *sgl_list; /* sgl list */
|
|
void *sgl_list_alloc; /* sgl list address used for free */
|
|
dma_addr_t sense_buf_pa; /* dma address for sense buffer*/
|
|
dma_addr_t sgl_list_pa; /* dma address for sgl list */
|
|
u16 sgl_cnt;
|
|
u8 sgl_type; /* device DMA descriptor list type */
|
|
u8 io_completed:1; /* set to 1 when fw completes IO */
|
|
u32 port_id; /* remote port DID */
|
|
unsigned long start_time; /* in jiffies */
|
|
struct completion *abts_done; /* completion for abts */
|
|
struct completion *dr_done; /* completion for device reset */
|
|
};
|
|
|
|
enum fnic_port_speeds {
|
|
DCEM_PORTSPEED_NONE = 0,
|
|
DCEM_PORTSPEED_1G = 1000,
|
|
DCEM_PORTSPEED_10G = 10000,
|
|
DCEM_PORTSPEED_20G = 20000,
|
|
DCEM_PORTSPEED_25G = 25000,
|
|
DCEM_PORTSPEED_40G = 40000,
|
|
DCEM_PORTSPEED_4x10G = 41000,
|
|
DCEM_PORTSPEED_100G = 100000,
|
|
};
|
|
#endif /* _FNIC_IO_H_ */
|