Subject: should networkdevice_ioctl() always be called from a thread context?
To: None <tech-net@netbsd.org, tech-kern@netbsd.org>
From: Ignatios Souvatzis <is@netbsd.org>
List: tech-kern
Date: 09/25/2006 13:35:22
Hi,

while analyzing, writing, and reparing kern/34521, I wondered:

- should interface_ioctl() always be called by a thread context?

Background:

IPv6 neighbour/router/prefix discovery can trigger an interface
address addition from the (soft) network interupt when an ICMPv6
router advertizement comes in. THe ICMPv6 code eventally calls
the driver's foo_ioctl(... SIOCADDMULTI ...) call to register the
multicast address the interface needs to listen to for the IPv6 
neigbbour discovery to work.

Now, the aue_ioctl() eventually calls usb code that is not interupt
safe.

You may have noticed that I fixed this for netbsd-4 and later by
activating a workqueue(9) [which is a kernel thread in disguise].
However, I wonder whether foo_ioctl() should be able to expect that
it's called from a thread context, that is, whether the ICMPv6 code
(and other code that calls ..._ioctl() entry points) should create
a work thread itself if necessary.

[Others have already mentioned that we're doing too much stuff in
interupt context...]

What do you think?

Regards,
	-is