Re: [take19 1/4] kevent: Core files.

From: Ulrich Drepper
Date: Mon Oct 16 2006 - 06:17:36 EST


Evgeniy Polyakov wrote:
The whole idea of mmap buffer seems to be broken, since those who asked
for creation do not like existing design and do not show theirs...

What kind of argumentation is that?

"Because my attempt to implement it doesn't work and nobody right
away has a better suggestion this means the idea is broken."

Nonsense.

It just means that time should be spend on thinking about this. You cut all this short by rushing out your attempt without any discussions. Unfortunately nobody else really looked at the approach so it lingered around for some weeks. Well, now it is clear that it is not the right approach and we can start thinking about it again.


You seems to not checked the code - each event can be marked as ready only one time, which means only one copy and so on.
It was done _specially_. And it is not limitation, but "new" approach.

I know that it is done deliberately and I tell you that this is wrong and unacceptable. Realtime signals are one event which need to have more than one event queued. This is no description of what you have implemented, it's a description of the reality of realtime signals.

RT signals are queued. They carry a data value (the sigval_t object) which can be unique for each signal delivery. Coalescing the signal events therefore leads to information loss.

Therefore, at the very least for signal we need to have the ability to queue more than one event for each event source. Not having this functionality means that signals and likely other types of events cannot be implemented using kevent queues.


Queue of the same signals or any other events has fundamental flawness
(as any other ring buffer implementation, which has queue size) -
it's size of the queue and extremely bad case of the overflow.

Of course there are additional problems. Overflows need to be handled. But this is nothing which is unsolvable.


So, the same event may not be ready several times. Any design which
allows to create infinite number of events generated for the same case
is broken, since consumer can be in situation, when it can not handle
that flow.

That's complete nonsense. Again, for RT signals it is very reasonable and not "broken" to have multiple outstanding signals.


That is why poll() returns only POLLIN when data is ready in
network stack, but is not trying to generate some kind of a signal for each byte/packet/MTU/MSS received.

It makes no sense to drag poll() into this discussion. poll() is a very limited interface. The new event handling is supposed to be the opposite, namely, usable for all kinds of events. Arguing that because poll() does it like this just means you don't see what big step is needed to get to the goal of a unified event handling. The shackles of poll() must be left behind.


RT signals have design problems, and I will not repeate the same error
with similar limits in kevent.

I don't know what to say. You claim to be the source of all wisdom is OS design. Maybe you should design your own OS, from ground up. I wonder how many people would like that since all your arguments are squarely geared towards optimizing the implementation. But: the implementation is irrelevant without users. The functionality users (= programmers) want and need is what must drive the implementation. And RT signals are definitely heavily used and liked by programmers. You have to accept that you try to modify an OS which has that functionality regardless of how much you hate it and want to fight it.


Mmap implementation can be added separately, since it does not affect
kevent core.

That I doubt very much and it is why I would not want the kevent stuff go into any released kernel until that "detail" is resolved.

--
â Ulrich Drepper â Red Hat, Inc. â 444 Castro St â Mountain View, CA â
-
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/