1

I am using spdlog for logging in async mode. I want to assign the task of logging to just one cpu core. Is there an API to achieve this in spdlog?

Snakeeye
  • 31
  • 3

1 Answers1

1

For now, I have a workaround to set affinity while creating thread pool in library file threadpool-inl.h

SPDLOG_INLINE thread_pool::thread_pool(size_t q_max_items, size_t threads_n, std::function<void()> on_thread_start)
    : q_(q_max_items)
{
    //printf("number of threads %lu", threads_n);
    if (threads_n == 0 || threads_n > 1000)
    {
        throw_spdlog_ex("spdlog::thread_pool(): invalid threads_n param (valid "
                        "range is 1-1000)");
    }
    for (size_t i = 0; i < threads_n; i++)
    {
        threads_.emplace_back([this, on_thread_start] {
            on_thread_start();
            this->thread_pool::worker_loop_();
        });
        // Create a cpu_set_t object representing a set of CPUs. Clear it and mark only CPU 2 as set.
        cpu_set_t cpuset;
        CPU_ZERO(&cpuset);
        CPU_SET(2, &cpuset);
        int rc = pthread_setaffinity_np(threads_[i].native_handle(), sizeof(cpu_set_t), &cpuset);
        if (rc != 0) {
            printf( "Error calling pthread_setaffinity_np: %d \n", rc);
        }
    }
}
Snakeeye
  • 31
  • 3