提交 7262026f 编写于 作者: W Wayne Boyer 提交者: James Bottomley

[SCSI] ipr: fix array error logging

The structure definitions for reporting array errors did not have the correct
size for the Array WWID field.  This patch fixes those definitions.  It also
fixes part of the output formatting that did not have newlines and fixes size
calculations.
Signed-off-by: NWayne Boyer <wayneb@linux.vnet.ibm.com>
Acked-by: NBrian King <brking@linux.vnet.ibm.com>
Signed-off-by: NJames Bottomley <James.Bottomley@suse.de>
上级 4ebcfb92
...@@ -1671,7 +1671,7 @@ static void ipr_log_enhanced_array_error(struct ipr_ioa_cfg *ioa_cfg, ...@@ -1671,7 +1671,7 @@ static void ipr_log_enhanced_array_error(struct ipr_ioa_cfg *ioa_cfg,
array_entry = error->array_member; array_entry = error->array_member;
num_entries = min_t(u32, be32_to_cpu(error->num_entries), num_entries = min_t(u32, be32_to_cpu(error->num_entries),
sizeof(error->array_member)); ARRAY_SIZE(error->array_member));
for (i = 0; i < num_entries; i++, array_entry++) { for (i = 0; i < num_entries; i++, array_entry++) {
if (!memcmp(array_entry->vpd.vpd.sn, zero_sn, IPR_SERIAL_NUM_LEN)) if (!memcmp(array_entry->vpd.vpd.sn, zero_sn, IPR_SERIAL_NUM_LEN))
...@@ -2152,8 +2152,8 @@ static void ipr_log_sis64_array_error(struct ipr_ioa_cfg *ioa_cfg, ...@@ -2152,8 +2152,8 @@ static void ipr_log_sis64_array_error(struct ipr_ioa_cfg *ioa_cfg,
ipr_err_separator; ipr_err_separator;
array_entry = error->array_member; array_entry = error->array_member;
num_entries = min_t(u32, be32_to_cpu(error->num_entries), num_entries = min_t(u32, error->num_entries,
sizeof(error->array_member)); ARRAY_SIZE(error->array_member));
for (i = 0; i < num_entries; i++, array_entry++) { for (i = 0; i < num_entries; i++, array_entry++) {
...@@ -2167,10 +2167,10 @@ static void ipr_log_sis64_array_error(struct ipr_ioa_cfg *ioa_cfg, ...@@ -2167,10 +2167,10 @@ static void ipr_log_sis64_array_error(struct ipr_ioa_cfg *ioa_cfg,
ipr_err("Array Member %d:\n", i); ipr_err("Array Member %d:\n", i);
ipr_log_ext_vpd(&array_entry->vpd); ipr_log_ext_vpd(&array_entry->vpd);
ipr_err("Current Location: %s", ipr_err("Current Location: %s\n",
ipr_format_res_path(array_entry->res_path, buffer, ipr_format_res_path(array_entry->res_path, buffer,
sizeof(buffer))); sizeof(buffer)));
ipr_err("Expected Location: %s", ipr_err("Expected Location: %s\n",
ipr_format_res_path(array_entry->expected_res_path, ipr_format_res_path(array_entry->expected_res_path,
buffer, sizeof(buffer))); buffer, sizeof(buffer)));
......
...@@ -319,6 +319,11 @@ struct ipr_ext_vpd { ...@@ -319,6 +319,11 @@ struct ipr_ext_vpd {
__be32 wwid[2]; __be32 wwid[2];
}__attribute__((packed)); }__attribute__((packed));
struct ipr_ext_vpd64 {
struct ipr_vpd vpd;
__be32 wwid[4];
}__attribute__((packed));
struct ipr_std_inq_data { struct ipr_std_inq_data {
u8 peri_qual_dev_type; u8 peri_qual_dev_type;
#define IPR_STD_INQ_PERI_QUAL(peri) ((peri) >> 5) #define IPR_STD_INQ_PERI_QUAL(peri) ((peri) >> 5)
...@@ -395,7 +400,7 @@ struct ipr_config_table_entry64 { ...@@ -395,7 +400,7 @@ struct ipr_config_table_entry64 {
__be64 res_path; __be64 res_path;
struct ipr_std_inq_data std_inq_data; struct ipr_std_inq_data std_inq_data;
u8 reserved2[4]; u8 reserved2[4];
__be64 reserved3[2]; // description text __be64 reserved3[2];
u8 reserved4[8]; u8 reserved4[8];
}__attribute__ ((packed, aligned (8))); }__attribute__ ((packed, aligned (8)));
...@@ -914,7 +919,7 @@ struct ipr_hostrcb_type_24_error { ...@@ -914,7 +919,7 @@ struct ipr_hostrcb_type_24_error {
u8 array_id; u8 array_id;
u8 last_res_path[8]; u8 last_res_path[8];
u8 protection_level[8]; u8 protection_level[8];
struct ipr_ext_vpd array_vpd; struct ipr_ext_vpd64 array_vpd;
u8 description[16]; u8 description[16];
u8 reserved2[3]; u8 reserved2[3];
u8 num_entries; u8 num_entries;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册