Re: Why does connector use a work queue???

From: Evgeniy Polyakov
Date: Sun Feb 28 2010 - 14:52:49 EST


On Sat, Feb 27, 2010 at 06:57:02PM -0800, Eric W. Biederman (ebiederm@xxxxxxxxxxxx) wrote:
> These days netlink callbacks for messages happen in the context of the
> process who sent the message. Things like permission checks are much
> more complicated if we don't use that process context.
>
> I was looking at removing NETLINK_CB(skb).eff_cap but I discovered
> that connected takes the netlink messages, them from their
> perfectly good process context, and puts the into a workqueue
> for reasons that are not apparent to me.

Netlink was made synchronous rather recently and connector was not
changed to take advantage of that. Previously it used work queue to
postpone work processing into always-process context.

> Unless I am misreading something we should just be able to remove the
> work queues and greatly simplify the connector code.
>
> Something like:

Idea looks very good, thank you, but it misses structure changes
to eliminate now unneded members.

--
Evgeniy Polyakov
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/