Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 29 May 2012 21:59:09 +0000 (UTC)
From:      Dimitry Andric <dim@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r236260 - in head/contrib/llvm: include/llvm/Support lib/Support/Unix lib/Support/Windows tools/clang/lib/Frontend
Message-ID:  <201205292159.q4TLx9Yf005377@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: dim
Date: Tue May 29 21:59:09 2012
New Revision: 236260
URL: http://svn.freebsd.org/changeset/base/236260

Log:
  Pull in r156591 from upstream llvm trunk:
  
    Allow unique_file to take a mode for file permissions, but default
    to user only read/write.
  
  and r156592 from upstream clang trunk:
  
    For final output files create them with mode 0664 to match other
    compilers and expected defaults.
  
  This should fix clang creating files with mode 0600.
  
  Reported by:	James <james@hicag.org>
  MFC after:	3 days

Modified:
  head/contrib/llvm/include/llvm/Support/FileSystem.h
  head/contrib/llvm/lib/Support/Unix/PathV2.inc
  head/contrib/llvm/lib/Support/Windows/PathV2.inc
  head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp

Modified: head/contrib/llvm/include/llvm/Support/FileSystem.h
==============================================================================
--- head/contrib/llvm/include/llvm/Support/FileSystem.h	Tue May 29 21:34:09 2012	(r236259)
+++ head/contrib/llvm/include/llvm/Support/FileSystem.h	Tue May 29 21:59:09 2012	(r236260)
@@ -422,8 +422,8 @@ error_code status_known(const Twine &pat
 /// @results errc::success if result_{fd,path} have been successfully set,
 ///          otherwise a platform specific error_code.
 error_code unique_file(const Twine &model, int &result_fd,
-                             SmallVectorImpl<char> &result_path,
-                             bool makeAbsolute = true);
+                       SmallVectorImpl<char> &result_path,
+                       bool makeAbsolute = true, unsigned mode = 0600);
 
 /// @brief Canonicalize path.
 ///

Modified: head/contrib/llvm/lib/Support/Unix/PathV2.inc
==============================================================================
--- head/contrib/llvm/lib/Support/Unix/PathV2.inc	Tue May 29 21:34:09 2012	(r236259)
+++ head/contrib/llvm/lib/Support/Unix/PathV2.inc	Tue May 29 21:59:09 2012	(r236260)
@@ -346,9 +346,10 @@ error_code status(const Twine &path, fil
   return error_code::success();
 }
 
+// Since this is most often used for temporary files, mode defaults to 0600.
 error_code unique_file(const Twine &model, int &result_fd,
-                             SmallVectorImpl<char> &result_path,
-                             bool makeAbsolute) {
+                       SmallVectorImpl<char> &result_path,
+                       bool makeAbsolute, unsigned mode) {
   SmallString<128> Model;
   model.toVector(Model);
   // Null terminate.
@@ -395,7 +396,7 @@ retry_random_path:
 
   // Try to open + create the file.
 rety_open_create:
-  int RandomFD = ::open(RandomPath.c_str(), O_RDWR | O_CREAT | O_EXCL, 0600);
+  int RandomFD = ::open(RandomPath.c_str(), O_RDWR | O_CREAT | O_EXCL, mode);
   if (RandomFD == -1) {
     // If the file existed, try again, otherwise, error.
     if (errno == errc::file_exists)

Modified: head/contrib/llvm/lib/Support/Windows/PathV2.inc
==============================================================================
--- head/contrib/llvm/lib/Support/Windows/PathV2.inc	Tue May 29 21:34:09 2012	(r236259)
+++ head/contrib/llvm/lib/Support/Windows/PathV2.inc	Tue May 29 21:59:09 2012	(r236260)
@@ -487,9 +487,11 @@ handle_status_error:
   return error_code::success();
 }
 
+// FIXME: mode should be used here and default to user r/w only,
+// it currently comes in as a UNIX mode.
 error_code unique_file(const Twine &model, int &result_fd,
-                             SmallVectorImpl<char> &result_path,
-                             bool makeAbsolute) {
+                       SmallVectorImpl<char> &result_path,
+                       bool makeAbsolute, unsigned mode) {
   // Use result_path as temp storage.
   result_path.set_size(0);
   StringRef m = model.toStringRef(result_path);

Modified: head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp
==============================================================================
--- head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp	Tue May 29 21:34:09 2012	(r236259)
+++ head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp	Tue May 29 21:59:09 2012	(r236260)
@@ -560,7 +560,8 @@ CompilerInstance::createOutputFile(Strin
       TempPath += "-%%%%%%%%";
       int fd;
       if (llvm::sys::fs::unique_file(TempPath.str(), fd, TempPath,
-                               /*makeAbsolute=*/false) == llvm::errc::success) {
+                                     /*makeAbsolute=*/false, 0664)
+          == llvm::errc::success) {
         OS.reset(new llvm::raw_fd_ostream(fd, /*shouldClose=*/true));
         OSFile = TempFile = TempPath.str();
       }



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201205292159.q4TLx9Yf005377>