On Sat, 23 May 2009, Johannes Schindelin wrote: > On Fri, 15 May 2009, Linus Torvalds wrote: > > > On Fri, 15 May 2009, Johannes Schindelin wrote: > > > > > > fd = mkstemp(template); > > > + if (fd < 0) { > > > + release_pack_memory((size_t)-1ll, -1); > > > + fd = mkstemp(template); > > > > This is wrong. You can't use "template" twice. You need to re-initialize > > it. The first one will blow away the XXXX pattern. > > Turns out that would be awkward, as the xmkstemp() function would have to > copy the template just in case mkstemp() fails due to too many open files, > and of course it would need to release the copy afterwards. > > OTOH we cannot just use the initialized filename, because there > might be a race condition with another process, right? Correct. You basically need to have the caller re-create the template. We already do that in some other cases: see odb_mkstemp(), or create_tempfile(). Both of them do that template re-creation on failure, and try again. You could save off the template into a local temporary array, of course. Linus -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html