aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrian King <brking@linux.vnet.ibm.com>2009-05-28 17:17:26 -0400
committerJames Bottomley <James.Bottomley@HansenPartnership.com>2009-06-08 14:07:34 -0400
commit7d0e462247241b8ec2d377306203b58c7f423553 (patch)
tree8460e4c8b58f05b99a1b802c3be85345d3708e01
parent85e2399e925e0afa04dd6e185a910bdd3dc4626b (diff)
[SCSI] ibmvfc: Reduce error logging noise
The ibmvfc driver currently logs errors during discovery for several transient fabric errors, which generally get retried. If retries do not work, we see multiple errors in the log. If retries do work, we see errors in the log which may be confusing since the retry worked. This patch enhances the discovery time error logging to only log errors for command failures during discovery if all allowed retries have been used up. The existing behavior of logging all failures can be restored by setting the hosts log_level to a value of 3 or greater. Signed-off-by: Brian King <brking@linux.vnet.ibm.com> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
-rw-r--r--drivers/scsi/ibmvscsi/ibmvfc.c68
-rw-r--r--drivers/scsi/ibmvscsi/ibmvfc.h6
2 files changed, 48 insertions, 26 deletions
diff --git a/drivers/scsi/ibmvscsi/ibmvfc.c b/drivers/scsi/ibmvscsi/ibmvfc.c
index 26abed2c3a41..182c8e75aaf0 100644
--- a/drivers/scsi/ibmvscsi/ibmvfc.c
+++ b/drivers/scsi/ibmvscsi/ibmvfc.c
@@ -842,9 +842,13 @@ static void ibmvfc_reset_host(struct ibmvfc_host *vhost)
842 * ibmvfc_retry_host_init - Retry host initialization if allowed 842 * ibmvfc_retry_host_init - Retry host initialization if allowed
843 * @vhost: ibmvfc host struct 843 * @vhost: ibmvfc host struct
844 * 844 *
845 * Returns: 1 if init will be retried / 0 if not
846 *
845 **/ 847 **/
846static void ibmvfc_retry_host_init(struct ibmvfc_host *vhost) 848static int ibmvfc_retry_host_init(struct ibmvfc_host *vhost)
847{ 849{
850 int retry = 0;
851
848 if (vhost->action == IBMVFC_HOST_ACTION_INIT_WAIT) { 852 if (vhost->action == IBMVFC_HOST_ACTION_INIT_WAIT) {
849 vhost->delay_init = 1; 853 vhost->delay_init = 1;
850 if (++vhost->init_retries > IBMVFC_MAX_HOST_INIT_RETRIES) { 854 if (++vhost->init_retries > IBMVFC_MAX_HOST_INIT_RETRIES) {
@@ -853,11 +857,14 @@ static void ibmvfc_retry_host_init(struct ibmvfc_host *vhost)
853 ibmvfc_link_down(vhost, IBMVFC_HOST_OFFLINE); 857 ibmvfc_link_down(vhost, IBMVFC_HOST_OFFLINE);
854 } else if (vhost->init_retries == IBMVFC_MAX_HOST_INIT_RETRIES) 858 } else if (vhost->init_retries == IBMVFC_MAX_HOST_INIT_RETRIES)
855 __ibmvfc_reset_host(vhost); 859 __ibmvfc_reset_host(vhost);
856 else 860 else {
857 ibmvfc_set_host_action(vhost, IBMVFC_HOST_ACTION_INIT); 861 ibmvfc_set_host_action(vhost, IBMVFC_HOST_ACTION_INIT);
862 retry = 1;
863 }
858 } 864 }
859 865
860 wake_up(&vhost->work_wait_q); 866 wake_up(&vhost->work_wait_q);
867 return retry;
861} 868}
862 869
863/** 870/**
@@ -2733,15 +2740,19 @@ static void ibmvfc_init_tgt(struct ibmvfc_target *tgt,
2733 * @tgt: ibmvfc target struct 2740 * @tgt: ibmvfc target struct
2734 * @job_step: initialization job step 2741 * @job_step: initialization job step
2735 * 2742 *
2743 * Returns: 1 if step will be retried / 0 if not
2744 *
2736 **/ 2745 **/
2737static void ibmvfc_retry_tgt_init(struct ibmvfc_target *tgt, 2746static int ibmvfc_retry_tgt_init(struct ibmvfc_target *tgt,
2738 void (*job_step) (struct ibmvfc_target *)) 2747 void (*job_step) (struct ibmvfc_target *))
2739{ 2748{
2740 if (++tgt->init_retries > IBMVFC_MAX_TGT_INIT_RETRIES) { 2749 if (++tgt->init_retries > IBMVFC_MAX_TGT_INIT_RETRIES) {
2741 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT); 2750 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT);
2742 wake_up(&tgt->vhost->work_wait_q); 2751 wake_up(&tgt->vhost->work_wait_q);
2752 return 0;
2743 } else 2753 } else
2744 ibmvfc_init_tgt(tgt, job_step); 2754 ibmvfc_init_tgt(tgt, job_step);
2755 return 1;
2745} 2756}
2746 2757
2747/* Defined in FC-LS */ 2758/* Defined in FC-LS */
@@ -2790,7 +2801,7 @@ static void ibmvfc_tgt_prli_done(struct ibmvfc_event *evt)
2790 struct ibmvfc_process_login *rsp = &evt->xfer_iu->prli; 2801 struct ibmvfc_process_login *rsp = &evt->xfer_iu->prli;
2791 struct ibmvfc_prli_svc_parms *parms = &rsp->parms; 2802 struct ibmvfc_prli_svc_parms *parms = &rsp->parms;
2792 u32 status = rsp->common.status; 2803 u32 status = rsp->common.status;
2793 int index; 2804 int index, level = IBMVFC_DEFAULT_LOG_LEVEL;
2794 2805
2795 vhost->discovery_threads--; 2806 vhost->discovery_threads--;
2796 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_NONE); 2807 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_NONE);
@@ -2826,13 +2837,14 @@ static void ibmvfc_tgt_prli_done(struct ibmvfc_event *evt)
2826 break; 2837 break;
2827 case IBMVFC_MAD_FAILED: 2838 case IBMVFC_MAD_FAILED:
2828 default: 2839 default:
2829 tgt_err(tgt, "Process Login failed: %s (%x:%x) rc=0x%02X\n",
2830 ibmvfc_get_cmd_error(rsp->status, rsp->error),
2831 rsp->status, rsp->error, status);
2832 if (ibmvfc_retry_cmd(rsp->status, rsp->error)) 2840 if (ibmvfc_retry_cmd(rsp->status, rsp->error))
2833 ibmvfc_retry_tgt_init(tgt, ibmvfc_tgt_send_prli); 2841 level += ibmvfc_retry_tgt_init(tgt, ibmvfc_tgt_send_prli);
2834 else 2842 else
2835 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT); 2843 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT);
2844
2845 tgt_log(tgt, level, "Process Login failed: %s (%x:%x) rc=0x%02X\n",
2846 ibmvfc_get_cmd_error(rsp->status, rsp->error),
2847 rsp->status, rsp->error, status);
2836 break; 2848 break;
2837 }; 2849 };
2838 2850
@@ -2891,6 +2903,7 @@ static void ibmvfc_tgt_plogi_done(struct ibmvfc_event *evt)
2891 struct ibmvfc_host *vhost = evt->vhost; 2903 struct ibmvfc_host *vhost = evt->vhost;
2892 struct ibmvfc_port_login *rsp = &evt->xfer_iu->plogi; 2904 struct ibmvfc_port_login *rsp = &evt->xfer_iu->plogi;
2893 u32 status = rsp->common.status; 2905 u32 status = rsp->common.status;
2906 int level = IBMVFC_DEFAULT_LOG_LEVEL;
2894 2907
2895 vhost->discovery_threads--; 2908 vhost->discovery_threads--;
2896 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_NONE); 2909 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_NONE);
@@ -2919,15 +2932,15 @@ static void ibmvfc_tgt_plogi_done(struct ibmvfc_event *evt)
2919 break; 2932 break;
2920 case IBMVFC_MAD_FAILED: 2933 case IBMVFC_MAD_FAILED:
2921 default: 2934 default:
2922 tgt_err(tgt, "Port Login failed: %s (%x:%x) %s (%x) %s (%x) rc=0x%02X\n",
2923 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error,
2924 ibmvfc_get_fc_type(rsp->fc_type), rsp->fc_type,
2925 ibmvfc_get_ls_explain(rsp->fc_explain), rsp->fc_explain, status);
2926
2927 if (ibmvfc_retry_cmd(rsp->status, rsp->error)) 2935 if (ibmvfc_retry_cmd(rsp->status, rsp->error))
2928 ibmvfc_retry_tgt_init(tgt, ibmvfc_tgt_send_plogi); 2936 level += ibmvfc_retry_tgt_init(tgt, ibmvfc_tgt_send_plogi);
2929 else 2937 else
2930 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT); 2938 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT);
2939
2940 tgt_log(tgt, level, "Port Login failed: %s (%x:%x) %s (%x) %s (%x) rc=0x%02X\n",
2941 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error,
2942 ibmvfc_get_fc_type(rsp->fc_type), rsp->fc_type,
2943 ibmvfc_get_ls_explain(rsp->fc_explain), rsp->fc_explain, status);
2931 break; 2944 break;
2932 }; 2945 };
2933 2946
@@ -3281,6 +3294,7 @@ static void ibmvfc_tgt_query_target_done(struct ibmvfc_event *evt)
3281 struct ibmvfc_host *vhost = evt->vhost; 3294 struct ibmvfc_host *vhost = evt->vhost;
3282 struct ibmvfc_query_tgt *rsp = &evt->xfer_iu->query_tgt; 3295 struct ibmvfc_query_tgt *rsp = &evt->xfer_iu->query_tgt;
3283 u32 status = rsp->common.status; 3296 u32 status = rsp->common.status;
3297 int level = IBMVFC_DEFAULT_LOG_LEVEL;
3284 3298
3285 vhost->discovery_threads--; 3299 vhost->discovery_threads--;
3286 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_NONE); 3300 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_NONE);
@@ -3300,19 +3314,19 @@ static void ibmvfc_tgt_query_target_done(struct ibmvfc_event *evt)
3300 break; 3314 break;
3301 case IBMVFC_MAD_FAILED: 3315 case IBMVFC_MAD_FAILED:
3302 default: 3316 default:
3303 tgt_err(tgt, "Query Target failed: %s (%x:%x) %s (%x) %s (%x) rc=0x%02X\n",
3304 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error,
3305 ibmvfc_get_fc_type(rsp->fc_type), rsp->fc_type,
3306 ibmvfc_get_gs_explain(rsp->fc_explain), rsp->fc_explain, status);
3307
3308 if ((rsp->status & IBMVFC_FABRIC_MAPPED) == IBMVFC_FABRIC_MAPPED && 3317 if ((rsp->status & IBMVFC_FABRIC_MAPPED) == IBMVFC_FABRIC_MAPPED &&
3309 rsp->error == IBMVFC_UNABLE_TO_PERFORM_REQ && 3318 rsp->error == IBMVFC_UNABLE_TO_PERFORM_REQ &&
3310 rsp->fc_explain == IBMVFC_PORT_NAME_NOT_REG) 3319 rsp->fc_explain == IBMVFC_PORT_NAME_NOT_REG)
3311 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT); 3320 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT);
3312 else if (ibmvfc_retry_cmd(rsp->status, rsp->error)) 3321 else if (ibmvfc_retry_cmd(rsp->status, rsp->error))
3313 ibmvfc_retry_tgt_init(tgt, ibmvfc_tgt_query_target); 3322 level += ibmvfc_retry_tgt_init(tgt, ibmvfc_tgt_query_target);
3314 else 3323 else
3315 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT); 3324 ibmvfc_set_tgt_action(tgt, IBMVFC_TGT_ACTION_DEL_RPORT);
3325
3326 tgt_log(tgt, level, "Query Target failed: %s (%x:%x) %s (%x) %s (%x) rc=0x%02X\n",
3327 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error,
3328 ibmvfc_get_fc_type(rsp->fc_type), rsp->fc_type,
3329 ibmvfc_get_gs_explain(rsp->fc_explain), rsp->fc_explain, status);
3316 break; 3330 break;
3317 }; 3331 };
3318 3332
@@ -3431,6 +3445,7 @@ static void ibmvfc_discover_targets_done(struct ibmvfc_event *evt)
3431 struct ibmvfc_host *vhost = evt->vhost; 3445 struct ibmvfc_host *vhost = evt->vhost;
3432 struct ibmvfc_discover_targets *rsp = &evt->xfer_iu->discover_targets; 3446 struct ibmvfc_discover_targets *rsp = &evt->xfer_iu->discover_targets;
3433 u32 mad_status = rsp->common.status; 3447 u32 mad_status = rsp->common.status;
3448 int level = IBMVFC_DEFAULT_LOG_LEVEL;
3434 3449
3435 switch (mad_status) { 3450 switch (mad_status) {
3436 case IBMVFC_MAD_SUCCESS: 3451 case IBMVFC_MAD_SUCCESS:
@@ -3439,9 +3454,9 @@ static void ibmvfc_discover_targets_done(struct ibmvfc_event *evt)
3439 ibmvfc_set_host_action(vhost, IBMVFC_HOST_ACTION_ALLOC_TGTS); 3454 ibmvfc_set_host_action(vhost, IBMVFC_HOST_ACTION_ALLOC_TGTS);
3440 break; 3455 break;
3441 case IBMVFC_MAD_FAILED: 3456 case IBMVFC_MAD_FAILED:
3442 dev_err(vhost->dev, "Discover Targets failed: %s (%x:%x)\n", 3457 level += ibmvfc_retry_host_init(vhost);
3443 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error); 3458 ibmvfc_log(vhost, level, "Discover Targets failed: %s (%x:%x)\n",
3444 ibmvfc_retry_host_init(vhost); 3459 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error);
3445 break; 3460 break;
3446 case IBMVFC_MAD_DRIVER_FAILED: 3461 case IBMVFC_MAD_DRIVER_FAILED:
3447 break; 3462 break;
@@ -3493,18 +3508,19 @@ static void ibmvfc_npiv_login_done(struct ibmvfc_event *evt)
3493 u32 mad_status = evt->xfer_iu->npiv_login.common.status; 3508 u32 mad_status = evt->xfer_iu->npiv_login.common.status;
3494 struct ibmvfc_npiv_login_resp *rsp = &vhost->login_buf->resp; 3509 struct ibmvfc_npiv_login_resp *rsp = &vhost->login_buf->resp;
3495 unsigned int npiv_max_sectors; 3510 unsigned int npiv_max_sectors;
3511 int level = IBMVFC_DEFAULT_LOG_LEVEL;
3496 3512
3497 switch (mad_status) { 3513 switch (mad_status) {
3498 case IBMVFC_MAD_SUCCESS: 3514 case IBMVFC_MAD_SUCCESS:
3499 ibmvfc_free_event(evt); 3515 ibmvfc_free_event(evt);
3500 break; 3516 break;
3501 case IBMVFC_MAD_FAILED: 3517 case IBMVFC_MAD_FAILED:
3502 dev_err(vhost->dev, "NPIV Login failed: %s (%x:%x)\n",
3503 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error);
3504 if (ibmvfc_retry_cmd(rsp->status, rsp->error)) 3518 if (ibmvfc_retry_cmd(rsp->status, rsp->error))
3505 ibmvfc_retry_host_init(vhost); 3519 level += ibmvfc_retry_host_init(vhost);
3506 else 3520 else
3507 ibmvfc_link_down(vhost, IBMVFC_LINK_DEAD); 3521 ibmvfc_link_down(vhost, IBMVFC_LINK_DEAD);
3522 ibmvfc_log(vhost, level, "NPIV Login failed: %s (%x:%x)\n",
3523 ibmvfc_get_cmd_error(rsp->status, rsp->error), rsp->status, rsp->error);
3508 ibmvfc_free_event(evt); 3524 ibmvfc_free_event(evt);
3509 return; 3525 return;
3510 case IBMVFC_MAD_CRQ_ERROR: 3526 case IBMVFC_MAD_CRQ_ERROR:
diff --git a/drivers/scsi/ibmvscsi/ibmvfc.h b/drivers/scsi/ibmvscsi/ibmvfc.h
index ca1dcf7a7568..4dac3560c1a4 100644
--- a/drivers/scsi/ibmvscsi/ibmvfc.h
+++ b/drivers/scsi/ibmvscsi/ibmvfc.h
@@ -707,6 +707,12 @@ struct ibmvfc_host {
707#define tgt_err(t, fmt, ...) \ 707#define tgt_err(t, fmt, ...) \
708 dev_err((t)->vhost->dev, "%llX: " fmt, (t)->scsi_id, ##__VA_ARGS__) 708 dev_err((t)->vhost->dev, "%llX: " fmt, (t)->scsi_id, ##__VA_ARGS__)
709 709
710#define tgt_log(t, level, fmt, ...) \
711 do { \
712 if ((t)->vhost->log_level >= level) \
713 tgt_err(t, fmt, ##__VA_ARGS__); \
714 } while (0)
715
710#define ibmvfc_dbg(vhost, ...) \ 716#define ibmvfc_dbg(vhost, ...) \
711 DBG_CMD(dev_info((vhost)->dev, ##__VA_ARGS__)) 717 DBG_CMD(dev_info((vhost)->dev, ##__VA_ARGS__))
712 718