linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Re: Suggestion for a new system call: convert file handle to a cookie for transfering file handles between processes.)
@ 2003-07-21 17:04 RAMON_GARCIA_F
  2003-07-21 17:27 ` Jan Harkes
  0 siblings, 1 reply; 4+ messages in thread
From: RAMON_GARCIA_F @ 2003-07-21 17:04 UTC (permalink / raw)
  To: linux-kernel

Many of you have said that it is not a good thing to bloat the kernel
with new system calls. But for that purpose, it is important to design
the system interface in such way that primitives can be combined
together to get any desired result.

This is the reason why Linux clone() is better than Solaris threads, why
Unix fork()+execve() is better than Windows CreateProcess(). The former
are more simple primitives. They encourage simple and thus less error
prone code both in the kernel as in user space applications.

And that is exactly the reason why I like the interface that I designed.
As opposed to transfer of handles through unix domain sockets, that is
tied to unix sockets, my interface is more primitive. It is not tied to
anything. You get a representation of a file handle, and then you can
transfer it through a regular file, a pipe, ...

Ramon



^ permalink raw reply	[flat|nested] 4+ messages in thread
* Re: Suggestion for a new system call: convert file handle to a cookie for transfering file handles between processes.)
@ 2003-07-21 19:06 RAMON_GARCIA_F
  0 siblings, 0 replies; 4+ messages in thread
From: RAMON_GARCIA_F @ 2003-07-21 19:06 UTC (permalink / raw)
  To: Jan Harkes, linux-kernel

I do not understand the first argument. You seem to say it is posible
to create tcpsockets between different computers while it is not useful
to pass cookies under it. I do not see any problem. Just use cookies in
the local system only.

With regard to resource limits, the solution is not too difficult. As
far as resource limits are concernted, a cookie created and not yet
destroyed should count as a file handle owned by the process and user
that created it. That is, a process cannot have more coookies opened and
 not yet consumed plus total open files than the maximum number of
process descriptors. The same for each user id. There is no need for a
new limit.

Apart from the inconvenience of sendmsg being a library function rather
than a system call, I am convinced that it would be posible to implement
unix socket descriptor passing as a library call. This is not posible
for practical reasons of backward compatibility. But that does not
demonstrate that the proposed primitive is not simpler.

Ramon



^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2003-07-22  2:45 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-07-21 17:04 Suggestion for a new system call: convert file handle to a cookie for transfering file handles between processes.) RAMON_GARCIA_F
2003-07-21 17:27 ` Jan Harkes
2003-07-21 19:31   ` Ingo Oeser
2003-07-21 19:06 RAMON_GARCIA_F

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).