Flesh out a page size accessor in the new API.
authorChandler Carruth <chandlerc@gmail.com>
Mon, 31 Dec 2012 23:23:35 +0000 (23:23 +0000)
committerChandler Carruth <chandlerc@gmail.com>
Mon, 31 Dec 2012 23:23:35 +0000 (23:23 +0000)
Implement the old API in terms of the new one. This simplifies the
implementation on Windows which can now re-use the self_process's once
initialization.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@171330 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Support/Process.h
lib/Support/Process.cpp
lib/Support/Unix/Process.inc
lib/Support/Windows/Process.inc
unittests/Support/ProcessTest.cpp

index 6b29f57fc1c881c9597c0d5d30eca10afe48ab41..15fa3763c918a5873a1a71575df334418433bf71 100644 (file)
@@ -89,7 +89,27 @@ class self_process : public process {
 public:
   virtual id_type get_id();
 
+  /// \name Process configuration (sysconf on POSIX)
+  /// @{
+
+  /// \brief Get the virtual memory page size.
+  ///
+  /// Query the operating system for this process's page size.
+  size_t page_size() const { return PageSize; };
+
+  /// @}
+
 private:
+  /// \name Cached process state.
+  /// @{
+
+  /// \brief Cached page size, this cannot vary during the life of the process.
+  size_t PageSize;
+
+  /// @}
+
+  /// \brief Constructor, used by \c process::get_self() only.
+  self_process();
 };
 
 
index 1e21d64e601f43cc85da8fa054faad2ef7d7a7b5..9d87b7744b8cebd92eb54cf41c3326c67e262ae2 100644 (file)
@@ -55,6 +55,14 @@ self_process::~self_process() {
 #endif
 
 
+//===----------------------------------------------------------------------===//
+// Implementations of legacy functions in terms of the new self_process object.
+
+unsigned Process::GetPageSize() {
+  return process::get_self()->page_size();
+}
+
+
 // Include the platform-specific parts of this class.
 #ifdef LLVM_ON_UNIX
 #include "Unix/Process.inc"
index e96d37ce563fd941cd451b4dde3149bce16a094c..9ad6272bab48b3f3239b9feb08e54c58dbe25942 100644 (file)
@@ -49,10 +49,7 @@ process::id_type self_process::get_id() {
   return getpid();
 }
 
-
-unsigned
-Process::GetPageSize()
-{
+static unsigned getPageSize() {
 #if defined(__CYGWIN__)
   // On Cygwin, getpagesize() returns 64k but the page size for the purposes of
   // memory protection and mmap() is 4k.
@@ -68,6 +65,12 @@ Process::GetPageSize()
   return static_cast<unsigned>(page_size);
 }
 
+// This constructor guaranteed to be run exactly once on a single thread, and
+// sets up various process invariants that can be queried cheaply from then on.
+self_process::self_process() : PageSize(getPageSize()) {
+}
+
+
 size_t Process::GetMallocUsage() {
 #if defined(HAVE_MALLINFO)
   struct mallinfo mi;
index d3a0c94e1ceec7f222b03b1b1908f7e7c312db0a..9eb611be8707b97f58b7d37a01b4b0c24a1096a2 100644 (file)
@@ -43,11 +43,9 @@ process::id_type self_process::get_id() {
   return GetCurrentProcess();
 }
 
-
 // This function retrieves the page size using GetSystemInfo and is present
-// solely so it can be called once in Process::GetPageSize to initialize the
-// static variable PageSize.
-inline unsigned GetPageSizeOnce() {
+// solely so it can be called once to initialize the self_process member below.
+static unsigned getPageSize() {
   // NOTE: A 32-bit application running under WOW64 is supposed to use
   // GetNativeSystemInfo.  However, this interface is not present prior
   // to Windows XP so to use it requires dynamic linking.  It is not clear
@@ -58,12 +56,12 @@ inline unsigned GetPageSizeOnce() {
   return static_cast<unsigned>(info.dwPageSize);
 }
 
-unsigned
-Process::GetPageSize() {
-  static const unsigned PageSize = GetPageSizeOnce();
-  return PageSize;
+// This constructor guaranteed to be run exactly once on a single thread, and
+// sets up various process invariants that can be queried cheaply from then on.
+self_process::self_process() : PageSize(getPageSize()) {
 }
 
+
 size_t
 Process::GetMallocUsage()
 {
index d4c4b54ccca6222676d9c1e5213da3a2c7619244..58a7c4acaaa18a3fffda2ec0e2f551b736c9fab7 100644 (file)
@@ -28,6 +28,8 @@ TEST(ProcessTest, SelfProcess) {
 #elif defined(LLVM_ON_WIN32)
   EXPECT_EQ(GetCurrentProcess(), process::get_self()->get_id());
 #endif
+
+  EXPECT_LT(1u, process::get_self()->page_size());
 }
 
 } // end anonymous namespace