summaryrefslogtreecommitdiffstats
path: root/sys/net
diff options
context:
space:
mode:
authorzec <zec@FreeBSD.org>2011-06-07 20:46:03 +0000
committerzec <zec@FreeBSD.org>2011-06-07 20:46:03 +0000
commit5bdda7f91b10ca46468c2c8773e9f861a6d5e8ad (patch)
tree98d96445ad1c57672214ff1764a441f0a8e3cf15 /sys/net
parentf6cfb7359dc65080027581c9099b39284c5d3d50 (diff)
downloadFreeBSD-src-5bdda7f91b10ca46468c2c8773e9f861a6d5e8ad.zip
FreeBSD-src-5bdda7f91b10ca46468c2c8773e9f861a6d5e8ad.tar.gz
Set curvnet context in a callout-trigerred code path.
MFC after: 3 days
Diffstat (limited to 'sys/net')
-rw-r--r--sys/net/bridgestp.c5
-rw-r--r--sys/net/bridgestp.h1
2 files changed, 6 insertions, 0 deletions
diff --git a/sys/net/bridgestp.c b/sys/net/bridgestp.c
index 2993838..e263b0b 100644
--- a/sys/net/bridgestp.c
+++ b/sys/net/bridgestp.c
@@ -1860,6 +1860,8 @@ bstp_tick(void *arg)
if (bs->bs_running == 0)
return;
+ CURVNET_SET(bs->bs_vnet);
+
/* slow timer to catch missed link events */
if (bstp_timer_expired(&bs->bs_link_timer)) {
LIST_FOREACH(bp, &bs->bs_bplist, bp_next)
@@ -1893,6 +1895,8 @@ bstp_tick(void *arg)
bp->bp_txcount--;
}
+ CURVNET_RESTORE();
+
callout_reset(&bs->bs_bstpcallout, hz, bstp_tick, bs);
}
@@ -2126,6 +2130,7 @@ bstp_attach(struct bstp_state *bs, struct bstp_cb_ops *cb)
bs->bs_protover = BSTP_PROTO_RSTP;
bs->bs_state_cb = cb->bcb_state;
bs->bs_rtage_cb = cb->bcb_rtage;
+ bs->bs_vnet = curvnet;
getmicrotime(&bs->bs_last_tc_time);
diff --git a/sys/net/bridgestp.h b/sys/net/bridgestp.h
index 74086fc..fdf16aa 100644
--- a/sys/net/bridgestp.h
+++ b/sys/net/bridgestp.h
@@ -358,6 +358,7 @@ struct bstp_state {
LIST_HEAD(, bstp_port) bs_bplist;
bstp_state_cb_t bs_state_cb;
bstp_rtage_cb_t bs_rtage_cb;
+ struct vnet *bs_vnet;
};
#define BSTP_LOCK_INIT(_bs) mtx_init(&(_bs)->bs_mtx, "bstp", NULL, MTX_DEF)
OpenPOWER on IntegriCloud