From 1792510380da6bc270198fc2d3d0bac2c3957c52 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Axel=20D=C3=B6rfler?= Date: Sat, 28 Jun 2003 02:44:20 +0000 Subject: [PATCH] Fixed the pipe creation and made it secure against very fast threads, as suggested by Ingo. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3704 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/kernel/libroot/posix/unistd/pipe.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/kernel/libroot/posix/unistd/pipe.c b/src/kernel/libroot/posix/unistd/pipe.c index 51516f47ca..6d38b43cda 100644 --- a/src/kernel/libroot/posix/unistd/pipe.c +++ b/src/kernel/libroot/posix/unistd/pipe.c @@ -14,10 +14,11 @@ int pipe(int streams[2]) { - // ToDo: if the thread manages to call this function during the - // the same microsecond twice, we're doomed :) + static int32 counter = 0; + // ToDo: a way without this variable would be even cooler + char pipeName[64]; - sprintf(pipeName, "/pipe/%lx-%Ld\n", find_thread(NULL), system_time()); + sprintf(pipeName, "/pipe/%03lx-%03ld", find_thread(NULL), atomic_add(&counter, 1)); streams[0] = open(pipeName, O_CREAT | O_RDONLY, 0777); if (streams[0] < 0)