Re: [patch v2] epoll use a single inode ...

From: Eric Dumazet
Date: Tue Mar 06 2007 - 01:23:05 EST


Davide Libenzi a écrit :
On Mon, 5 Mar 2007, H. Peter Anvin wrote:

Davide Libenzi wrote:
Right now is using:

this.len = sprintf(name, "[%u.%d]", current->pid, fd);

That should be unique and not have the wraparound problem. Ack?

NAK, very much NAK.

File descriptors aren't file structures, they're *pointers* to file
structures.

It's perfectly possible -- downright common -- for a file descriptor to be
inherited by another process, and then the pid is recycled -- collision.

Ugh! Right! 64 bit counter it is ... :)

For epoll, I suspect this is harmless : Programs dont allocate epolls fd every milli second, but at startup only.

For pipes/sockets, using a 64 bits would be problematic, because sprintf() uses a divide for each digit. And a divide is slow. Ten divides are *very* slow.


-
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/