#include <netinet6/in6_ifattach.h>
#endif /* INET6 */
-#if NS
-#include <netns/ns.h>
-#include <netns/ns_if.h>
-#endif
-
#include "bpfilter.h"
#if NBPFILTER > 0
#include <net/bpf.h>
}
ifp->if_flags &= ~IFF_RUNNING;
funsetown(tp->tun_sigio);
- thread_funnel_switch(NETWORK_FUNNEL, KERNEL_FUNNEL);
selwakeup(&tp->tun_rsel);
- thread_funnel_switch(KERNEL_FUNNEL, NETWORK_FUNNEL);
+ selthreadclear(&tp->tun_rsel);
TUNDEBUG ("%s%d: closed\n", ifp->if_name, ifp->if_unit);
return (0);
s = splimp();
switch(cmd) {
+ case SIOCGIFSTATUS:
+ ifs = (struct ifstat *)data;
+ if (tp->tun_pid)
+ sprintf(ifs->ascii + strlen(ifs->ascii),
+ "\tOpened by PID %d\n", tp->tun_pid);
+ break;
case SIOCSIFADDR:
tuninit(ifp->if_unit);
TUNDEBUG("%s%d: address set\n",
}
if (tp->tun_flags & TUN_ASYNC && tp->tun_sigio)
pgsigio(tp->tun_sigio, SIGIO, 0);
- thread_funnel_switch(NETWORK_FUNNEL, KERNEL_FUNNEL);
selwakeup(&tp->tun_rsel);
- thread_funnel_switch(KERNEL_FUNNEL, NETWORK_FUNNEL);
return 0;
}
* anyway, it either accepts the packet or drops it.
*/
static int
-tunpoll(dev, events, p)
+tunpoll(dev, events, wql, p)
dev_t dev;
int events;
+ void * wql;
struct proc *p;
{
int unit = dev_val(minor(dev)), s;
} else {
TUNDEBUG("%s%d: tunpoll waiting\n", ifp->if_name,
ifp->if_unit);
- selrecord(p, &tp->tun_rsel);
+ selrecord(p, &tp->tun_rsel, wql);
}
if (events & (POLLOUT | POLLWRNORM))