44fd7fe3dd
Add Buffer to buffer credit recovery support to the driver. This is a negotiated feature with the peer that allows for both sides to detect dropped RRDY's and FC Frames and recover credit. Signed-off-by: Dick Kennedy <dick.kennedy@broadcom.com> Signed-off-by: James Smart <james.smart@broadcom.com> Reviewed-by: Johannes Thumshirn <jthumshirn@suse.de> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
129 lines
5.6 KiB
C
129 lines
5.6 KiB
C
/*******************************************************************
|
|
* This file is part of the Emulex Linux Device Driver for *
|
|
* Fibre Channel Host Bus Adapters. *
|
|
* Copyright (C) 2017 Broadcom. All Rights Reserved. The term *
|
|
* “Broadcom” refers to Broadcom Limited and/or its subsidiaries. *
|
|
* Copyright (C) 2004-2016 Emulex. All rights reserved. *
|
|
* EMULEX and SLI are trademarks of Emulex. *
|
|
* www.broadcom.com *
|
|
* Portions Copyright (C) 2004-2005 Christoph Hellwig *
|
|
* *
|
|
* This program is free software; you can redistribute it and/or *
|
|
* modify it under the terms of version 2 of the GNU General *
|
|
* Public License as published by the Free Software Foundation. *
|
|
* This program is distributed in the hope that it will be useful. *
|
|
* ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND *
|
|
* WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, *
|
|
* FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT, ARE *
|
|
* DISCLAIMED, EXCEPT TO THE EXTENT THAT SUCH DISCLAIMERS ARE HELD *
|
|
* TO BE LEGALLY INVALID. See the GNU General Public License for *
|
|
* more details, a copy of which can be found in the file COPYING *
|
|
* included with this package. *
|
|
*******************************************************************/
|
|
|
|
#define LPFC_ATTR(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_param_init(name, defval, minval, maxval)
|
|
|
|
#define LPFC_ATTR_R(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_param_show(name)\
|
|
lpfc_param_init(name, defval, minval, maxval)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO, lpfc_##name##_show, NULL)
|
|
|
|
#define LPFC_ATTR_RW(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_param_show(name)\
|
|
lpfc_param_init(name, defval, minval, maxval)\
|
|
lpfc_param_set(name, defval, minval, maxval)\
|
|
lpfc_param_store(name)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO | S_IWUSR,\
|
|
lpfc_##name##_show, lpfc_##name##_store)
|
|
|
|
#define LPFC_BBCR_ATTR_RW(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, 0444);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_param_show(name)\
|
|
lpfc_param_init(name, defval, minval, maxval)\
|
|
lpfc_param_store(name)\
|
|
static DEVICE_ATTR(lpfc_##name, 0444 | 0644,\
|
|
lpfc_##name##_show, lpfc_##name##_store)
|
|
|
|
#define LPFC_ATTR_HEX_R(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_param_hex_show(name)\
|
|
lpfc_param_init(name, defval, minval, maxval)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO, lpfc_##name##_show, NULL)
|
|
|
|
#define LPFC_ATTR_HEX_RW(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_param_hex_show(name)\
|
|
lpfc_param_init(name, defval, minval, maxval)\
|
|
lpfc_param_set(name, defval, minval, maxval)\
|
|
lpfc_param_store(name)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO | S_IWUSR,\
|
|
lpfc_##name##_show, lpfc_##name##_store)
|
|
|
|
#define LPFC_VPORT_ATTR(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_vport_param_init(name, defval, minval, maxval)
|
|
|
|
#define LPFC_VPORT_ATTR_R(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_vport_param_show(name)\
|
|
lpfc_vport_param_init(name, defval, minval, maxval)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO, lpfc_##name##_show, NULL)
|
|
|
|
#define LPFC_VPORT_ULL_ATTR_R(name, defval, minval, maxval, desc) \
|
|
static uint64_t lpfc_##name = defval;\
|
|
module_param(lpfc_##name, ullong, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_vport_param_show(name)\
|
|
lpfc_vport_param_init(name, defval, minval, maxval)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO, lpfc_##name##_show, NULL)
|
|
|
|
#define LPFC_VPORT_ATTR_RW(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_vport_param_show(name)\
|
|
lpfc_vport_param_init(name, defval, minval, maxval)\
|
|
lpfc_vport_param_set(name, defval, minval, maxval)\
|
|
lpfc_vport_param_store(name)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO | S_IWUSR,\
|
|
lpfc_##name##_show, lpfc_##name##_store)
|
|
|
|
#define LPFC_VPORT_ATTR_HEX_R(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_vport_param_hex_show(name)\
|
|
lpfc_vport_param_init(name, defval, minval, maxval)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO, lpfc_##name##_show, NULL)
|
|
|
|
#define LPFC_VPORT_ATTR_HEX_RW(name, defval, minval, maxval, desc) \
|
|
static uint lpfc_##name = defval;\
|
|
module_param(lpfc_##name, uint, S_IRUGO);\
|
|
MODULE_PARM_DESC(lpfc_##name, desc);\
|
|
lpfc_vport_param_hex_show(name)\
|
|
lpfc_vport_param_init(name, defval, minval, maxval)\
|
|
lpfc_vport_param_set(name, defval, minval, maxval)\
|
|
lpfc_vport_param_store(name)\
|
|
static DEVICE_ATTR(lpfc_##name, S_IRUGO | S_IWUSR,\
|
|
lpfc_##name##_show, lpfc_##name##_store)
|