[cfe-dev] Clang violates the mkstemp() contract?

Kees van Reeuwijk reeuwijk at few.vu.nl
Wed Jul 14 12:59:39 PDT 2010


On 14 Jul 2010, at 21:09, Török Edwin wrote:

> The file should probably not be removed at all. If there is concern
> that the file stays there after process exit, it should be added to
> removeFileOnSignal.

Well, clang is actually not interested in that particular file, because it wants to append a .o or .s after the filename that was generated. That makes the cleanup a bit trickier.

Also, clang uses mktemp() if mkstemp() is not available on a particular platform, and in that case clang should actively create the file as soon as it gets the name. 

> 
> 
>> 
>> Which seems to confirm that an unwarranted assumption is made.
>> 
>> The reason this works on many platforms is because there the unique
>> filename is generated by first attempting to use a name based on a
>> random number. If a file with that name exists, the name is then
>> modified to avoid existing names. However, on Minix the first attempt
>> uses the process id, so you'll always get the same temporary filename
>> if the previous ones do not exist (any more), on other platforms that
>> is far less likely (but not impossible).
> 
> Sounds like mkstemp() on Minix is fairly predictable then.


That's correct, but if you're implying that that is a security concern: AFAIK mkstemp() is supposed to be an atomic operation and therefore predictability is not a concern.

-- 
Kees van Reeuwijk








More information about the cfe-dev mailing list