Module Name: src Committed By: mlelstv Date: Sun Jun 5 13:54:28 UTC 2016
Modified Files: src/sys/dev/iscsi: iscsi_send.c iscsi_utils.c Log Message: Handle freeing of PDU when referencing CCB is freed. To generate a diff of this commit: cvs rdiff -u -r1.29 -r1.30 src/sys/dev/iscsi/iscsi_send.c cvs rdiff -u -r1.18 -r1.19 src/sys/dev/iscsi/iscsi_utils.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/iscsi/iscsi_send.c diff -u src/sys/dev/iscsi/iscsi_send.c:1.29 src/sys/dev/iscsi/iscsi_send.c:1.30 --- src/sys/dev/iscsi/iscsi_send.c:1.29 Sun Jun 5 09:12:48 2016 +++ src/sys/dev/iscsi/iscsi_send.c Sun Jun 5 13:54:28 2016 @@ -1,4 +1,4 @@ -/* $NetBSD: iscsi_send.c,v 1.29 2016/06/05 09:12:48 mlelstv Exp $ */ +/* $NetBSD: iscsi_send.c,v 1.30 2016/06/05 13:54:28 mlelstv Exp $ */ /*- * Copyright (c) 2004,2005,2006,2011 The NetBSD Foundation, Inc. @@ -291,6 +291,7 @@ iscsi_send_thread(void *par) ccb_t *ccb, *nccb; pdu_t *pdu; struct file *fp; + pdu_disp_t pdisp; sess = conn->session; /* so cleanup thread knows there's someone left */ @@ -302,6 +303,7 @@ iscsi_send_thread(void *par) while (!conn->terminating && (pdu = TAILQ_FIRST(&conn->pdus_to_send)) != NULL) { TAILQ_REMOVE(&conn->pdus_to_send, pdu, send_chain); + pdu->flags &= ~PDUF_INQUEUE; mutex_exit(&conn->lock); /* update ExpStatSN here to avoid discontinuities */ @@ -315,12 +317,14 @@ iscsi_send_thread(void *par) my_soo_write(conn, &pdu->uio); mutex_enter(&conn->lock); - pdu->flags &= ~PDUF_INQUEUE; - if (pdu->disp > PDUDISP_FREE) + pdisp = pdu->disp; + if (pdisp <= PDUDISP_FREE) + pdu->disp = PDUDISP_UNUSED; + else pdu->flags &= ~PDUF_BUSY; mutex_exit(&conn->lock); - if (pdu->disp <= PDUDISP_FREE) + if (pdisp <= PDUDISP_FREE) free_pdu(pdu); mutex_enter(&conn->lock); Index: src/sys/dev/iscsi/iscsi_utils.c diff -u src/sys/dev/iscsi/iscsi_utils.c:1.18 src/sys/dev/iscsi/iscsi_utils.c:1.19 --- src/sys/dev/iscsi/iscsi_utils.c:1.18 Sun Jun 5 09:21:14 2016 +++ src/sys/dev/iscsi/iscsi_utils.c Sun Jun 5 13:54:28 2016 @@ -1,4 +1,4 @@ -/* $NetBSD: iscsi_utils.c,v 1.18 2016/06/05 09:21:14 mlelstv Exp $ */ +/* $NetBSD: iscsi_utils.c,v 1.19 2016/06/05 13:54:28 mlelstv Exp $ */ /*- * Copyright (c) 2004,2005,2006,2008 The NetBSD Foundation, Inc. @@ -268,16 +268,17 @@ void free_ccb(ccb_t *ccb) { session_t *sess = ccb->session; + connection_t *conn = ccb->connection; pdu_t *pdu; - DEBC(ccb->connection, 15, ( + DEBC(conn, 15, ( "free_ccb: ccb = %p, usecount = %d\n", - ccb, ccb->connection->usecount-1)); + ccb, conn->usecount-1)); KASSERT((ccb->flags & CCBF_THROTTLING) == 0); KASSERT((ccb->flags & CCBF_WAITQUEUE) == 0); - atomic_dec_uint(&ccb->connection->usecount); + atomic_dec_uint(&conn->usecount); ccb->connection = NULL; if (ccb->disp > CCBDISP_NOWAIT) { @@ -296,6 +297,12 @@ free_ccb(ccb_t *ccb) /* free PDU waiting for ACK */ if ((pdu = ccb->pdu_waiting) != NULL) { ccb->pdu_waiting = NULL; + mutex_enter(&conn->lock); + if ((pdu->flags & PDUF_INQUEUE) != 0) { + TAILQ_REMOVE(&conn->pdus_to_send, pdu, send_chain); + pdu->flags &= ~PDUF_INQUEUE; + } + mutex_exit(&conn->lock); free_pdu(pdu); }