mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-23 04:34:11 +08:00
93dd1911cf
Re-organize source for easier driver attribute management Signed-off-by: Dick Kennedy <dick.kennedy@broadcom.com> Signed-off-by: James Smart <james.smart@broadcom.com> Reviewed-by: Hannes Reinecke <hare@suse.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
117 lines
5.1 KiB
C
117 lines
5.1 KiB
C
/*******************************************************************
|
|
* This file is part of the Emulex Linux Device Driver for *
|
|
* Fibre Channel Host Bus Adapters. *
|
|
* Copyright (C) 2004-2016 Emulex. All rights reserved. *
|
|
* EMULEX and SLI are trademarks of Emulex. *
|
|
* www.emulex.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_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)
|