2019-06-04 12:14:50 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2015 The WebRTC 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 in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef RTC_BASE_PLATFORM_THREAD_H_
|
|
|
|
#define RTC_BASE_PLATFORM_THREAD_H_
|
|
|
|
|
2021-06-25 02:43:10 +02:00
|
|
|
#include <functional>
|
2019-06-04 12:14:50 +02:00
|
|
|
#include <string>
|
|
|
|
|
2020-08-14 18:58:22 +02:00
|
|
|
#include "absl/strings/string_view.h"
|
2021-06-25 02:43:10 +02:00
|
|
|
#include "absl/types/optional.h"
|
2019-06-04 12:14:50 +02:00
|
|
|
#include "rtc_base/platform_thread_types.h"
|
|
|
|
|
|
|
|
namespace rtc {
|
|
|
|
|
2021-06-25 02:43:10 +02:00
|
|
|
enum class ThreadPriority {
|
|
|
|
kLow = 1,
|
|
|
|
kNormal,
|
|
|
|
kHigh,
|
|
|
|
kRealtime,
|
|
|
|
};
|
2019-06-04 12:14:50 +02:00
|
|
|
|
2021-06-25 02:43:10 +02:00
|
|
|
struct ThreadAttributes {
|
|
|
|
ThreadPriority priority = ThreadPriority::kNormal;
|
|
|
|
ThreadAttributes& SetPriority(ThreadPriority priority_param) {
|
|
|
|
priority = priority_param;
|
|
|
|
return *this;
|
|
|
|
}
|
2019-06-04 12:14:50 +02:00
|
|
|
};
|
|
|
|
|
2021-06-25 02:43:10 +02:00
|
|
|
// Represents a simple worker thread.
|
|
|
|
class PlatformThread final {
|
2019-06-04 12:14:50 +02:00
|
|
|
public:
|
2021-06-25 02:43:10 +02:00
|
|
|
// Handle is the base platform thread handle.
|
|
|
|
#if defined(WEBRTC_WIN)
|
|
|
|
using Handle = HANDLE;
|
|
|
|
#else
|
|
|
|
using Handle = pthread_t;
|
|
|
|
#endif // defined(WEBRTC_WIN)
|
|
|
|
// This ctor creates the PlatformThread with an unset handle (returning true
|
|
|
|
// in empty()) and is provided for convenience.
|
|
|
|
// TODO(bugs.webrtc.org/12727) Look into if default and move support can be
|
|
|
|
// removed.
|
|
|
|
PlatformThread() = default;
|
|
|
|
|
2022-03-11 17:49:54 +01:00
|
|
|
// Moves `rhs` into this, storing an empty state in `rhs`.
|
2021-06-25 02:43:10 +02:00
|
|
|
// TODO(bugs.webrtc.org/12727) Look into if default and move support can be
|
|
|
|
// removed.
|
|
|
|
PlatformThread(PlatformThread&& rhs);
|
|
|
|
|
2023-02-18 22:24:25 +01:00
|
|
|
// Copies won't work since we'd have problems with joinable threads.
|
|
|
|
PlatformThread(const PlatformThread&) = delete;
|
|
|
|
PlatformThread& operator=(const PlatformThread&) = delete;
|
|
|
|
|
2022-03-11 17:49:54 +01:00
|
|
|
// Moves `rhs` into this, storing an empty state in `rhs`.
|
2021-06-25 02:43:10 +02:00
|
|
|
// TODO(bugs.webrtc.org/12727) Look into if default and move support can be
|
|
|
|
// removed.
|
|
|
|
PlatformThread& operator=(PlatformThread&& rhs);
|
|
|
|
|
|
|
|
// For a PlatformThread that's been spawned joinable, the destructor suspends
|
|
|
|
// the calling thread until the created thread exits unless the thread has
|
|
|
|
// already exited.
|
2019-06-04 12:14:50 +02:00
|
|
|
virtual ~PlatformThread();
|
|
|
|
|
2021-06-25 02:43:10 +02:00
|
|
|
// Finalizes any allocated resources.
|
|
|
|
// For a PlatformThread that's been spawned joinable, Finalize() suspends
|
|
|
|
// the calling thread until the created thread exits unless the thread has
|
|
|
|
// already exited.
|
|
|
|
// empty() returns true after completion.
|
|
|
|
void Finalize();
|
|
|
|
|
|
|
|
// Returns true if default constructed, moved from, or Finalize()ed.
|
|
|
|
bool empty() const { return !handle_.has_value(); }
|
|
|
|
|
|
|
|
// Creates a started joinable thread which will be joined when the returned
|
|
|
|
// PlatformThread destructs or Finalize() is called.
|
|
|
|
static PlatformThread SpawnJoinable(
|
|
|
|
std::function<void()> thread_function,
|
|
|
|
absl::string_view name,
|
|
|
|
ThreadAttributes attributes = ThreadAttributes());
|
|
|
|
|
|
|
|
// Creates a started detached thread. The caller has to use external
|
|
|
|
// synchronization as nothing is provided by the PlatformThread construct.
|
|
|
|
static PlatformThread SpawnDetached(
|
|
|
|
std::function<void()> thread_function,
|
|
|
|
absl::string_view name,
|
|
|
|
ThreadAttributes attributes = ThreadAttributes());
|
|
|
|
|
|
|
|
// Returns the base platform thread handle of this thread.
|
|
|
|
absl::optional<Handle> GetHandle() const;
|
2019-06-04 12:14:50 +02:00
|
|
|
|
|
|
|
#if defined(WEBRTC_WIN)
|
2021-06-25 02:43:10 +02:00
|
|
|
// Queue a Windows APC function that runs when the thread is alertable.
|
2019-06-04 12:14:50 +02:00
|
|
|
bool QueueAPC(PAPCFUNC apc_function, ULONG_PTR data);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
private:
|
2021-06-25 02:43:10 +02:00
|
|
|
PlatformThread(Handle handle, bool joinable);
|
|
|
|
static PlatformThread SpawnThread(std::function<void()> thread_function,
|
|
|
|
absl::string_view name,
|
|
|
|
ThreadAttributes attributes,
|
|
|
|
bool joinable);
|
|
|
|
|
|
|
|
absl::optional<Handle> handle_;
|
|
|
|
bool joinable_ = false;
|
2019-06-04 12:14:50 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace rtc
|
|
|
|
|
|
|
|
#endif // RTC_BASE_PLATFORM_THREAD_H_
|