Explicitly init some std::atomic.
GitOrigin-RevId: bfbe95bd1aaed9c3ade31d9a7222b223bfece347
This commit is contained in:
parent
0ac8c2d389
commit
2edc069583
@ -110,7 +110,7 @@ BENCH(TdRandFast, "td_rand_fast") {
|
|||||||
#if !TD_THREAD_UNSUPPORTED
|
#if !TD_THREAD_UNSUPPORTED
|
||||||
BENCH(SslRand, "ssl_rand_int32") {
|
BENCH(SslRand, "ssl_rand_int32") {
|
||||||
std::vector<td::thread> v;
|
std::vector<td::thread> v;
|
||||||
std::atomic<td::uint32> sum;
|
std::atomic<td::uint32> sum{0};
|
||||||
for (int i = 0; i < 3; i++) {
|
for (int i = 0; i < 3; i++) {
|
||||||
v.push_back(td::thread([&] {
|
v.push_back(td::thread([&] {
|
||||||
td::int32 res = 0;
|
td::int32 res = 0;
|
||||||
|
@ -28,12 +28,6 @@
|
|||||||
#include <sys/eventfd.h>
|
#include <sys/eventfd.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
using std::atomic;
|
|
||||||
using std::vector;
|
|
||||||
|
|
||||||
using td::int32;
|
|
||||||
using td::uint32;
|
|
||||||
|
|
||||||
#define MODE std::memory_order_relaxed
|
#define MODE std::memory_order_relaxed
|
||||||
|
|
||||||
// void set_affinity(int mask) {
|
// void set_affinity(int mask) {
|
||||||
@ -100,7 +94,7 @@ class Backoff {
|
|||||||
};
|
};
|
||||||
|
|
||||||
class VarQueue {
|
class VarQueue {
|
||||||
atomic<qvalue_t> data;
|
std::atomic<qvalue_t> data{0};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void init() {
|
void init() {
|
||||||
@ -218,17 +212,17 @@ const int queue_buf_size = 1 << 10;
|
|||||||
class BufferQueue {
|
class BufferQueue {
|
||||||
struct node {
|
struct node {
|
||||||
qvalue_t val;
|
qvalue_t val;
|
||||||
char pad[64 - sizeof(atomic<qvalue_t>)];
|
char pad[64 - sizeof(std::atomic<qvalue_t>)];
|
||||||
};
|
};
|
||||||
node q[queue_buf_size];
|
node q[queue_buf_size];
|
||||||
|
|
||||||
struct Position {
|
struct Position {
|
||||||
atomic<uint32> i;
|
std::atomic<td::uint32> i{0};
|
||||||
char pad[64 - sizeof(atomic<uint32>)];
|
char pad[64 - sizeof(std::atomic<td::uint32>)];
|
||||||
|
|
||||||
uint32 local_read_i;
|
td::uint32 local_read_i;
|
||||||
uint32 local_write_i;
|
td::uint32 local_write_i;
|
||||||
char pad2[64 - sizeof(uint32) * 2];
|
char pad2[64 - sizeof(td::uint32) * 2];
|
||||||
|
|
||||||
void init() {
|
void init() {
|
||||||
i = 0;
|
i = 0;
|
||||||
@ -342,7 +336,7 @@ class BufferQueue {
|
|||||||
#if TD_LINUX
|
#if TD_LINUX
|
||||||
class BufferedFdQueue {
|
class BufferedFdQueue {
|
||||||
int fd;
|
int fd;
|
||||||
atomic<int> wait_flag;
|
std::atomic<int> wait_flag{0};
|
||||||
BufferQueue q;
|
BufferQueue q;
|
||||||
char pad[64];
|
char pad[64];
|
||||||
|
|
||||||
@ -440,7 +434,7 @@ class BufferedFdQueue {
|
|||||||
|
|
||||||
class FdQueue {
|
class FdQueue {
|
||||||
int fd;
|
int fd;
|
||||||
atomic<int> wait_flag;
|
std::atomic<int> wait_flag{0};
|
||||||
VarQueue q;
|
VarQueue q;
|
||||||
char pad[64];
|
char pad[64];
|
||||||
|
|
||||||
@ -572,8 +566,8 @@ class QueueBenchmark2 : public td::Benchmark {
|
|||||||
|
|
||||||
int server_active_connections;
|
int server_active_connections;
|
||||||
int client_active_connections;
|
int client_active_connections;
|
||||||
vector<td::int64> server_conn;
|
std::vector<td::int64> server_conn;
|
||||||
vector<td::int64> client_conn;
|
std::vector<td::int64> client_conn;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit QueueBenchmark2(int connections_n = 1) : connections_n(connections_n) {
|
explicit QueueBenchmark2(int connections_n = 1) : connections_n(connections_n) {
|
||||||
@ -615,7 +609,7 @@ class QueueBenchmark2 : public td::Benchmark {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void *server_run(void *) {
|
void *server_run(void *) {
|
||||||
server_conn = vector<td::int64>(connections_n);
|
server_conn = std::vector<td::int64>(connections_n);
|
||||||
server_active_connections = connections_n;
|
server_active_connections = connections_n;
|
||||||
|
|
||||||
while (server_active_connections > 0) {
|
while (server_active_connections > 0) {
|
||||||
@ -656,7 +650,7 @@ class QueueBenchmark2 : public td::Benchmark {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void *client_run(void *) {
|
void *client_run(void *) {
|
||||||
client_conn = vector<td::int64>(connections_n);
|
client_conn = std::vector<td::int64>(connections_n);
|
||||||
client_active_connections = connections_n;
|
client_active_connections = connections_n;
|
||||||
if (queries_n >= (1 << 24)) {
|
if (queries_n >= (1 << 24)) {
|
||||||
std::fprintf(stderr, "Too big queries_n\n");
|
std::fprintf(stderr, "Too big queries_n\n");
|
||||||
@ -732,7 +726,7 @@ class QueueBenchmark : public td::Benchmark {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void *server_run(void *) {
|
void *server_run(void *) {
|
||||||
vector<td::int64> conn(connections_n);
|
std::vector<td::int64> conn(connections_n);
|
||||||
int active_connections = connections_n;
|
int active_connections = connections_n;
|
||||||
while (active_connections > 0) {
|
while (active_connections > 0) {
|
||||||
qvalue_t value = server.get();
|
qvalue_t value = server.get();
|
||||||
@ -756,7 +750,7 @@ class QueueBenchmark : public td::Benchmark {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void *client_run(void *) {
|
void *client_run(void *) {
|
||||||
vector<td::int64> conn(connections_n);
|
std::vector<td::int64> conn(connections_n);
|
||||||
if (queries_n >= (1 << 24)) {
|
if (queries_n >= (1 << 24)) {
|
||||||
std::fprintf(stderr, "Too big queries_n\n");
|
std::fprintf(stderr, "Too big queries_n\n");
|
||||||
std::exit(0);
|
std::exit(0);
|
||||||
@ -789,7 +783,7 @@ class QueueBenchmark : public td::Benchmark {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void *client_run2(void *) {
|
void *client_run2(void *) {
|
||||||
vector<td::int64> conn(connections_n);
|
std::vector<td::int64> conn(connections_n);
|
||||||
if (queries_n >= (1 << 24)) {
|
if (queries_n >= (1 << 24)) {
|
||||||
std::fprintf(stderr, "Too big queries_n\n");
|
std::fprintf(stderr, "Too big queries_n\n");
|
||||||
std::exit(0);
|
std::exit(0);
|
||||||
|
@ -72,7 +72,8 @@ static int fast_backtrace(void **buffer, int size) {
|
|||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::atomic<std::size_t> fast_backtrace_failed_cnt, backtrace_total_cnt;
|
static std::atomic<std::size_t> fast_backtrace_failed_cnt;
|
||||||
|
static std::atomic<std::size_t> backtrace_total_cnt;
|
||||||
double get_fast_backtrace_success_rate() {
|
double get_fast_backtrace_success_rate() {
|
||||||
return 1 - static_cast<double>(fast_backtrace_failed_cnt.load(std::memory_order_relaxed)) /
|
return 1 - static_cast<double>(fast_backtrace_failed_cnt.load(std::memory_order_relaxed)) /
|
||||||
static_cast<double>(std::max(std::size_t(1), backtrace_total_cnt.load(std::memory_order_relaxed)));
|
static_cast<double>(std::max(std::size_t(1), backtrace_total_cnt.load(std::memory_order_relaxed)));
|
||||||
|
@ -378,8 +378,8 @@ class Global : public ActorContext {
|
|||||||
int32 gc_scheduler_id_;
|
int32 gc_scheduler_id_;
|
||||||
int32 slow_net_scheduler_id_;
|
int32 slow_net_scheduler_id_;
|
||||||
|
|
||||||
std::atomic<double> server_time_difference_;
|
std::atomic<double> server_time_difference_{0.0};
|
||||||
std::atomic<bool> server_time_difference_was_updated_;
|
std::atomic<bool> server_time_difference_was_updated_{false};
|
||||||
std::atomic<bool> close_flag_{false};
|
std::atomic<bool> close_flag_{false};
|
||||||
|
|
||||||
std::vector<std::shared_ptr<NetStatsCallback>> net_stats_file_callbacks_;
|
std::vector<std::shared_ptr<NetStatsCallback>> net_stats_file_callbacks_;
|
||||||
|
@ -86,7 +86,7 @@ class ConcurrentScheduler : private Scheduler::Callback {
|
|||||||
enum class State { Start, Run };
|
enum class State { Start, Run };
|
||||||
State state_ = State::Start;
|
State state_ = State::Start;
|
||||||
std::vector<unique_ptr<Scheduler>> schedulers_;
|
std::vector<unique_ptr<Scheduler>> schedulers_;
|
||||||
std::atomic<bool> is_finished_;
|
std::atomic<bool> is_finished_{false};
|
||||||
std::mutex at_finish_mutex_;
|
std::mutex at_finish_mutex_;
|
||||||
std::vector<std::function<void()>> at_finish_;
|
std::vector<std::function<void()>> at_finish_;
|
||||||
#if !TD_THREAD_UNSUPPORTED && !TD_EVENTFD_UNSUPPORTED
|
#if !TD_THREAD_UNSUPPORTED && !TD_EVENTFD_UNSUPPORTED
|
||||||
|
@ -63,7 +63,7 @@ class ConcurrentBinlog : public BinlogInterface {
|
|||||||
|
|
||||||
ActorOwn<detail::BinlogActor> binlog_actor_;
|
ActorOwn<detail::BinlogActor> binlog_actor_;
|
||||||
string path_;
|
string path_;
|
||||||
std::atomic<uint64> last_id_;
|
std::atomic<uint64> last_id_{0};
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace td
|
} // namespace td
|
||||||
|
@ -20,7 +20,7 @@ class HazardPointers {
|
|||||||
explicit HazardPointers(size_t threads_n) : threads_(threads_n) {
|
explicit HazardPointers(size_t threads_n) : threads_(threads_n) {
|
||||||
for (auto &data : threads_) {
|
for (auto &data : threads_) {
|
||||||
for (auto &ptr : data.hazard) {
|
for (auto &ptr : data.hazard) {
|
||||||
ptr = nullptr;
|
std::atomic_init(&ptr, nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -77,7 +77,7 @@ class MemoryLog : public LogInterface {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
char buffer_[buffer_size];
|
char buffer_[buffer_size];
|
||||||
std::atomic<uint32> pos_;
|
std::atomic<uint32> pos_{0};
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace td
|
} // namespace td
|
||||||
|
@ -306,9 +306,9 @@ class MpmcQueueOld {
|
|||||||
MpmcQueueBlock<T> block;
|
MpmcQueueBlock<T> block;
|
||||||
//Got pad in MpmcQueueBlock
|
//Got pad in MpmcQueueBlock
|
||||||
};
|
};
|
||||||
std::atomic<Node *> write_pos_;
|
std::atomic<Node *> write_pos_{nullptr};
|
||||||
char pad[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
char pad[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
||||||
std::atomic<Node *> read_pos_;
|
std::atomic<Node *> read_pos_{nullptr};
|
||||||
char pad2[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
char pad2[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
||||||
size_t block_size_;
|
size_t block_size_;
|
||||||
HazardPointers<Node, 1> hazard_pointers_;
|
HazardPointers<Node, 1> hazard_pointers_;
|
||||||
@ -438,9 +438,9 @@ class MpmcQueue {
|
|||||||
char pad[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
char pad[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
||||||
//Got pad in MpmcQueueBlock
|
//Got pad in MpmcQueueBlock
|
||||||
};
|
};
|
||||||
std::atomic<Node *> write_pos_;
|
std::atomic<Node *> write_pos_{nullptr};
|
||||||
char pad[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
char pad[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
||||||
std::atomic<Node *> read_pos_;
|
std::atomic<Node *> read_pos_{nullptr};
|
||||||
char pad2[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
char pad2[TD_CONCURRENCY_PAD - sizeof(std::atomic<Node *>)];
|
||||||
HazardPointers<Node, 1> hazard_pointers_;
|
HazardPointers<Node, 1> hazard_pointers_;
|
||||||
//Got pad in HazardPointers
|
//Got pad in HazardPointers
|
||||||
|
@ -34,7 +34,7 @@ class AtomicRefCnt {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::atomic<uint64> cnt_;
|
std::atomic<uint64> cnt_{0};
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class DataT, class DeleterT>
|
template <class DataT, class DeleterT>
|
||||||
|
@ -103,13 +103,14 @@ BufferRaw *BufferAllocator::create_buffer_raw(size_t size) {
|
|||||||
new (buffer_raw) BufferRaw();
|
new (buffer_raw) BufferRaw();
|
||||||
buffer_raw->data_size_ = size;
|
buffer_raw->data_size_ = size;
|
||||||
buffer_raw->begin_ = 0;
|
buffer_raw->begin_ = 0;
|
||||||
buffer_raw->end_ = 0;
|
std::atomic_init(&buffer_raw->end_, 0);
|
||||||
|
|
||||||
buffer_raw->ref_cnt_.store(1, std::memory_order_relaxed);
|
std::atomic_init(&buffer_raw->ref_cnt_, 1);
|
||||||
buffer_raw->has_writer_.store(true, std::memory_order_relaxed);
|
std::atomic_init(&buffer_raw->has_writer_, true);
|
||||||
buffer_raw->was_reader_ = false;
|
buffer_raw->was_reader_ = false;
|
||||||
return buffer_raw;
|
return buffer_raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
void BufferBuilder::append(BufferSlice slice) {
|
void BufferBuilder::append(BufferSlice slice) {
|
||||||
if (append_inplace(slice.as_slice())) {
|
if (append_inplace(slice.as_slice())) {
|
||||||
return;
|
return;
|
||||||
|
@ -67,7 +67,7 @@ class SPSCBlockQueue {
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct Position {
|
struct Position {
|
||||||
std::atomic<uint32> i;
|
std::atomic<uint32> i{0};
|
||||||
char pad[64 - sizeof(std::atomic<uint32>)];
|
char pad[64 - sizeof(std::atomic<uint32>)];
|
||||||
uint32 local_writer_i;
|
uint32 local_writer_i;
|
||||||
char pad2[64 - sizeof(uint32)];
|
char pad2[64 - sizeof(uint32)];
|
||||||
@ -252,7 +252,7 @@ class SPSCChainQueue {
|
|||||||
private:
|
private:
|
||||||
struct Node {
|
struct Node {
|
||||||
BlockQueueT q_;
|
BlockQueueT q_;
|
||||||
std::atomic<bool> is_closed_;
|
std::atomic<bool> is_closed_{false};
|
||||||
Node *next_;
|
Node *next_;
|
||||||
|
|
||||||
void init() {
|
void init() {
|
||||||
@ -399,7 +399,7 @@ class PollQueue : public QueueT {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
EventFd event_fd_;
|
EventFd event_fd_;
|
||||||
std::atomic<int> wait_state_;
|
std::atomic<int> wait_state_{0};
|
||||||
int writer_wait_state_;
|
int writer_wait_state_;
|
||||||
|
|
||||||
int get_wait_state() {
|
int get_wait_state() {
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
#if !TD_THREAD_UNSUPPORTED
|
#if !TD_THREAD_UNSUPPORTED
|
||||||
TEST(HazardPointers, stress) {
|
TEST(HazardPointers, stress) {
|
||||||
struct Node {
|
struct Node {
|
||||||
std::atomic<std::string *> name_;
|
std::atomic<std::string *> name_{nullptr};
|
||||||
char pad[64];
|
char pad[64];
|
||||||
};
|
};
|
||||||
int threads_n = 10;
|
int threads_n = 10;
|
||||||
|
@ -18,7 +18,7 @@ TEST(MpmcWaiter, stress_one_one) {
|
|||||||
td::Stage check;
|
td::Stage check;
|
||||||
|
|
||||||
std::vector<td::thread> threads;
|
std::vector<td::thread> threads;
|
||||||
std::atomic<size_t> value;
|
std::atomic<size_t> value{0};
|
||||||
size_t write_cnt = 10;
|
size_t write_cnt = 10;
|
||||||
td::unique_ptr<td::MpmcWaiter> waiter;
|
td::unique_ptr<td::MpmcWaiter> waiter;
|
||||||
size_t threads_n = 2;
|
size_t threads_n = 2;
|
||||||
@ -64,8 +64,8 @@ TEST(MpmcWaiter, stress) {
|
|||||||
std::vector<td::thread> threads;
|
std::vector<td::thread> threads;
|
||||||
size_t write_n;
|
size_t write_n;
|
||||||
size_t read_n;
|
size_t read_n;
|
||||||
std::atomic<size_t> write_pos;
|
std::atomic<size_t> write_pos{0};
|
||||||
std::atomic<size_t> read_pos;
|
std::atomic<size_t> read_pos{0};
|
||||||
size_t end_pos;
|
size_t end_pos;
|
||||||
size_t write_cnt;
|
size_t write_cnt;
|
||||||
size_t threads_n = 20;
|
size_t threads_n = 20;
|
||||||
|
@ -96,7 +96,7 @@ TEST(Misc, errno_tls_bug) {
|
|||||||
#if !TD_THREAD_UNSUPPORTED && !TD_EVENTFD_UNSUPPORTED
|
#if !TD_THREAD_UNSUPPORTED && !TD_EVENTFD_UNSUPPORTED
|
||||||
EventFd test_event_fd;
|
EventFd test_event_fd;
|
||||||
test_event_fd.init();
|
test_event_fd.init();
|
||||||
std::atomic<int> s(0);
|
std::atomic<int> s{0};
|
||||||
s = 1;
|
s = 1;
|
||||||
td::thread th([&] {
|
td::thread th([&] {
|
||||||
while (s != 1) {
|
while (s != 1) {
|
||||||
|
Reference in New Issue
Block a user