diff --git a/libavcodec/pthread.c b/libavcodec/pthread.c
index 2433880323a94b1392e51fc5b7a4d181b30e8c29..259dab0d8c309134d71be058d7771d9397adead8 100644
--- a/libavcodec/pthread.c
+++ b/libavcodec/pthread.c
@@ -790,7 +790,6 @@ static int frame_thread_init(AVCodecContext *avctx)
         int nb_cpus = av_cpu_count();
         if ((avctx->debug & (FF_DEBUG_VIS_QP | FF_DEBUG_VIS_MB_TYPE)) || avctx->debug_mv)
             nb_cpus = 1;
-        av_log(avctx, AV_LOG_DEBUG, "detected %d logical cores\n", nb_cpus);
         // use number of cores + 1 as thread count if there is more than one
         if (nb_cpus > 1)
             thread_count = avctx->thread_count = FFMIN(nb_cpus + 1, MAX_AUTO_THREADS);
diff --git a/libavfilter/pthread.c b/libavfilter/pthread.c
index 6ceb8e65e32823a0be1e7c7ce2543264a7636db6..0630ad2f501b352b0ad48edc2c368db05e5d056e 100644
--- a/libavfilter/pthread.c
+++ b/libavfilter/pthread.c
@@ -150,7 +150,6 @@ static int thread_init(ThreadContext *c, int nb_threads)
 
     if (!nb_threads) {
         int nb_cpus = av_cpu_count();
-        av_log(c->graph, AV_LOG_DEBUG, "Detected %d logical cores.\n", nb_cpus);
         // use number of cores + 1 as thread count if there is more than one
         if (nb_cpus > 1)
             nb_threads = nb_cpus + 1;
diff --git a/libavutil/cpu.c b/libavutil/cpu.c
index 73d58565f3019c0b6c0a89e862b887808795d0fa..10e15ba668eddb7fdc4007f49d7a58ef50431a85 100644
--- a/libavutil/cpu.c
+++ b/libavutil/cpu.c
@@ -198,6 +198,8 @@ int av_parse_cpu_caps(unsigned *flags, const char *s)
 
 int av_cpu_count(void)
 {
+    static volatile int printed;
+
     int ret, nb_cpus = 1;
 #if HAVE_SCHED_GETAFFINITY && defined(CPU_COUNT)
     cpu_set_t cpuset;
@@ -226,6 +228,11 @@ int av_cpu_count(void)
     nb_cpus = sysconf(_SC_NPROCESSORS_ONLN);
 #endif
 
+    if (!printed) {
+        av_log(NULL, AV_LOG_DEBUG, "detected %d logical cores\n", nb_cpus);
+        printed = 1;
+    }
+
     return nb_cpus;
 }