diff options
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_common.h | 12 | ||||
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_eeprom.c | 27 | ||||
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_kernel.h | 7 | ||||
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_pe800.c | 2 |
4 files changed, 38 insertions, 10 deletions
diff --git a/drivers/infiniband/hw/ipath/ipath_common.h b/drivers/infiniband/hw/ipath/ipath_common.h index 106f8f49cbb1..3130a7ed254b 100644 --- a/drivers/infiniband/hw/ipath/ipath_common.h +++ b/drivers/infiniband/hw/ipath/ipath_common.h | |||
@@ -476,7 +476,7 @@ struct ipath_sma_pkt | |||
476 | * Data layout in I2C flash (for GUID, etc.) | 476 | * Data layout in I2C flash (for GUID, etc.) |
477 | * All fields are little-endian binary unless otherwise stated | 477 | * All fields are little-endian binary unless otherwise stated |
478 | */ | 478 | */ |
479 | #define IPATH_FLASH_VERSION 1 | 479 | #define IPATH_FLASH_VERSION 2 |
480 | struct ipath_flash { | 480 | struct ipath_flash { |
481 | /* flash layout version (IPATH_FLASH_VERSION) */ | 481 | /* flash layout version (IPATH_FLASH_VERSION) */ |
482 | __u8 if_fversion; | 482 | __u8 if_fversion; |
@@ -484,14 +484,14 @@ struct ipath_flash { | |||
484 | __u8 if_csum; | 484 | __u8 if_csum; |
485 | /* | 485 | /* |
486 | * valid length (in use, protected by if_csum), including | 486 | * valid length (in use, protected by if_csum), including |
487 | * if_fversion and if_sum themselves) | 487 | * if_fversion and if_csum themselves) |
488 | */ | 488 | */ |
489 | __u8 if_length; | 489 | __u8 if_length; |
490 | /* the GUID, in network order */ | 490 | /* the GUID, in network order */ |
491 | __u8 if_guid[8]; | 491 | __u8 if_guid[8]; |
492 | /* number of GUIDs to use, starting from if_guid */ | 492 | /* number of GUIDs to use, starting from if_guid */ |
493 | __u8 if_numguid; | 493 | __u8 if_numguid; |
494 | /* the board serial number, in ASCII */ | 494 | /* the (last 10 characters of) board serial number, in ASCII */ |
495 | char if_serial[12]; | 495 | char if_serial[12]; |
496 | /* board mfg date (YYYYMMDD ASCII) */ | 496 | /* board mfg date (YYYYMMDD ASCII) */ |
497 | char if_mfgdate[8]; | 497 | char if_mfgdate[8]; |
@@ -503,8 +503,10 @@ struct ipath_flash { | |||
503 | __u8 if_powerhour[2]; | 503 | __u8 if_powerhour[2]; |
504 | /* ASCII free-form comment field */ | 504 | /* ASCII free-form comment field */ |
505 | char if_comment[32]; | 505 | char if_comment[32]; |
506 | /* 78 bytes used, min flash size is 128 bytes */ | 506 | /* Backwards compatible prefix for longer QLogic Serial Numbers */ |
507 | __u8 if_future[50]; | 507 | char if_sprefix[4]; |
508 | /* 82 bytes used, min flash size is 128 bytes */ | ||
509 | __u8 if_future[46]; | ||
508 | }; | 510 | }; |
509 | 511 | ||
510 | /* | 512 | /* |
diff --git a/drivers/infiniband/hw/ipath/ipath_eeprom.c b/drivers/infiniband/hw/ipath/ipath_eeprom.c index f086e3360459..3313356ab93a 100644 --- a/drivers/infiniband/hw/ipath/ipath_eeprom.c +++ b/drivers/infiniband/hw/ipath/ipath_eeprom.c | |||
@@ -601,8 +601,31 @@ void ipath_get_eeprom_info(struct ipath_devdata *dd) | |||
601 | guid = *(__be64 *) ifp->if_guid; | 601 | guid = *(__be64 *) ifp->if_guid; |
602 | dd->ipath_guid = guid; | 602 | dd->ipath_guid = guid; |
603 | dd->ipath_nguid = ifp->if_numguid; | 603 | dd->ipath_nguid = ifp->if_numguid; |
604 | memcpy(dd->ipath_serial, ifp->if_serial, | 604 | /* |
605 | sizeof(ifp->if_serial)); | 605 | * Things are slightly complicated by the desire to transparently |
606 | * support both the Pathscale 10-digit serial number and the QLogic | ||
607 | * 13-character version. | ||
608 | */ | ||
609 | if ((ifp->if_fversion > 1) && ifp->if_sprefix[0] | ||
610 | && ((u8 *)ifp->if_sprefix)[0] != 0xFF) { | ||
611 | /* This board has a Serial-prefix, which is stored | ||
612 | * elsewhere for backward-compatibility. | ||
613 | */ | ||
614 | char *snp = dd->ipath_serial; | ||
615 | int len; | ||
616 | memcpy(snp, ifp->if_sprefix, sizeof ifp->if_sprefix); | ||
617 | snp[sizeof ifp->if_sprefix] = '\0'; | ||
618 | len = strlen(snp); | ||
619 | snp += len; | ||
620 | len = (sizeof dd->ipath_serial) - len; | ||
621 | if (len > sizeof ifp->if_serial) { | ||
622 | len = sizeof ifp->if_serial; | ||
623 | } | ||
624 | memcpy(snp, ifp->if_serial, len); | ||
625 | } else | ||
626 | memcpy(dd->ipath_serial, ifp->if_serial, | ||
627 | sizeof ifp->if_serial); | ||
628 | |||
606 | ipath_cdbg(VERBOSE, "Initted GUID to %llx from eeprom\n", | 629 | ipath_cdbg(VERBOSE, "Initted GUID to %llx from eeprom\n", |
607 | (unsigned long long) be64_to_cpu(dd->ipath_guid)); | 630 | (unsigned long long) be64_to_cpu(dd->ipath_guid)); |
608 | 631 | ||
diff --git a/drivers/infiniband/hw/ipath/ipath_kernel.h b/drivers/infiniband/hw/ipath/ipath_kernel.h index fe3c862e23b5..00a6bbdbe957 100644 --- a/drivers/infiniband/hw/ipath/ipath_kernel.h +++ b/drivers/infiniband/hw/ipath/ipath_kernel.h | |||
@@ -491,8 +491,11 @@ struct ipath_devdata { | |||
491 | u16 ipath_lid; | 491 | u16 ipath_lid; |
492 | /* list of pkeys programmed; 0 if not set */ | 492 | /* list of pkeys programmed; 0 if not set */ |
493 | u16 ipath_pkeys[4]; | 493 | u16 ipath_pkeys[4]; |
494 | /* ASCII serial number, from flash */ | 494 | /* |
495 | u8 ipath_serial[12]; | 495 | * ASCII serial number, from flash, large enough for original |
496 | * all digit strings, and longer QLogic serial number format | ||
497 | */ | ||
498 | u8 ipath_serial[16]; | ||
496 | /* human readable board version */ | 499 | /* human readable board version */ |
497 | u8 ipath_boardversion[80]; | 500 | u8 ipath_boardversion[80]; |
498 | /* chip major rev, from ipath_revision */ | 501 | /* chip major rev, from ipath_revision */ |
diff --git a/drivers/infiniband/hw/ipath/ipath_pe800.c b/drivers/infiniband/hw/ipath/ipath_pe800.c index 98fd5d37dfff..b83f66d8262c 100644 --- a/drivers/infiniband/hw/ipath/ipath_pe800.c +++ b/drivers/infiniband/hw/ipath/ipath_pe800.c | |||
@@ -533,7 +533,7 @@ static int ipath_pe_boardname(struct ipath_devdata *dd, char *name, | |||
533 | if (n) | 533 | if (n) |
534 | snprintf(name, namelen, "%s", n); | 534 | snprintf(name, namelen, "%s", n); |
535 | 535 | ||
536 | if (dd->ipath_majrev != 4 || dd->ipath_minrev != 1) { | 536 | if (dd->ipath_majrev != 4 || !dd->ipath_minrev || dd->ipath_minrev>2) { |
537 | ipath_dev_err(dd, "Unsupported PE-800 revision %u.%u!\n", | 537 | ipath_dev_err(dd, "Unsupported PE-800 revision %u.%u!\n", |
538 | dd->ipath_majrev, dd->ipath_minrev); | 538 | dd->ipath_majrev, dd->ipath_minrev); |
539 | ret = 1; | 539 | ret = 1; |