diff options
-rw-r--r-- | drivers/scsi/ipr.c | 37 | ||||
-rw-r--r-- | drivers/scsi/ipr.h | 52 |
2 files changed, 36 insertions, 53 deletions
diff --git a/drivers/scsi/ipr.c b/drivers/scsi/ipr.c index da61ce1998c3..d5da5e5c4c6d 100644 --- a/drivers/scsi/ipr.c +++ b/drivers/scsi/ipr.c | |||
@@ -889,24 +889,23 @@ static void ipr_process_ccn(struct ipr_cmnd *ipr_cmd) | |||
889 | 889 | ||
890 | /** | 890 | /** |
891 | * ipr_log_vpd - Log the passed VPD to the error log. | 891 | * ipr_log_vpd - Log the passed VPD to the error log. |
892 | * @vpids: vendor/product id struct | 892 | * @vpd: vendor/product id/sn struct |
893 | * @serial_num: serial number string | ||
894 | * | 893 | * |
895 | * Return value: | 894 | * Return value: |
896 | * none | 895 | * none |
897 | **/ | 896 | **/ |
898 | static void ipr_log_vpd(struct ipr_std_inq_vpids *vpids, u8 *serial_num) | 897 | static void ipr_log_vpd(struct ipr_vpd *vpd) |
899 | { | 898 | { |
900 | char buffer[IPR_VENDOR_ID_LEN + IPR_PROD_ID_LEN | 899 | char buffer[IPR_VENDOR_ID_LEN + IPR_PROD_ID_LEN |
901 | + IPR_SERIAL_NUM_LEN]; | 900 | + IPR_SERIAL_NUM_LEN]; |
902 | 901 | ||
903 | memcpy(buffer, vpids->vendor_id, IPR_VENDOR_ID_LEN); | 902 | memcpy(buffer, vpd->vpids.vendor_id, IPR_VENDOR_ID_LEN); |
904 | memcpy(buffer + IPR_VENDOR_ID_LEN, vpids->product_id, | 903 | memcpy(buffer + IPR_VENDOR_ID_LEN, vpd->vpids.product_id, |
905 | IPR_PROD_ID_LEN); | 904 | IPR_PROD_ID_LEN); |
906 | buffer[IPR_VENDOR_ID_LEN + IPR_PROD_ID_LEN] = '\0'; | 905 | buffer[IPR_VENDOR_ID_LEN + IPR_PROD_ID_LEN] = '\0'; |
907 | ipr_err("Vendor/Product ID: %s\n", buffer); | 906 | ipr_err("Vendor/Product ID: %s\n", buffer); |
908 | 907 | ||
909 | memcpy(buffer, serial_num, IPR_SERIAL_NUM_LEN); | 908 | memcpy(buffer, vpd->sn, IPR_SERIAL_NUM_LEN); |
910 | buffer[IPR_SERIAL_NUM_LEN] = '\0'; | 909 | buffer[IPR_SERIAL_NUM_LEN] = '\0'; |
911 | ipr_err(" Serial Number: %s\n", buffer); | 910 | ipr_err(" Serial Number: %s\n", buffer); |
912 | } | 911 | } |
@@ -927,17 +926,15 @@ static void ipr_log_cache_error(struct ipr_ioa_cfg *ioa_cfg, | |||
927 | 926 | ||
928 | ipr_err("-----Current Configuration-----\n"); | 927 | ipr_err("-----Current Configuration-----\n"); |
929 | ipr_err("Cache Directory Card Information:\n"); | 928 | ipr_err("Cache Directory Card Information:\n"); |
930 | ipr_log_vpd(&error->ioa_vpids, error->ioa_sn); | 929 | ipr_log_vpd(&error->ioa_vpd); |
931 | ipr_err("Adapter Card Information:\n"); | 930 | ipr_err("Adapter Card Information:\n"); |
932 | ipr_log_vpd(&error->cfc_vpids, error->cfc_sn); | 931 | ipr_log_vpd(&error->cfc_vpd); |
933 | 932 | ||
934 | ipr_err("-----Expected Configuration-----\n"); | 933 | ipr_err("-----Expected Configuration-----\n"); |
935 | ipr_err("Cache Directory Card Information:\n"); | 934 | ipr_err("Cache Directory Card Information:\n"); |
936 | ipr_log_vpd(&error->ioa_last_attached_to_cfc_vpids, | 935 | ipr_log_vpd(&error->ioa_last_attached_to_cfc_vpd); |
937 | error->ioa_last_attached_to_cfc_sn); | ||
938 | ipr_err("Adapter Card Information:\n"); | 936 | ipr_err("Adapter Card Information:\n"); |
939 | ipr_log_vpd(&error->cfc_last_attached_to_ioa_vpids, | 937 | ipr_log_vpd(&error->cfc_last_attached_to_ioa_vpd); |
940 | error->cfc_last_attached_to_ioa_sn); | ||
941 | 938 | ||
942 | ipr_err("Additional IOA Data: %08X %08X %08X\n", | 939 | ipr_err("Additional IOA Data: %08X %08X %08X\n", |
943 | be32_to_cpu(error->ioa_data[0]), | 940 | be32_to_cpu(error->ioa_data[0]), |
@@ -966,7 +963,7 @@ static void ipr_log_config_error(struct ipr_ioa_cfg *ioa_cfg, | |||
966 | ipr_err("Device Errors Detected/Logged: %d/%d\n", | 963 | ipr_err("Device Errors Detected/Logged: %d/%d\n", |
967 | be32_to_cpu(error->errors_detected), errors_logged); | 964 | be32_to_cpu(error->errors_detected), errors_logged); |
968 | 965 | ||
969 | dev_entry = error->dev_entry; | 966 | dev_entry = error->dev; |
970 | 967 | ||
971 | for (i = 0; i < errors_logged; i++, dev_entry++) { | 968 | for (i = 0; i < errors_logged; i++, dev_entry++) { |
972 | ipr_err_separator; | 969 | ipr_err_separator; |
@@ -978,18 +975,16 @@ static void ipr_log_config_error(struct ipr_ioa_cfg *ioa_cfg, | |||
978 | ioa_cfg->host->host_no, dev_entry->dev_res_addr.bus, | 975 | ioa_cfg->host->host_no, dev_entry->dev_res_addr.bus, |
979 | dev_entry->dev_res_addr.target, dev_entry->dev_res_addr.lun); | 976 | dev_entry->dev_res_addr.target, dev_entry->dev_res_addr.lun); |
980 | } | 977 | } |
981 | ipr_log_vpd(&dev_entry->dev_vpids, dev_entry->dev_sn); | 978 | ipr_log_vpd(&dev_entry->vpd); |
982 | 979 | ||
983 | ipr_err("-----New Device Information-----\n"); | 980 | ipr_err("-----New Device Information-----\n"); |
984 | ipr_log_vpd(&dev_entry->new_dev_vpids, dev_entry->new_dev_sn); | 981 | ipr_log_vpd(&dev_entry->new_vpd); |
985 | 982 | ||
986 | ipr_err("Cache Directory Card Information:\n"); | 983 | ipr_err("Cache Directory Card Information:\n"); |
987 | ipr_log_vpd(&dev_entry->ioa_last_with_dev_vpids, | 984 | ipr_log_vpd(&dev_entry->ioa_last_with_dev_vpd); |
988 | dev_entry->ioa_last_with_dev_sn); | ||
989 | 985 | ||
990 | ipr_err("Adapter Card Information:\n"); | 986 | ipr_err("Adapter Card Information:\n"); |
991 | ipr_log_vpd(&dev_entry->cfc_last_with_dev_vpids, | 987 | ipr_log_vpd(&dev_entry->cfc_last_with_dev_vpd); |
992 | dev_entry->cfc_last_with_dev_sn); | ||
993 | 988 | ||
994 | ipr_err("Additional IOA Data: %08X %08X %08X %08X %08X\n", | 989 | ipr_err("Additional IOA Data: %08X %08X %08X %08X %08X\n", |
995 | be32_to_cpu(dev_entry->ioa_data[0]), | 990 | be32_to_cpu(dev_entry->ioa_data[0]), |
@@ -1032,7 +1027,7 @@ static void ipr_log_array_error(struct ipr_ioa_cfg *ioa_cfg, | |||
1032 | array_entry = error->array_member; | 1027 | array_entry = error->array_member; |
1033 | 1028 | ||
1034 | for (i = 0; i < 18; i++) { | 1029 | for (i = 0; i < 18; i++) { |
1035 | if (!memcmp(array_entry->serial_num, zero_sn, IPR_SERIAL_NUM_LEN)) | 1030 | if (!memcmp(array_entry->vpd.sn, zero_sn, IPR_SERIAL_NUM_LEN)) |
1036 | continue; | 1031 | continue; |
1037 | 1032 | ||
1038 | if (be32_to_cpu(error->exposed_mode_adn) == i) { | 1033 | if (be32_to_cpu(error->exposed_mode_adn) == i) { |
@@ -1041,7 +1036,7 @@ static void ipr_log_array_error(struct ipr_ioa_cfg *ioa_cfg, | |||
1041 | ipr_err("Array Member %d:\n", i); | 1036 | ipr_err("Array Member %d:\n", i); |
1042 | } | 1037 | } |
1043 | 1038 | ||
1044 | ipr_log_vpd(&array_entry->vpids, array_entry->serial_num); | 1039 | ipr_log_vpd(&array_entry->vpd); |
1045 | 1040 | ||
1046 | if (array_entry->dev_res_addr.bus >= IPR_MAX_NUM_BUSES) { | 1041 | if (array_entry->dev_res_addr.bus >= IPR_MAX_NUM_BUSES) { |
1047 | ipr_err("Current Location: unknown\n"); | 1042 | ipr_err("Current Location: unknown\n"); |
diff --git a/drivers/scsi/ipr.h b/drivers/scsi/ipr.h index 8cf967108500..01950b9d2e6d 100644 --- a/drivers/scsi/ipr.h +++ b/drivers/scsi/ipr.h | |||
@@ -261,6 +261,11 @@ struct ipr_std_inq_vpids { | |||
261 | u8 product_id[IPR_PROD_ID_LEN]; | 261 | u8 product_id[IPR_PROD_ID_LEN]; |
262 | }__attribute__((packed)); | 262 | }__attribute__((packed)); |
263 | 263 | ||
264 | struct ipr_vpd { | ||
265 | struct ipr_std_inq_vpids vpids; | ||
266 | u8 sn[IPR_SERIAL_NUM_LEN]; | ||
267 | }__attribute__((packed)); | ||
268 | |||
264 | struct ipr_std_inq_data { | 269 | struct ipr_std_inq_data { |
265 | u8 peri_qual_dev_type; | 270 | u8 peri_qual_dev_type; |
266 | #define IPR_STD_INQ_PERI_QUAL(peri) ((peri) >> 5) | 271 | #define IPR_STD_INQ_PERI_QUAL(peri) ((peri) >> 5) |
@@ -537,21 +542,16 @@ struct ipr_inquiry_page3 { | |||
537 | }__attribute__((packed)); | 542 | }__attribute__((packed)); |
538 | 543 | ||
539 | struct ipr_hostrcb_device_data_entry { | 544 | struct ipr_hostrcb_device_data_entry { |
540 | struct ipr_std_inq_vpids dev_vpids; | 545 | struct ipr_vpd vpd; |
541 | u8 dev_sn[IPR_SERIAL_NUM_LEN]; | ||
542 | struct ipr_res_addr dev_res_addr; | 546 | struct ipr_res_addr dev_res_addr; |
543 | struct ipr_std_inq_vpids new_dev_vpids; | 547 | struct ipr_vpd new_vpd; |
544 | u8 new_dev_sn[IPR_SERIAL_NUM_LEN]; | 548 | struct ipr_vpd ioa_last_with_dev_vpd; |
545 | struct ipr_std_inq_vpids ioa_last_with_dev_vpids; | 549 | struct ipr_vpd cfc_last_with_dev_vpd; |
546 | u8 ioa_last_with_dev_sn[IPR_SERIAL_NUM_LEN]; | ||
547 | struct ipr_std_inq_vpids cfc_last_with_dev_vpids; | ||
548 | u8 cfc_last_with_dev_sn[IPR_SERIAL_NUM_LEN]; | ||
549 | __be32 ioa_data[5]; | 550 | __be32 ioa_data[5]; |
550 | }__attribute__((packed, aligned (4))); | 551 | }__attribute__((packed, aligned (4))); |
551 | 552 | ||
552 | struct ipr_hostrcb_array_data_entry { | 553 | struct ipr_hostrcb_array_data_entry { |
553 | struct ipr_std_inq_vpids vpids; | 554 | struct ipr_vpd vpd; |
554 | u8 serial_num[IPR_SERIAL_NUM_LEN]; | ||
555 | struct ipr_res_addr expected_dev_res_addr; | 555 | struct ipr_res_addr expected_dev_res_addr; |
556 | struct ipr_res_addr dev_res_addr; | 556 | struct ipr_res_addr dev_res_addr; |
557 | }__attribute__((packed, aligned (4))); | 557 | }__attribute__((packed, aligned (4))); |
@@ -568,47 +568,35 @@ struct ipr_hostrcb_type_01_error { | |||
568 | }__attribute__((packed, aligned (4))); | 568 | }__attribute__((packed, aligned (4))); |
569 | 569 | ||
570 | struct ipr_hostrcb_type_02_error { | 570 | struct ipr_hostrcb_type_02_error { |
571 | struct ipr_std_inq_vpids ioa_vpids; | 571 | struct ipr_vpd ioa_vpd; |
572 | u8 ioa_sn[IPR_SERIAL_NUM_LEN]; | 572 | struct ipr_vpd cfc_vpd; |
573 | struct ipr_std_inq_vpids cfc_vpids; | 573 | struct ipr_vpd ioa_last_attached_to_cfc_vpd; |
574 | u8 cfc_sn[IPR_SERIAL_NUM_LEN]; | 574 | struct ipr_vpd cfc_last_attached_to_ioa_vpd; |
575 | struct ipr_std_inq_vpids ioa_last_attached_to_cfc_vpids; | ||
576 | u8 ioa_last_attached_to_cfc_sn[IPR_SERIAL_NUM_LEN]; | ||
577 | struct ipr_std_inq_vpids cfc_last_attached_to_ioa_vpids; | ||
578 | u8 cfc_last_attached_to_ioa_sn[IPR_SERIAL_NUM_LEN]; | ||
579 | __be32 ioa_data[3]; | 575 | __be32 ioa_data[3]; |
580 | u8 reserved[844]; | ||
581 | }__attribute__((packed, aligned (4))); | 576 | }__attribute__((packed, aligned (4))); |
582 | 577 | ||
583 | struct ipr_hostrcb_type_03_error { | 578 | struct ipr_hostrcb_type_03_error { |
584 | struct ipr_std_inq_vpids ioa_vpids; | 579 | struct ipr_vpd ioa_vpd; |
585 | u8 ioa_sn[IPR_SERIAL_NUM_LEN]; | 580 | struct ipr_vpd cfc_vpd; |
586 | struct ipr_std_inq_vpids cfc_vpids; | ||
587 | u8 cfc_sn[IPR_SERIAL_NUM_LEN]; | ||
588 | __be32 errors_detected; | 581 | __be32 errors_detected; |
589 | __be32 errors_logged; | 582 | __be32 errors_logged; |
590 | u8 ioa_data[12]; | 583 | u8 ioa_data[12]; |
591 | struct ipr_hostrcb_device_data_entry dev_entry[3]; | 584 | struct ipr_hostrcb_device_data_entry dev[3]; |
592 | u8 reserved[444]; | ||
593 | }__attribute__((packed, aligned (4))); | 585 | }__attribute__((packed, aligned (4))); |
594 | 586 | ||
595 | struct ipr_hostrcb_type_04_error { | 587 | struct ipr_hostrcb_type_04_error { |
596 | struct ipr_std_inq_vpids ioa_vpids; | 588 | struct ipr_vpd ioa_vpd; |
597 | u8 ioa_sn[IPR_SERIAL_NUM_LEN]; | 589 | struct ipr_vpd cfc_vpd; |
598 | struct ipr_std_inq_vpids cfc_vpids; | ||
599 | u8 cfc_sn[IPR_SERIAL_NUM_LEN]; | ||
600 | u8 ioa_data[12]; | 590 | u8 ioa_data[12]; |
601 | struct ipr_hostrcb_array_data_entry array_member[10]; | 591 | struct ipr_hostrcb_array_data_entry array_member[10]; |
602 | __be32 exposed_mode_adn; | 592 | __be32 exposed_mode_adn; |
603 | __be32 array_id; | 593 | __be32 array_id; |
604 | struct ipr_std_inq_vpids incomp_dev_vpids; | 594 | struct ipr_vpd incomp_dev_vpd; |
605 | u8 incomp_dev_sn[IPR_SERIAL_NUM_LEN]; | ||
606 | __be32 ioa_data2; | 595 | __be32 ioa_data2; |
607 | struct ipr_hostrcb_array_data_entry array_member2[8]; | 596 | struct ipr_hostrcb_array_data_entry array_member2[8]; |
608 | struct ipr_res_addr last_func_vset_res_addr; | 597 | struct ipr_res_addr last_func_vset_res_addr; |
609 | u8 vset_serial_num[IPR_SERIAL_NUM_LEN]; | 598 | u8 vset_serial_num[IPR_SERIAL_NUM_LEN]; |
610 | u8 protection_level[8]; | 599 | u8 protection_level[8]; |
611 | u8 reserved[124]; | ||
612 | }__attribute__((packed, aligned (4))); | 600 | }__attribute__((packed, aligned (4))); |
613 | 601 | ||
614 | struct ipr_hostrcb_error { | 602 | struct ipr_hostrcb_error { |