From cb1d4f92ec27a3b505201fbec8aa798478efabe5 Mon Sep 17 00:00:00 2001 From: "Christian S.J. Peron" Date: Tue, 4 Oct 2005 15:06:10 +0000 Subject: [PATCH] Protect PID initializations for statistics by the bpf descriptor locks. Also while we are here, protect the bpf descriptor during knlist_remove{add} operations. Discussed with: rwatson --- sys/net/bpf.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/sys/net/bpf.c b/sys/net/bpf.c index 659410d0a8d2..d2c2d51702c0 100644 --- a/sys/net/bpf.c +++ b/sys/net/bpf.c @@ -696,8 +696,8 @@ bpfioctl(dev, cmd, addr, flags, td) /* * Refresh PID associated with this descriptor. */ - d->bd_pid = td->td_proc->p_pid; BPFD_LOCK(d); + d->bd_pid = td->td_proc->p_pid; if (d->bd_state == BPF_WAITING) callout_stop(&d->bd_callout); d->bd_state = BPF_IDLE; @@ -1147,9 +1147,9 @@ bpfpoll(dev, events, td) /* * Refresh PID associated with this descriptor. */ - d->bd_pid = td->td_proc->p_pid; revents = events & (POLLOUT | POLLWRNORM); BPFD_LOCK(d); + d->bd_pid = td->td_proc->p_pid; if (events & (POLLIN | POLLRDNORM)) { if (bpf_ready(d)) revents |= events & (POLLIN | POLLRDNORM); @@ -1184,10 +1184,12 @@ bpfkqfilter(dev, kn) /* * Refresh PID associated with this descriptor. */ + BPFD_LOCK(d); d->bd_pid = curthread->td_proc->p_pid; kn->kn_fop = &bpfread_filtops; kn->kn_hook = d; knlist_add(&d->bd_sel.si_note, kn, 0); + BPFD_UNLOCK(d); return (0); } @@ -1198,7 +1200,9 @@ filt_bpfdetach(kn) { struct bpf_d *d = (struct bpf_d *)kn->kn_hook; + BPFD_LOCK(d); knlist_remove(&d->bd_sel.si_note, kn, 0); + BPFD_UNLOCK(d); } static int