|
|
@ -46,11 +46,16 @@ void threads_print_self();
|
|
|
|
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace srslte {
|
|
|
|
|
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
class thread
|
|
|
|
class thread
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
public:
|
|
|
|
thread(const std::string& name_) : _thread(0), name(name_) {}
|
|
|
|
thread(const std::string& name_) : _thread(0), name(name_) {}
|
|
|
|
|
|
|
|
|
|
|
|
thread(const thread&) = delete;
|
|
|
|
thread(const thread&) = delete;
|
|
|
|
|
|
|
|
|
|
|
|
thread(thread&& other) noexcept
|
|
|
|
thread(thread&& other) noexcept
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_thread = other._thread;
|
|
|
|
_thread = other._thread;
|
|
|
@ -58,21 +63,30 @@ public:
|
|
|
|
other._thread = 0;
|
|
|
|
other._thread = 0;
|
|
|
|
other.name = "";
|
|
|
|
other.name = "";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
thread& operator=(const thread&) = delete;
|
|
|
|
thread& operator=(const thread&) = delete;
|
|
|
|
|
|
|
|
|
|
|
|
thread& operator=(thread&&) noexcept = delete;
|
|
|
|
thread& operator=(thread&&) noexcept = delete;
|
|
|
|
bool start(int prio = -1) { return threads_new_rt_prio(&_thread, thread_function_entry, this, prio); }
|
|
|
|
|
|
|
|
bool start_cpu(int prio, int cpu) { return threads_new_rt_cpu(&_thread, thread_function_entry, this, cpu, prio); }
|
|
|
|
bool start(int prio = -1) { return threads_new_rt_prio(&_thread, thread_function_entry, this, prio); }
|
|
|
|
bool start_cpu_mask(int prio, int mask)
|
|
|
|
|
|
|
|
|
|
|
|
bool start_cpu(int prio, int cpu) { return threads_new_rt_cpu(&_thread, thread_function_entry, this, cpu, prio); }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool start_cpu_mask(int prio, int mask)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return threads_new_rt_mask(&_thread, thread_function_entry, this, mask, prio);
|
|
|
|
return threads_new_rt_mask(&_thread, thread_function_entry, this, mask, prio);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void print_priority() { threads_print_self(); }
|
|
|
|
void print_priority() { threads_print_self(); }
|
|
|
|
|
|
|
|
|
|
|
|
void set_name(const std::string& name_)
|
|
|
|
void set_name(const std::string& name_)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
name = name_;
|
|
|
|
name = name_;
|
|
|
|
pthread_setname_np(pthread_self(), name.c_str());
|
|
|
|
pthread_setname_np(pthread_self(), name.c_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void wait_thread_finish() { pthread_join(_thread, NULL); }
|
|
|
|
void wait_thread_finish() { pthread_join(_thread, NULL); }
|
|
|
|
|
|
|
|
|
|
|
|
void thread_cancel() { pthread_cancel(_thread); }
|
|
|
|
void thread_cancel() { pthread_cancel(_thread); }
|
|
|
|
|
|
|
|
|
|
|
|
static std::string get_name()
|
|
|
|
static std::string get_name()
|
|
|
@ -96,6 +110,7 @@ private:
|
|
|
|
((thread*)_this)->run_thread();
|
|
|
|
((thread*)_this)->run_thread();
|
|
|
|
return NULL;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pthread_t _thread;
|
|
|
|
pthread_t _thread;
|
|
|
|
std::string name;
|
|
|
|
std::string name;
|
|
|
|
};
|
|
|
|
};
|
|
|
@ -104,12 +119,14 @@ class periodic_thread : public thread
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
public:
|
|
|
|
periodic_thread(const std::string name_) : thread(name_) {}
|
|
|
|
periodic_thread(const std::string name_) : thread(name_) {}
|
|
|
|
|
|
|
|
|
|
|
|
void start_periodic(int period_us_, int priority = -1)
|
|
|
|
void start_periodic(int period_us_, int priority = -1)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
run_enable = true;
|
|
|
|
run_enable = true;
|
|
|
|
period_us = period_us_;
|
|
|
|
period_us = period_us_;
|
|
|
|
start(priority);
|
|
|
|
start(priority);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void stop_thread()
|
|
|
|
void stop_thread()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
run_enable = false;
|
|
|
|
run_enable = false;
|
|
|
@ -124,6 +141,7 @@ private:
|
|
|
|
int timer_fd;
|
|
|
|
int timer_fd;
|
|
|
|
int period_us;
|
|
|
|
int period_us;
|
|
|
|
bool run_enable;
|
|
|
|
bool run_enable;
|
|
|
|
|
|
|
|
|
|
|
|
void run_thread()
|
|
|
|
void run_thread()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (make_periodic()) {
|
|
|
|
if (make_periodic()) {
|
|
|
@ -136,6 +154,7 @@ private:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int make_periodic()
|
|
|
|
int make_periodic()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int ret = -1;
|
|
|
|
int ret = -1;
|
|
|
@ -164,6 +183,7 @@ private:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void wait_period()
|
|
|
|
void wait_period()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
unsigned long long missed;
|
|
|
|
unsigned long long missed;
|
|
|
@ -184,6 +204,8 @@ private:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace srslte
|
|
|
|
|
|
|
|
|
|
|
|
#endif // __cplusplus
|
|
|
|
#endif // __cplusplus
|
|
|
|
|
|
|
|
|
|
|
|
#endif // SRSLTE_THREADS_H
|
|
|
|
#endif // SRSLTE_THREADS_H
|
|
|
|