You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
2.2 KiB
76 lines
2.2 KiB
/*
|
|
* Copyright 2019 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <mutex>
|
|
#include <string>
|
|
#include <thread>
|
|
|
|
#include "os/reactor.h"
|
|
#include "os/utils.h"
|
|
|
|
namespace bluetooth {
|
|
namespace os {
|
|
|
|
// Reactor-based looper thread implementation. The thread runs immediately after it is constructed, and stops after
|
|
// Stop() is invoked. To assign task to this thread, user needs to register a reactable object to the underlying
|
|
// reactor.
|
|
class Thread {
|
|
public:
|
|
// Used by thread constructor. Suggest the priority to the kernel scheduler. Use REAL_TIME if we need (soft) real-time
|
|
// scheduling guarantee for this thread; use NORMAL if no real-time guarantee is needed to save CPU time slice for
|
|
// other threads
|
|
enum class Priority {
|
|
REAL_TIME,
|
|
NORMAL,
|
|
};
|
|
|
|
// name: thread name for POSIX systems
|
|
// priority: priority for kernel scheduler
|
|
Thread(const std::string& name, Priority priority);
|
|
|
|
// Stop and destroy this thread
|
|
~Thread();
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(Thread);
|
|
|
|
// Stop this thread. Must be invoked from another thread. After this thread is stopped, it cannot be started again.
|
|
bool Stop();
|
|
|
|
// Return true if this function is invoked from this thread
|
|
bool IsSameThread() const;
|
|
|
|
// Return the POSIX thread name
|
|
std::string GetThreadName() const;
|
|
|
|
// Return a user-friendly string representation of this thread object
|
|
std::string ToString() const;
|
|
|
|
// Return the pointer of underlying reactor. The ownership is NOT transferred.
|
|
Reactor* GetReactor() const;
|
|
|
|
private:
|
|
void run(Priority priority);
|
|
mutable std::mutex mutex_;
|
|
const std::string name_;
|
|
mutable Reactor reactor_;
|
|
std::thread running_thread_;
|
|
};
|
|
|
|
} // namespace os
|
|
} // namespace bluetooth
|