Commit a5b168ef authored by Bradley Grove's avatar Bradley Grove Committed by Martin K. Petersen
Browse files

scsi: lpfc: Add support for ATTO Fibre Channel devices

Update pci_device_id table and generate reporting strings for ATTO Celerity
and ThunderLink Fibre Channel devices.

Link: https://lore.kernel.org/r/20220524125621.47102-1-bgrove@attotech.com


Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
Reviewed-by: default avatarJames Smart <jsmart2021@gmail.com>
Co-developed-by: default avatarJason Seba <jseba@attotech.com>
Signed-off-by: default avatarJason Seba <jseba@attotech.com>
Signed-off-by: default avatarBradley Grove <bgrove@attotech.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent b3bc1a88
Loading
Loading
Loading
Loading
+22 −0
Original line number Diff line number Diff line
@@ -1736,6 +1736,28 @@ struct lpfc_fdmi_reg_portattr {
#define PCI_DEVICE_ID_TOMCAT        0x0714
#define PCI_DEVICE_ID_SKYHAWK       0x0724
#define PCI_DEVICE_ID_SKYHAWK_VF    0x072c
#define PCI_VENDOR_ID_ATTO          0x117c
#define PCI_DEVICE_ID_CLRY_16XE     0x0064
#define PCI_DEVICE_ID_CLRY_161E     0x0063
#define PCI_DEVICE_ID_CLRY_162E     0x0064
#define PCI_DEVICE_ID_CLRY_164E     0x0065
#define PCI_DEVICE_ID_CLRY_16XP     0x0094
#define PCI_DEVICE_ID_CLRY_161P     0x00a0
#define PCI_DEVICE_ID_CLRY_162P     0x0094
#define PCI_DEVICE_ID_CLRY_164P     0x00a1
#define PCI_DEVICE_ID_CLRY_32XE     0x0094
#define PCI_DEVICE_ID_CLRY_321E     0x00a2
#define PCI_DEVICE_ID_CLRY_322E     0x00a3
#define PCI_DEVICE_ID_CLRY_324E     0x00ac
#define PCI_DEVICE_ID_CLRY_32XP     0x00bb
#define PCI_DEVICE_ID_CLRY_321P     0x00bc
#define PCI_DEVICE_ID_CLRY_322P     0x00bd
#define PCI_DEVICE_ID_CLRY_324P     0x00be
#define PCI_DEVICE_ID_TLFC_2        0x0064
#define PCI_DEVICE_ID_TLFC_2XX2     0x4064
#define PCI_DEVICE_ID_TLFC_3        0x0094
#define PCI_DEVICE_ID_TLFC_3162     0x40a6
#define PCI_DEVICE_ID_TLFC_3322     0x40a7

#define JEDEC_ID_ADDRESS            0x0080001c
#define FIREFLY_JEDEC_ID            0x1ACC
+30 −0
Original line number Diff line number Diff line
@@ -124,5 +124,35 @@ const struct pci_device_id lpfc_id_table[] = {
		PCI_ANY_ID, PCI_ANY_ID, },
	{PCI_VENDOR_ID_EMULEX, PCI_DEVICE_ID_SKYHAWK_VF,
		PCI_ANY_ID, PCI_ANY_ID, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_16XE,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_161E, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_16XE,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_162E, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_16XE,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_164E, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_16XP,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_161P, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_16XP,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_162P, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_16XP,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_164P, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_32XE,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_321E, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_32XE,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_322E, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_32XE,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_324E, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_32XP,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_321P, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_32XP,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_322P, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_32XP,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_CLRY_324P, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_TLFC_2,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_TLFC_2XX2, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_TLFC_3,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_TLFC_3162, },
	{PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_TLFC_3,
		PCI_VENDOR_ID_ATTO, PCI_DEVICE_ID_TLFC_3322, },
	{ 0 }
};
+89 −0
Original line number Diff line number Diff line
@@ -2414,6 +2414,90 @@ lpfc_parse_vpd(struct lpfc_hba *phba, uint8_t *vpd, int len)
	return(1);
}

/**
 * lpfc_get_atto_model_desc - Retrieve ATTO HBA device model name and description
 * @phba: pointer to lpfc hba data structure.
 * @mdp: pointer to the data structure to hold the derived model name.
 * @descp: pointer to the data structure to hold the derived description.
 *
 * This routine retrieves HBA's description based on its registered PCI device
 * ID. The @descp passed into this function points to an array of 256 chars. It
 * shall be returned with the model name, maximum speed, and the host bus type.
 * The @mdp passed into this function points to an array of 80 chars. When the
 * function returns, the @mdp will be filled with the model name.
 **/
static void
lpfc_get_atto_model_desc(struct lpfc_hba *phba, uint8_t *mdp, uint8_t *descp)
{
	uint16_t sub_dev_id = phba->pcidev->subsystem_device;
	char *model = "<Unknown>";
	int tbolt = 0;

	switch (sub_dev_id) {
	case PCI_DEVICE_ID_CLRY_161E:
		model = "161E";
		break;
	case PCI_DEVICE_ID_CLRY_162E:
		model = "162E";
		break;
	case PCI_DEVICE_ID_CLRY_164E:
		model = "164E";
		break;
	case PCI_DEVICE_ID_CLRY_161P:
		model = "161P";
		break;
	case PCI_DEVICE_ID_CLRY_162P:
		model = "162P";
		break;
	case PCI_DEVICE_ID_CLRY_164P:
		model = "164P";
		break;
	case PCI_DEVICE_ID_CLRY_321E:
		model = "321E";
		break;
	case PCI_DEVICE_ID_CLRY_322E:
		model = "322E";
		break;
	case PCI_DEVICE_ID_CLRY_324E:
		model = "324E";
		break;
	case PCI_DEVICE_ID_CLRY_321P:
		model = "321P";
		break;
	case PCI_DEVICE_ID_CLRY_322P:
		model = "322P";
		break;
	case PCI_DEVICE_ID_CLRY_324P:
		model = "324P";
		break;
	case PCI_DEVICE_ID_TLFC_2XX2:
		model = "2XX2";
		tbolt = 1;
		break;
	case PCI_DEVICE_ID_TLFC_3162:
		model = "3162";
		tbolt = 1;
		break;
	case PCI_DEVICE_ID_TLFC_3322:
		model = "3322";
		tbolt = 1;
		break;
	default:
		model = "Unknown";
		break;
	}

	if (mdp && mdp[0] == '\0')
		snprintf(mdp, 79, "%s", model);

	if (descp && descp[0] == '\0')
		snprintf(descp, 255,
			 "ATTO %s%s, Fibre Channel Adapter Initiator, Port %s",
			 (tbolt) ? "ThunderLink FC " : "Celerity FC-",
			 model,
			 phba->Port);
}

/**
 * lpfc_get_hba_model_desc - Retrieve HBA device model name and description
 * @phba: pointer to lpfc hba data structure.
@@ -2444,6 +2528,11 @@ lpfc_get_hba_model_desc(struct lpfc_hba *phba, uint8_t *mdp, uint8_t *descp)
		&& descp && descp[0] != '\0')
		return;

	if (phba->pcidev->vendor == PCI_VENDOR_ID_ATTO) {
		lpfc_get_atto_model_desc(phba, mdp, descp);
		return;
	}

	if (phba->lmt & LMT_64Gb)
		max_speed = 64;
	else if (phba->lmt & LMT_32Gb)