Ich finde die Cache-Latenz, einen gespeicherten Wert erneut zu lesen, nachdem ein sekundärer Thread darauf zugegriffen hat. Wenn der sekundäre Thread deaktiviert ist (start_thread = 0), sehe ich eine durchschnittliche Latenz von 25 ns. Wenn der Thread jedoch aktiviert ist (start_thread = 1), steigt die Latenz auf 46 ns, eine zusätzliche 20 ns.#include
#include
#include
#include
#include
#include
#include
std::atomic shared_value{0};
char padding[64];
std::atomic ready{false}; // Synchronization flag
std::atomic stop_thread{false}; // Termination flag
void set_thread_affinity(int core_id) {
cpu_set_t cpuset;
CPU_ZERO(&cpuset);
CPU_SET(core_id, &cpuset);
pthread_setaffinity_np(pthread_self(), sizeof(cpu_set_t), &cpuset);
}
void reader_thread() {
set_thread_affinity(2); // Pin reader to core 2
while (!stop_thread.load(std::memory_order_relaxed)) {
while (!ready.load(std::memory_order_acquire) && !stop_thread.load(std::memory_order_relaxed)) {
_mm_pause(); // Reduce contention
}
if (stop_thread.load(std::memory_order_relaxed)) break;
int local_value = shared_value.load(std::memory_order_acquire);
(void)local_value; // Prevent compiler optimizations
ready.store(false, std::memory_order_release);
}
}
int main(int argc, char *argv[]) {
if (argc != 3) {
std::cerr
Unerwartete zusätzliche Latenz erhöht sich, wenn sekundärer Thread aktiviert ist ⇐ C++
-
- Similar Topics
- Replies
- Views
- Last post
-
-
Unerwartete zusätzliche Latenz erhöht sich, wenn sekundärer Thread aktiviert ist
by Anonymous » » in C++ - 0 Replies
- 6 Views
-
Last post by Anonymous
-