aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/libfc/fc_elsct.c38
-rw-r--r--drivers/scsi/libfc/fc_lport.c20
-rw-r--r--drivers/scsi/libfc/fc_rport.c8
-rw-r--r--include/scsi/libfc.h5
4 files changed, 57 insertions, 14 deletions
diff --git a/drivers/scsi/libfc/fc_elsct.c b/drivers/scsi/libfc/fc_elsct.c
index 5e8b011af50e..d655924d46b6 100644
--- a/drivers/scsi/libfc/fc_elsct.c
+++ b/drivers/scsi/libfc/fc_elsct.c
@@ -70,3 +70,41 @@ int fc_elsct_init(struct fc_lport *lport)
70 return 0; 70 return 0;
71} 71}
72EXPORT_SYMBOL(fc_elsct_init); 72EXPORT_SYMBOL(fc_elsct_init);
73
74/**
75 * fc_els_resp_type() - return string describing ELS response for debug.
76 * @fp: frame pointer with possible error code.
77 */
78const char *fc_els_resp_type(struct fc_frame *fp)
79{
80 const char *msg;
81 if (IS_ERR(fp)) {
82 switch (-PTR_ERR(fp)) {
83 case FC_NO_ERR:
84 msg = "response no error";
85 break;
86 case FC_EX_TIMEOUT:
87 msg = "response timeout";
88 break;
89 case FC_EX_CLOSED:
90 msg = "response closed";
91 break;
92 default:
93 msg = "response unknown error";
94 break;
95 }
96 } else {
97 switch (fc_frame_payload_op(fp)) {
98 case ELS_LS_ACC:
99 msg = "accept";
100 break;
101 case ELS_LS_RJT:
102 msg = "reject";
103 break;
104 default:
105 msg = "response unknown ELS";
106 break;
107 }
108 }
109 return msg;
110}
diff --git a/drivers/scsi/libfc/fc_lport.c b/drivers/scsi/libfc/fc_lport.c
index d3f4e0c34f5c..3f2f72390145 100644
--- a/drivers/scsi/libfc/fc_lport.c
+++ b/drivers/scsi/libfc/fc_lport.c
@@ -1006,13 +1006,13 @@ static void fc_lport_rft_id_resp(struct fc_seq *sp, struct fc_frame *fp,
1006 struct fc_frame_header *fh; 1006 struct fc_frame_header *fh;
1007 struct fc_ct_hdr *ct; 1007 struct fc_ct_hdr *ct;
1008 1008
1009 FC_LPORT_DBG(lport, "Received a RFT_ID %s\n", fc_els_resp_type(fp));
1010
1009 if (fp == ERR_PTR(-FC_EX_CLOSED)) 1011 if (fp == ERR_PTR(-FC_EX_CLOSED))
1010 return; 1012 return;
1011 1013
1012 mutex_lock(&lport->lp_mutex); 1014 mutex_lock(&lport->lp_mutex);
1013 1015
1014 FC_LPORT_DBG(lport, "Received a RFT_ID response\n");
1015
1016 if (lport->state != LPORT_ST_RFT_ID) { 1016 if (lport->state != LPORT_ST_RFT_ID) {
1017 FC_LPORT_DBG(lport, "Received a RFT_ID response, but in state " 1017 FC_LPORT_DBG(lport, "Received a RFT_ID response, but in state "
1018 "%s\n", fc_lport_state(lport)); 1018 "%s\n", fc_lport_state(lport));
@@ -1060,13 +1060,13 @@ static void fc_lport_rpn_id_resp(struct fc_seq *sp, struct fc_frame *fp,
1060 struct fc_frame_header *fh; 1060 struct fc_frame_header *fh;
1061 struct fc_ct_hdr *ct; 1061 struct fc_ct_hdr *ct;
1062 1062
1063 FC_LPORT_DBG(lport, "Received a RPN_ID %s\n", fc_els_resp_type(fp));
1064
1063 if (fp == ERR_PTR(-FC_EX_CLOSED)) 1065 if (fp == ERR_PTR(-FC_EX_CLOSED))
1064 return; 1066 return;
1065 1067
1066 mutex_lock(&lport->lp_mutex); 1068 mutex_lock(&lport->lp_mutex);
1067 1069
1068 FC_LPORT_DBG(lport, "Received a RPN_ID response\n");
1069
1070 if (lport->state != LPORT_ST_RPN_ID) { 1070 if (lport->state != LPORT_ST_RPN_ID) {
1071 FC_LPORT_DBG(lport, "Received a RPN_ID response, but in state " 1071 FC_LPORT_DBG(lport, "Received a RPN_ID response, but in state "
1072 "%s\n", fc_lport_state(lport)); 1072 "%s\n", fc_lport_state(lport));
@@ -1112,13 +1112,13 @@ static void fc_lport_scr_resp(struct fc_seq *sp, struct fc_frame *fp,
1112 struct fc_lport *lport = lp_arg; 1112 struct fc_lport *lport = lp_arg;
1113 u8 op; 1113 u8 op;
1114 1114
1115 FC_LPORT_DBG(lport, "Received a SCR %s\n", fc_els_resp_type(fp));
1116
1115 if (fp == ERR_PTR(-FC_EX_CLOSED)) 1117 if (fp == ERR_PTR(-FC_EX_CLOSED))
1116 return; 1118 return;
1117 1119
1118 mutex_lock(&lport->lp_mutex); 1120 mutex_lock(&lport->lp_mutex);
1119 1121
1120 FC_LPORT_DBG(lport, "Received a SCR response\n");
1121
1122 if (lport->state != LPORT_ST_SCR) { 1122 if (lport->state != LPORT_ST_SCR) {
1123 FC_LPORT_DBG(lport, "Received a SCR response, but in state " 1123 FC_LPORT_DBG(lport, "Received a SCR response, but in state "
1124 "%s\n", fc_lport_state(lport)); 1124 "%s\n", fc_lport_state(lport));
@@ -1333,13 +1333,13 @@ static void fc_lport_logo_resp(struct fc_seq *sp, struct fc_frame *fp,
1333 struct fc_lport *lport = lp_arg; 1333 struct fc_lport *lport = lp_arg;
1334 u8 op; 1334 u8 op;
1335 1335
1336 FC_LPORT_DBG(lport, "Received a LOGO %s\n", fc_els_resp_type(fp));
1337
1336 if (fp == ERR_PTR(-FC_EX_CLOSED)) 1338 if (fp == ERR_PTR(-FC_EX_CLOSED))
1337 return; 1339 return;
1338 1340
1339 mutex_lock(&lport->lp_mutex); 1341 mutex_lock(&lport->lp_mutex);
1340 1342
1341 FC_LPORT_DBG(lport, "Received a LOGO response\n");
1342
1343 if (lport->state != LPORT_ST_LOGO) { 1343 if (lport->state != LPORT_ST_LOGO) {
1344 FC_LPORT_DBG(lport, "Received a LOGO response, but in state " 1344 FC_LPORT_DBG(lport, "Received a LOGO response, but in state "
1345 "%s\n", fc_lport_state(lport)); 1345 "%s\n", fc_lport_state(lport));
@@ -1415,13 +1415,13 @@ static void fc_lport_flogi_resp(struct fc_seq *sp, struct fc_frame *fp,
1415 unsigned int e_d_tov; 1415 unsigned int e_d_tov;
1416 u16 mfs; 1416 u16 mfs;
1417 1417
1418 FC_LPORT_DBG(lport, "Received a FLOGI %s\n", fc_els_resp_type(fp));
1419
1418 if (fp == ERR_PTR(-FC_EX_CLOSED)) 1420 if (fp == ERR_PTR(-FC_EX_CLOSED))
1419 return; 1421 return;
1420 1422
1421 mutex_lock(&lport->lp_mutex); 1423 mutex_lock(&lport->lp_mutex);
1422 1424
1423 FC_LPORT_DBG(lport, "Received a FLOGI response\n");
1424
1425 if (lport->state != LPORT_ST_FLOGI) { 1425 if (lport->state != LPORT_ST_FLOGI) {
1426 FC_LPORT_DBG(lport, "Received a FLOGI response, but in state " 1426 FC_LPORT_DBG(lport, "Received a FLOGI response, but in state "
1427 "%s\n", fc_lport_state(lport)); 1427 "%s\n", fc_lport_state(lport));
diff --git a/drivers/scsi/libfc/fc_rport.c b/drivers/scsi/libfc/fc_rport.c
index 02200b26d897..d014b285cd1a 100644
--- a/drivers/scsi/libfc/fc_rport.c
+++ b/drivers/scsi/libfc/fc_rport.c
@@ -544,7 +544,7 @@ static void fc_rport_plogi_resp(struct fc_seq *sp, struct fc_frame *fp,
544 544
545 mutex_lock(&rdata->rp_mutex); 545 mutex_lock(&rdata->rp_mutex);
546 546
547 FC_RPORT_DBG(rdata, "Received a PLOGI response\n"); 547 FC_RPORT_DBG(rdata, "Received a PLOGI %s\n", fc_els_resp_type(fp));
548 548
549 if (rdata->rp_state != RPORT_ST_PLOGI) { 549 if (rdata->rp_state != RPORT_ST_PLOGI) {
550 FC_RPORT_DBG(rdata, "Received a PLOGI response, but in state " 550 FC_RPORT_DBG(rdata, "Received a PLOGI response, but in state "
@@ -651,7 +651,7 @@ static void fc_rport_prli_resp(struct fc_seq *sp, struct fc_frame *fp,
651 651
652 mutex_lock(&rdata->rp_mutex); 652 mutex_lock(&rdata->rp_mutex);
653 653
654 FC_RPORT_DBG(rdata, "Received a PRLI response\n"); 654 FC_RPORT_DBG(rdata, "Received a PRLI %s\n", fc_els_resp_type(fp));
655 655
656 if (rdata->rp_state != RPORT_ST_PRLI) { 656 if (rdata->rp_state != RPORT_ST_PRLI) {
657 FC_RPORT_DBG(rdata, "Received a PRLI response, but in state " 657 FC_RPORT_DBG(rdata, "Received a PRLI response, but in state "
@@ -717,7 +717,7 @@ static void fc_rport_logo_resp(struct fc_seq *sp, struct fc_frame *fp,
717 717
718 mutex_lock(&rdata->rp_mutex); 718 mutex_lock(&rdata->rp_mutex);
719 719
720 FC_RPORT_DBG(rdata, "Received a LOGO response\n"); 720 FC_RPORT_DBG(rdata, "Received a LOGO %s\n", fc_els_resp_type(fp));
721 721
722 if (rdata->rp_state != RPORT_ST_LOGO) { 722 if (rdata->rp_state != RPORT_ST_LOGO) {
723 FC_RPORT_DBG(rdata, "Received a LOGO response, but in state " 723 FC_RPORT_DBG(rdata, "Received a LOGO response, but in state "
@@ -801,7 +801,7 @@ static void fc_rport_rtv_resp(struct fc_seq *sp, struct fc_frame *fp,
801 801
802 mutex_lock(&rdata->rp_mutex); 802 mutex_lock(&rdata->rp_mutex);
803 803
804 FC_RPORT_DBG(rdata, "Received a RTV response\n"); 804 FC_RPORT_DBG(rdata, "Received a RTV %s\n", fc_els_resp_type(fp));
805 805
806 if (rdata->rp_state != RPORT_ST_RTV) { 806 if (rdata->rp_state != RPORT_ST_RTV) {
807 FC_RPORT_DBG(rdata, "Received a RTV response, but in state " 807 FC_RPORT_DBG(rdata, "Received a RTV response, but in state "
diff --git a/include/scsi/libfc.h b/include/scsi/libfc.h
index 265f106d9fd6..e18e5ce5af51 100644
--- a/include/scsi/libfc.h
+++ b/include/scsi/libfc.h
@@ -1084,4 +1084,9 @@ void fc_destroy_exch_mgr(void);
1084int fc_setup_rport(void); 1084int fc_setup_rport(void);
1085void fc_destroy_rport(void); 1085void fc_destroy_rport(void);
1086 1086
1087/*
1088 * Internal libfc functions.
1089 */
1090const char *fc_els_resp_type(struct fc_frame *);
1091
1087#endif /* _LIBFC_H_ */ 1092#endif /* _LIBFC_H_ */