summaryrefslogtreecommitdiff
path: root/usr/src/uts/common/inet/ip/ipsecesp.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr/src/uts/common/inet/ip/ipsecesp.c')
-rw-r--r--usr/src/uts/common/inet/ip/ipsecesp.c28
1 files changed, 15 insertions, 13 deletions
diff --git a/usr/src/uts/common/inet/ip/ipsecesp.c b/usr/src/uts/common/inet/ip/ipsecesp.c
index abf3e8816c..539eaef17c 100644
--- a/usr/src/uts/common/inet/ip/ipsecesp.c
+++ b/usr/src/uts/common/inet/ip/ipsecesp.c
@@ -19,7 +19,7 @@
* CDDL HEADER END
*/
/*
- * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
+ * Copyright 2010 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
@@ -3450,25 +3450,27 @@ esp_add_sa_finish(mblk_t *mp, sadb_msg_t *samsg, keysock_in_t *ksi,
} /* Else sadb_common_add unlinks it for me! */
}
- lpkt = NULL;
- if (larval != NULL)
- lpkt = sadb_clear_lpkt(larval);
+ if (larval != NULL) {
+ /*
+ * Hold again, because sadb_common_add() consumes a reference,
+ * and we don't want to clear_lpkt() without a reference.
+ */
+ IPSA_REFHOLD(larval);
+ }
rc = sadb_common_add(espstack->esp_pfkey_q,
mp, samsg, ksi, primary, secondary, larval, clone, is_inbound,
diagnostic, espstack->ipsecesp_netstack, &espstack->esp_sadb);
- if (lpkt != NULL) {
+ if (larval != NULL) {
if (rc == 0) {
- rc = !taskq_dispatch(esp_taskq, inbound_task,
- lpkt, TQ_NOSLEEP);
- }
- if (rc != 0) {
- lpkt = ip_recv_attr_free_mblk(lpkt);
- ip_drop_packet(lpkt, B_TRUE, NULL,
- DROPPER(ipss, ipds_sadb_inlarval_timeout),
- &espstack->esp_dropper);
+ lpkt = sadb_clear_lpkt(larval);
+ if (lpkt != NULL) {
+ rc = !taskq_dispatch(esp_taskq, inbound_task,
+ lpkt, TQ_NOSLEEP);
+ }
}
+ IPSA_REFRELE(larval);
}
/*