[SCSI] fcoe: moves common FCoE library API functions to libfcoe module
Moves these functions as-is from fcoe.c to libfcoe.c, since they're are common routines: - fcoe_wwn_from_mac - fcoe_libfc_config Signed-off-by: Vasu Dev <vasu.dev@intel.com> Signed-off-by: Robert Love <robert.w.love@intel.com> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
This commit is contained in:
committed by
James Bottomley
parent
9b34ecffd5
commit
5e80f7f7c8
@@ -1765,47 +1765,6 @@ int fcoe_reset(struct Scsi_Host *shost)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(fcoe_reset);
|
EXPORT_SYMBOL_GPL(fcoe_reset);
|
||||||
|
|
||||||
/**
|
|
||||||
* fcoe_wwn_from_mac() - Converts 48-bit IEEE MAC address to 64-bit FC WWN.
|
|
||||||
* @mac: mac address
|
|
||||||
* @scheme: check port
|
|
||||||
* @port: port indicator for converting
|
|
||||||
*
|
|
||||||
* Returns: u64 fc world wide name
|
|
||||||
*/
|
|
||||||
u64 fcoe_wwn_from_mac(unsigned char mac[MAX_ADDR_LEN],
|
|
||||||
unsigned int scheme, unsigned int port)
|
|
||||||
{
|
|
||||||
u64 wwn;
|
|
||||||
u64 host_mac;
|
|
||||||
|
|
||||||
/* The MAC is in NO, so flip only the low 48 bits */
|
|
||||||
host_mac = ((u64) mac[0] << 40) |
|
|
||||||
((u64) mac[1] << 32) |
|
|
||||||
((u64) mac[2] << 24) |
|
|
||||||
((u64) mac[3] << 16) |
|
|
||||||
((u64) mac[4] << 8) |
|
|
||||||
(u64) mac[5];
|
|
||||||
|
|
||||||
WARN_ON(host_mac >= (1ULL << 48));
|
|
||||||
wwn = host_mac | ((u64) scheme << 60);
|
|
||||||
switch (scheme) {
|
|
||||||
case 1:
|
|
||||||
WARN_ON(port != 0);
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
WARN_ON(port >= 0xfff);
|
|
||||||
wwn |= (u64) port << 48;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
WARN_ON(1);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return wwn;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(fcoe_wwn_from_mac);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* fcoe_hostlist_lookup_softc() - find the corresponding lport by a given device
|
* fcoe_hostlist_lookup_softc() - find the corresponding lport by a given device
|
||||||
* @device: this is currently ptr to net_device
|
* @device: this is currently ptr to net_device
|
||||||
@@ -1885,29 +1844,6 @@ int fcoe_hostlist_remove(const struct fc_lport *lp)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(fcoe_hostlist_remove);
|
EXPORT_SYMBOL_GPL(fcoe_hostlist_remove);
|
||||||
|
|
||||||
/**
|
|
||||||
* fcoe_libfc_config() - sets up libfc related properties for lport
|
|
||||||
* @lp: ptr to the fc_lport
|
|
||||||
* @tt: libfc function template
|
|
||||||
*
|
|
||||||
* Returns : 0 for success
|
|
||||||
*/
|
|
||||||
int fcoe_libfc_config(struct fc_lport *lp, struct libfc_function_template *tt)
|
|
||||||
{
|
|
||||||
/* Set the function pointers set by the LLDD */
|
|
||||||
memcpy(&lp->tt, tt, sizeof(*tt));
|
|
||||||
if (fc_fcp_init(lp))
|
|
||||||
return -ENOMEM;
|
|
||||||
fc_exch_init(lp);
|
|
||||||
fc_elsct_init(lp);
|
|
||||||
fc_lport_init(lp);
|
|
||||||
fc_rport_init(lp);
|
|
||||||
fc_disc_init(lp);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(fcoe_libfc_config);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* fcoe_init() - fcoe module loading initialization
|
* fcoe_init() - fcoe module loading initialization
|
||||||
*
|
*
|
||||||
|
@@ -18,7 +18,74 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
|
#include <linux/netdevice.h>
|
||||||
|
|
||||||
|
#include <scsi/libfc.h>
|
||||||
|
|
||||||
MODULE_AUTHOR("Open-FCoE.org");
|
MODULE_AUTHOR("Open-FCoE.org");
|
||||||
MODULE_DESCRIPTION("FCoE");
|
MODULE_DESCRIPTION("FCoE");
|
||||||
MODULE_LICENSE("GPL v2");
|
MODULE_LICENSE("GPL v2");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* fcoe_wwn_from_mac() - Converts 48-bit IEEE MAC address to 64-bit FC WWN.
|
||||||
|
* @mac: mac address
|
||||||
|
* @scheme: check port
|
||||||
|
* @port: port indicator for converting
|
||||||
|
*
|
||||||
|
* Returns: u64 fc world wide name
|
||||||
|
*/
|
||||||
|
u64 fcoe_wwn_from_mac(unsigned char mac[MAX_ADDR_LEN],
|
||||||
|
unsigned int scheme, unsigned int port)
|
||||||
|
{
|
||||||
|
u64 wwn;
|
||||||
|
u64 host_mac;
|
||||||
|
|
||||||
|
/* The MAC is in NO, so flip only the low 48 bits */
|
||||||
|
host_mac = ((u64) mac[0] << 40) |
|
||||||
|
((u64) mac[1] << 32) |
|
||||||
|
((u64) mac[2] << 24) |
|
||||||
|
((u64) mac[3] << 16) |
|
||||||
|
((u64) mac[4] << 8) |
|
||||||
|
(u64) mac[5];
|
||||||
|
|
||||||
|
WARN_ON(host_mac >= (1ULL << 48));
|
||||||
|
wwn = host_mac | ((u64) scheme << 60);
|
||||||
|
switch (scheme) {
|
||||||
|
case 1:
|
||||||
|
WARN_ON(port != 0);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
WARN_ON(port >= 0xfff);
|
||||||
|
wwn |= (u64) port << 48;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
WARN_ON(1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return wwn;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(fcoe_wwn_from_mac);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* fcoe_libfc_config() - sets up libfc related properties for lport
|
||||||
|
* @lp: ptr to the fc_lport
|
||||||
|
* @tt: libfc function template
|
||||||
|
*
|
||||||
|
* Returns : 0 for success
|
||||||
|
*/
|
||||||
|
int fcoe_libfc_config(struct fc_lport *lp, struct libfc_function_template *tt)
|
||||||
|
{
|
||||||
|
/* Set the function pointers set by the LLDD */
|
||||||
|
memcpy(&lp->tt, tt, sizeof(*tt));
|
||||||
|
if (fc_fcp_init(lp))
|
||||||
|
return -ENOMEM;
|
||||||
|
fc_exch_init(lp);
|
||||||
|
fc_elsct_init(lp);
|
||||||
|
fc_lport_init(lp);
|
||||||
|
fc_rport_init(lp);
|
||||||
|
fc_disc_init(lp);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(fcoe_libfc_config);
|
||||||
|
Reference in New Issue
Block a user