summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkmacy <kmacy@FreeBSD.org>2008-09-25 06:46:28 +0000
committerkmacy <kmacy@FreeBSD.org>2008-09-25 06:46:28 +0000
commit7ed2245e3e156c78830bab862e09656891eea415 (patch)
tree055bc2dae42e8db7b4cb11c26c6654115ccfacb4
parentc88e53acc087aed8313451f59f185ad3db0e62f1 (diff)
downloadFreeBSD-src-7ed2245e3e156c78830bab862e09656891eea415.zip
FreeBSD-src-7ed2245e3e156c78830bab862e09656891eea415.tar.gz
fix insta-panic:
- determine which ext_arg offsets to use based on the version number Submitted by: Chelsio Inc. MFC after: 1 day
-rw-r--r--sys/dev/cxgb/sys/mvec.h4
-rw-r--r--sys/dev/cxgb/sys/uipc_mvec.c5
2 files changed, 9 insertions, 0 deletions
diff --git a/sys/dev/cxgb/sys/mvec.h b/sys/dev/cxgb/sys/mvec.h
index 09dbf12..855c039 100644
--- a/sys/dev/cxgb/sys/mvec.h
+++ b/sys/dev/cxgb/sys/mvec.h
@@ -62,8 +62,12 @@ struct m_ext_ {
caddr_t ext_buf; /* start of buffer */
void (*ext_free) /* free routine if not the usual */
(void *, void *);
+#if __FreeBSD_version >= 800016
void *ext_arg1; /* optional argument pointer */
void *ext_arg2; /* optional argument pointer */
+#else
+ void *ext_args; /* optional argument pointer */
+#endif
u_int ext_size; /* size of buffer, for ext_free */
volatile u_int *ref_cnt; /* pointer to ref count info */
int ext_type; /* type of external storage */
diff --git a/sys/dev/cxgb/sys/uipc_mvec.c b/sys/dev/cxgb/sys/uipc_mvec.c
index cf0de13..1293e22 100644
--- a/sys/dev/cxgb/sys/uipc_mvec.c
+++ b/sys/dev/cxgb/sys/uipc_mvec.c
@@ -405,8 +405,13 @@ mb_free_ext_fast(struct mbuf_iovec *mi, int type, int idx)
case EXT_EXTREF:
KASSERT(mi->mi_ext.ext_free != NULL,
("%s: ext_free not set", __func__));
+#if __FreeBSD_version >= 800016
(*(mi->mi_ext.ext_free))(mi->mi_ext.ext_arg1,
mi->mi_ext.ext_arg2);
+#else
+ (*(mi->mi_ext.ext_free))(mi->mi_ext.ext_buf,
+ mi->mi_ext.ext_args);
+#endif
break;
default:
dump_mi(mi);
OpenPOWER on IntegriCloud