[threads] Add a condition_variable to test for all threads to be ready
This commit is contained in:
parent
4d42a94c19
commit
e8a2436332
|
@ -1,5 +1,6 @@
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
|
#include <condition_variable>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
|
@ -59,6 +60,11 @@ unsigned num_tests = sizeof (default_tests) / sizeof (default_tests[0]);
|
||||||
|
|
||||||
enum backend_t { HARFBUZZ, FREETYPE };
|
enum backend_t { HARFBUZZ, FREETYPE };
|
||||||
|
|
||||||
|
// https://en.cppreference.com/w/cpp/thread/condition_variable/wait
|
||||||
|
std::condition_variable cv;
|
||||||
|
std::mutex cv_m;
|
||||||
|
static bool ready = false;
|
||||||
|
|
||||||
static unsigned num_repetitions = 4;
|
static unsigned num_repetitions = 4;
|
||||||
static unsigned num_threads = 4;
|
static unsigned num_threads = 4;
|
||||||
|
|
||||||
|
@ -66,6 +72,12 @@ static void shape (bool is_var,
|
||||||
backend_t backend,
|
backend_t backend,
|
||||||
const test_input_t &input)
|
const test_input_t &input)
|
||||||
{
|
{
|
||||||
|
// Wait till all threads are ready.
|
||||||
|
{
|
||||||
|
std::unique_lock<std::mutex> lk (cv_m);
|
||||||
|
cv.wait(lk, [] {return ready;});
|
||||||
|
}
|
||||||
|
|
||||||
hb_font_t *font;
|
hb_font_t *font;
|
||||||
{
|
{
|
||||||
hb_blob_t *blob = hb_blob_create_from_file_or_fail (input.font_path);
|
hb_blob_t *blob = hb_blob_create_from_file_or_fail (input.font_path);
|
||||||
|
@ -148,6 +160,9 @@ static void test_backend (backend_t backend,
|
||||||
for (unsigned i = 0; i < num_threads; i++)
|
for (unsigned i = 0; i < num_threads; i++)
|
||||||
threads.push_back (std::thread (shape, variable, backend, test_input));
|
threads.push_back (std::thread (shape, variable, backend, test_input));
|
||||||
|
|
||||||
|
ready = true;
|
||||||
|
cv.notify_all();
|
||||||
|
|
||||||
for (unsigned i = 0; i < num_threads; i++)
|
for (unsigned i = 0; i < num_threads; i++)
|
||||||
threads[i].join ();
|
threads[i].join ();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue