diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-16 03:34:31 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-16 03:34:31 +0000 |
commit | eed7690155b8ab92e57bfd532f6707e1fafcea49 (patch) | |
tree | 5aba6d543912720f86ce32ccf955d7b0f44d8438 /llvm/tools | |
parent | 8c1ee47fb036645c91744626505573786d16fece (diff) | |
download | bcm5719-llvm-eed7690155b8ab92e57bfd532f6707e1fafcea49.tar.gz bcm5719-llvm-eed7690155b8ab92e57bfd532f6707e1fafcea49.zip |
Use open+fstat instead of stat+open.
llvm-svn: 186381
Diffstat (limited to 'llvm/tools')
-rw-r--r-- | llvm/tools/llvm-ar/llvm-ar.cpp | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/llvm/tools/llvm-ar/llvm-ar.cpp b/llvm/tools/llvm-ar/llvm-ar.cpp index e082687643d..32bcb49a1db 100644 --- a/llvm/tools/llvm-ar/llvm-ar.cpp +++ b/llvm/tools/llvm-ar/llvm-ar.cpp @@ -555,13 +555,23 @@ static void performWriteOperation(ArchiveOperation Operation, printWithSpacePadding(Out, Name, 16); if (I->isNewMember()) { - // FIXME: we do a stat + open. We should do a open + fstat. const char *FileName = I->getNew(); + + int OpenFlags = O_RDONLY; +#ifdef O_BINARY + OpenFlags |= O_BINARY; +#endif + int FD = ::open(FileName, OpenFlags); + if (FD == -1) + return failIfError(error_code(errno, posix_category()), FileName); + sys::fs::file_status Status; - failIfError(sys::fs::status(FileName, Status), FileName); + failIfError(sys::fs::status(FD, Status), FileName); OwningPtr<MemoryBuffer> File; - failIfError(MemoryBuffer::getFile(FileName, File), FileName); + failIfError( + MemoryBuffer::getOpenFile(FD, FileName, File, Status.getSize()), + FileName); uint64_t secondsSinceEpoch = Status.getLastModificationTime().toEpochTime(); |