summaryrefslogtreecommitdiff
path: root/Source/ThirdParty/ANGLE/util/linux
diff options
context:
space:
mode:
Diffstat (limited to 'Source/ThirdParty/ANGLE/util/linux')
-rw-r--r--Source/ThirdParty/ANGLE/util/linux/LinuxTimer.cpp49
-rw-r--r--Source/ThirdParty/ANGLE/util/linux/LinuxTimer.h31
-rw-r--r--Source/ThirdParty/ANGLE/util/linux/Linux_system_utils.cpp64
3 files changed, 144 insertions, 0 deletions
diff --git a/Source/ThirdParty/ANGLE/util/linux/LinuxTimer.cpp b/Source/ThirdParty/ANGLE/util/linux/LinuxTimer.cpp
new file mode 100644
index 000000000..196820580
--- /dev/null
+++ b/Source/ThirdParty/ANGLE/util/linux/LinuxTimer.cpp
@@ -0,0 +1,49 @@
+//
+// Copyright (c) 2015 The ANGLE Project Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+//
+
+// LinuxTimer.cpp: Implementation of a high precision timer class on Linux
+
+#include "linux/LinuxTimer.h"
+#include <iostream>
+
+LinuxTimer::LinuxTimer()
+ : mRunning(false)
+{
+}
+
+void LinuxTimer::start()
+{
+ clock_gettime(CLOCK_MONOTONIC, &mStartTime);
+ mRunning = true;
+}
+
+void LinuxTimer::stop()
+{
+ clock_gettime(CLOCK_MONOTONIC, &mStopTime);
+ mRunning = false;
+}
+
+double LinuxTimer::getElapsedTime() const
+{
+ struct timespec endTime;
+ if (mRunning)
+ {
+ clock_gettime(CLOCK_MONOTONIC, &endTime);
+ }
+ else
+ {
+ endTime = mStopTime;
+ }
+
+ double startSeconds = mStartTime.tv_sec + (1.0 / 1000000000) * mStartTime.tv_nsec;
+ double endSeconds = endTime.tv_sec + (1.0 / 1000000000) * endTime.tv_nsec;
+ return endSeconds - startSeconds;
+}
+
+Timer *CreateTimer()
+{
+ return new LinuxTimer();
+}
diff --git a/Source/ThirdParty/ANGLE/util/linux/LinuxTimer.h b/Source/ThirdParty/ANGLE/util/linux/LinuxTimer.h
new file mode 100644
index 000000000..8e68dd842
--- /dev/null
+++ b/Source/ThirdParty/ANGLE/util/linux/LinuxTimer.h
@@ -0,0 +1,31 @@
+//
+// Copyright (c) 2015 The ANGLE Project Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+//
+
+// LinuxTimer.h: Definition of a high precision timer class on Linux
+
+#ifndef UTIL_LINUX_TIMER_H
+#define UTIL_LINUX_TIMER_H
+
+#include <time.h>
+
+#include "Timer.h"
+
+class LinuxTimer : public Timer
+{
+ public:
+ LinuxTimer();
+
+ void start() override;
+ void stop() override;
+ double getElapsedTime() const override;
+
+ private:
+ bool mRunning;
+ struct timespec mStartTime;
+ struct timespec mStopTime;
+};
+
+#endif // UTIL_LINUX_TIMER_H
diff --git a/Source/ThirdParty/ANGLE/util/linux/Linux_system_utils.cpp b/Source/ThirdParty/ANGLE/util/linux/Linux_system_utils.cpp
new file mode 100644
index 000000000..2a57fc079
--- /dev/null
+++ b/Source/ThirdParty/ANGLE/util/linux/Linux_system_utils.cpp
@@ -0,0 +1,64 @@
+//
+// Copyright (c) 2015 The ANGLE Project Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+//
+
+// Linux_system_utils.cpp: Implementation of OS-specific functions for Linux
+
+#include "system_utils.h"
+
+#include <sys/stat.h>
+#include <sys/time.h>
+#include <sys/types.h>
+#include <unistd.h>
+
+namespace angle
+{
+
+namespace
+{
+
+std::string GetExecutablePathImpl()
+{
+ // We cannot use lstat to get the size of /proc/self/exe as it always returns 0
+ // so we just use a big buffer and hope the path fits in it.
+ char path[4096];
+
+ ssize_t result = readlink("/proc/self/exe", path, sizeof(path) - 1);
+ if (result < 0 || static_cast<size_t>(result) >= sizeof(path) - 1)
+ {
+ return "";
+ }
+
+ path[result] = '\0';
+ return path;
+}
+
+std::string GetExecutableDirectoryImpl()
+{
+ std::string executablePath = GetExecutablePath();
+ size_t lastPathSepLoc = executablePath.find_last_of("/");
+ return (lastPathSepLoc != std::string::npos) ? executablePath.substr(0, lastPathSepLoc) : "";
+}
+
+} // anonymous namespace
+
+const char *GetExecutablePath()
+{
+ const static std::string &exePath = GetExecutablePathImpl();
+ return exePath.c_str();
+}
+
+const char *GetExecutableDirectory()
+{
+ const static std::string &exeDir = GetExecutableDirectoryImpl();
+ return exeDir.c_str();
+}
+
+const char *GetSharedLibraryExtension()
+{
+ return "so";
+}
+
+} // namespace angle