diff options
author | Manjunath Kudlur <keveman@gmail.com> | 2015-11-06 16:27:58 -0800 |
---|---|---|
committer | Manjunath Kudlur <keveman@gmail.com> | 2015-11-06 16:27:58 -0800 |
commit | f41959ccb2d9d4c722fe8fc3351401d53bcf4900 (patch) | |
tree | ef0ca22cb2a5ac4bdec9d080d8e0788a53ed496d /tensorflow/stream_executor/platform |
TensorFlow: Initial commit of TensorFlow library.
TensorFlow is an open source software library for numerical computation
using data flow graphs.
Base CL: 107276108
Diffstat (limited to 'tensorflow/stream_executor/platform')
-rw-r--r-- | tensorflow/stream_executor/platform/default/mutex.h | 60 | ||||
-rw-r--r-- | tensorflow/stream_executor/platform/logging.h | 21 | ||||
-rw-r--r-- | tensorflow/stream_executor/platform/mutex.h | 12 | ||||
-rw-r--r-- | tensorflow/stream_executor/platform/port.h | 40 | ||||
-rw-r--r-- | tensorflow/stream_executor/platform/thread_annotations.h | 6 |
5 files changed, 139 insertions, 0 deletions
diff --git a/tensorflow/stream_executor/platform/default/mutex.h b/tensorflow/stream_executor/platform/default/mutex.h new file mode 100644 index 0000000000..371eb7f156 --- /dev/null +++ b/tensorflow/stream_executor/platform/default/mutex.h @@ -0,0 +1,60 @@ +#ifndef TENSORFLOW_STREAM_EXECUTOR_PLATFORM_DEFAULT_MUTEX_H_ +#define TENSORFLOW_STREAM_EXECUTOR_PLATFORM_DEFAULT_MUTEX_H_ + +#include <chrono> // NOLINT +#include <condition_variable> // NOLINT + +#include "tensorflow/stream_executor/platform/port.h" + +// std::shared_timed_mutex is a C++14 feature. +#if (__cplusplus >= 201402L) +#define STREAM_EXECUTOR_USE_SHARED_MUTEX +#endif // __cplusplus >= 201402L + +#ifdef STREAM_EXECUTOR_USE_SHARED_MUTEX +#include <shared_mutex> // NOLINT +#else +#include <mutex> // NOLINT +#endif + +namespace perftools { +namespace gputools { + +enum ConditionResult { kCond_Timeout, kCond_MaybeNotified }; + +#ifdef STREAM_EXECUTOR_USE_SHARED_MUTEX +typedef std::shared_timed_mutex BaseMutex; +#else +typedef std::mutex BaseMutex; +#endif + +// A class that wraps around the std::mutex implementation, only adding an +// additional LinkerInitialized constructor interface. +class mutex : public BaseMutex { + public: + mutex() {} + // The default implementation of std::mutex is safe to use after the linker + // initializations + explicit mutex(LinkerInitialized x) {} +}; + +typedef std::unique_lock<BaseMutex> mutex_lock; + +#ifdef STREAM_EXECUTOR_USE_SHARED_MUTEX +typedef std::shared_lock<BaseMutex> shared_lock; +#else +typedef std::unique_lock<BaseMutex> shared_lock; +#endif + +using std::condition_variable; + +inline ConditionResult WaitForMilliseconds(mutex_lock* mu, + condition_variable* cv, int64 ms) { + std::cv_status s = cv->wait_for(*mu, std::chrono::milliseconds(ms)); + return (s == std::cv_status::timeout) ? kCond_Timeout : kCond_MaybeNotified; +} + +} // namespace gputools +} // namespace perftools + +#endif // TENSORFLOW_STREAM_EXECUTOR_PLATFORM_DEFAULT_MUTEX_H_ diff --git a/tensorflow/stream_executor/platform/logging.h b/tensorflow/stream_executor/platform/logging.h new file mode 100644 index 0000000000..a3e2385dd3 --- /dev/null +++ b/tensorflow/stream_executor/platform/logging.h @@ -0,0 +1,21 @@ +#ifndef TENSORFLOW_STREAM_EXECUTOR_PLATFORM_LOGGING_H_ +#define TENSORFLOW_STREAM_EXECUTOR_PLATFORM_LOGGING_H_ + +#include "tensorflow/core/platform/logging.h" +#include "tensorflow/stream_executor/platform/port.h" + +#if !defined(PLATFORM_GOOGLE) + +// A CHECK() macro that lets you assert the success of a function that +// returns -1 and sets errno in case of an error. E.g. +// +// CHECK_ERR(mkdir(path, 0700)); +// +// or +// +// int fd = open(filename, flags); CHECK_ERR(fd) << ": open " << filename; +#define CHECK_ERR(invocation) CHECK((invocation) != -1) << #invocation + +#endif + +#endif // TENSORFLOW_STREAM_EXECUTOR_PLATFORM_LOGGING_H_ diff --git a/tensorflow/stream_executor/platform/mutex.h b/tensorflow/stream_executor/platform/mutex.h new file mode 100644 index 0000000000..21b1894737 --- /dev/null +++ b/tensorflow/stream_executor/platform/mutex.h @@ -0,0 +1,12 @@ +#ifndef TENSORFLOW_STREAM_EXECUTOR_PLATFORM_MUTEX_H_ +#define TENSORFLOW_STREAM_EXECUTOR_PLATFORM_MUTEX_H_ + +#include "tensorflow/core/platform/port.h" + +#if defined(PLATFORM_GOOGLE) +#include "tensorflow/stream_executor/platform/google/mutex.h" +#else +#include "tensorflow/stream_executor/platform/default/mutex.h" +#endif + +#endif // TENSORFLOW_STREAM_EXECUTOR_PLATFORM_MUTEX_H_ diff --git a/tensorflow/stream_executor/platform/port.h b/tensorflow/stream_executor/platform/port.h new file mode 100644 index 0000000000..ebe0cf517b --- /dev/null +++ b/tensorflow/stream_executor/platform/port.h @@ -0,0 +1,40 @@ +#ifndef TENSORFLOW_STREAM_EXECUTOR_PLATFORM_PORT_H_ +#define TENSORFLOW_STREAM_EXECUTOR_PLATFORM_PORT_H_ + +#include "tensorflow/core/platform/port.h" + +namespace perftools { +namespace gputools { + +using tensorflow::int8; +using tensorflow::int16; +using tensorflow::int32; +using tensorflow::int64; + +using tensorflow::uint8; +using tensorflow::uint16; +using tensorflow::uint32; +using tensorflow::uint64; + +#if !defined(PLATFORM_GOOGLE) +using std::string; +#endif + +#if !defined(COMPILER_MSVC) +#define ARRAYSIZE(a) \ + ((sizeof(a) / sizeof(*(a))) / \ + static_cast<size_t>(!(sizeof(a) % sizeof(*(a))))) +#endif + +using tensorflow::LinkerInitialized; +using tensorflow::LINKER_INITIALIZED; + +#define SE_FALLTHROUGH_INTENDED TF_FALLTHROUGH_INTENDED + +} // namespace gputools +} // namespace perftools + +#define SE_DISALLOW_COPY_AND_ASSIGN TF_DISALLOW_COPY_AND_ASSIGN +#define SE_MUST_USE_RESULT TF_MUST_USE_RESULT + +#endif // TENSORFLOW_STREAM_EXECUTOR_PLATFORM_PORT_H_ diff --git a/tensorflow/stream_executor/platform/thread_annotations.h b/tensorflow/stream_executor/platform/thread_annotations.h new file mode 100644 index 0000000000..bce4bb3794 --- /dev/null +++ b/tensorflow/stream_executor/platform/thread_annotations.h @@ -0,0 +1,6 @@ +#ifndef TENSORFLOW_STREAM_EXECUTOR_PLATFORM_THREAD_ANNOTATIONS_H_ +#define TENSORFLOW_STREAM_EXECUTOR_PLATFORM_THREAD_ANNOTATIONS_H_ + +#include "tensorflow/core/platform/thread_annotations.h" + +#endif // TENSORFLOW_STREAM_EXECUTOR_PLATFORM_THREAD_ANNOTATIONS_H_ |