Unerwartete zusätzliche Latenz erhöht sich, wenn sekundärer Thread aktiviert istC++

Programme in C++. Entwicklerforum
Anonymous
 Unerwartete zusätzliche Latenz erhöht sich, wenn sekundärer Thread aktiviert ist

Post by Anonymous »

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

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post