"Michael Kerrisk (man-pages)" <mtk.manpages@xxxxxxxxx> writes:
On 07/26/2016 10:39 PM, Andrew Vagin wrote:
On Tue, Jul 26, 2016 at 09:17:31PM +0200, Michael Kerrisk (man-pages) wrote:
If we want to compare two file descriptors of the current process,
it is one of cases for which kcmp can be used. We can call kcmp to
compare two namespaces which are opened in other processes.
Is there really a use case there? I assume we're talking about the
scenario where a process in one namespace opens a /proc/PID/ns/*
file descriptor and passes that FD to another process via a UNIX
domain socket. Is that correct?
So, supposing that we want to build a map of the relationships
between namespaces using the proposed kcmp() API, and there are
say N namespaces? Does this mena we make (N * (N-1) / 2) calls
to kcmp()?
Potentially. The numbers are small enough O(N^2) isn't fatal.
Where kcmp shines is that it allows migration to happen. Inode numbers
to change (which they very much will today), and still have things work.
We can keep it O(Nlog(N)) by taking advantage of not just the equality
but the ordering relationship. Although Ugh.
One disadvantage of
kcmp currently is that the way the ordering relationship is defined
the order is not preserved over migration :(