This is a prep patch to add a new error code to libiscsi. We want to
rework some kmap calls to be able to fail. When we do, we'd like to
use this error code.

This patch simply introduces ISCSI_TCP_INTERNAL_ERR and prints
"Internal Error." when it gets hit.

Signed-off-by: Logan Gunthorpe <log...@deltatee.com>
---
 drivers/scsi/cxgbi/libcxgbi.c | 5 +++++
 include/scsi/libiscsi_tcp.h   | 1 +
 2 files changed, 6 insertions(+)

diff --git a/drivers/scsi/cxgbi/libcxgbi.c b/drivers/scsi/cxgbi/libcxgbi.c
index bd7d39e..e38d0c1 100644
--- a/drivers/scsi/cxgbi/libcxgbi.c
+++ b/drivers/scsi/cxgbi/libcxgbi.c
@@ -1556,6 +1556,11 @@ static inline int read_pdu_skb(struct iscsi_conn *conn,
                 */
                iscsi_conn_printk(KERN_ERR, conn, "Invalid pdu or skb.");
                return -EFAULT;
+       case ISCSI_TCP_INTERNAL_ERR:
+               pr_info("skb 0x%p, off %u, %d, TCP_INTERNAL_ERR.\n",
+                       skb, offset, offloaded);
+               iscsi_conn_printk(KERN_ERR, conn, "Internal error.");
+               return -EFAULT;
        case ISCSI_TCP_SEGMENT_DONE:
                log_debug(1 << CXGBI_DBG_PDU_RX,
                        "skb 0x%p, off %u, %d, TCP_SEG_DONE, rc %d.\n",
diff --git a/include/scsi/libiscsi_tcp.h b/include/scsi/libiscsi_tcp.h
index 30520d5..90691ad 100644
--- a/include/scsi/libiscsi_tcp.h
+++ b/include/scsi/libiscsi_tcp.h
@@ -92,6 +92,7 @@ enum {
        ISCSI_TCP_SKB_DONE,             /* skb is out of data */
        ISCSI_TCP_CONN_ERR,             /* iscsi layer has fired a conn err */
        ISCSI_TCP_SUSPENDED,            /* conn is suspended */
+       ISCSI_TCP_INTERNAL_ERR,         /* an internal error occurred */
 };
 
 extern void iscsi_tcp_hdr_recv_prep(struct iscsi_tcp_conn *tcp_conn);
-- 
2.1.4

Reply via email to