Почему у меня высокая загрузка ЦП (одноядерный) при запуске glxgears на GPU?

422
Dylan Cali

При запуске glxgears (или любого графически интенсивного приложения) в Linux я вижу 100% -ное использование одного ядра процессора, хотя я и подтвердил, что он использует мой графический процессор Nvidia в качестве средства визуализации. Это ожидается?

Моя машина

$ inxi -Fxz System: Kernel: 4.15.0-38-generic x86_64 (64 bit gcc: 5.4.0) Desktop: Cinnamon 3.4.6 (Gtk 3.18.9) Distro: Linux Mint 18.2 Sonya Machine: System: Dell (portable) product: Precision 5520 Mobo: Dell model: 04GFKY v: A00 Bios: Dell v: 1.5.0 date: 08/30/2017 CPU: Quad core Intel Xeon E3-1505M v6 (-HT-MCP-) cache: 8192 KB flags: (lm nx sse sse2 sse3 sse4_1 sse4_2 ssse3 vmx) bmips: 24000 clock speeds: max: 4000 MHz 1: 1727 MHz 2: 1417 MHz 3: 1354 MHz 4: 1510 MHz 5: 949 MHz 6: 1430 MHz 7: 1283 MHz 8: 1440 MHz Graphics: Card-1: Intel HD Graphics P630 bus-ID: 00:02.0 Card-2: NVIDIA GM107GLM [Quadro M1200 Mobile] bus-ID: 01:00.0 Display Server: X.Org 1.18.4 driver: nvidia Resolution: 3440x1440@49.99hz GLX Renderer: Quadro M1200/PCIe/SSE2 GLX Version: 4.5.0 NVIDIA 384.130 Direct Rendering: Yes 

У меня несколько необычная установка: я использую Linux на ноутбуке с Nvidia Optimus (интегрированная графика Intel + дискретный графический процессор Nvidia для мобильных ПК). Однако я настроил linux для использования выделенного графического процессора Nvidia с использованием nvidia-primeи проверил конфигурацию (в inxiприведенных выше результатах также сообщается, что карта / драйвер Nvidia используется в качестве графического средства визуализации).

Тестовое задание

Я запускаю glxgears:

$ glxgears -info GL_RENDERER = Quadro M1200/PCIe/SSE2 GL_VERSION = 4.5.0 NVIDIA 384.130 GL_VENDOR = NVIDIA Corporation 

и htopя вижу:

Почему у меня высокая загрузка ЦП (одноядерный) при запуске glxgears на GPU?

Я также побежал, oprofileчтобы получить отчет о том, что делал мой процессор, который дал мне:

CPU: Intel Architectural Perfmon, speed 4000 MHz (estimated) Counted CPU_CLK_UNHALTED events (Clock cycles when not halted) with a unit mask of 0x00 (No unit mask) count 100000 CPU_CLK_UNHALT...| samples| %| ------------------ 4232537 100.000 glxgears CPU_CLK_UNHALT...| samples| %| ------------------ 3155713 74.5584 kallsyms 523169 12.3606 libnvidia-glcore.so.384.130 332903 7.8653 libc-2.23.so 177315 4.1893 libGL.so.384.130 27398 0.6473 .glxj5h8n 3605 0.0852 libxcb.so.1.1.0 3396 0.0802 libX11.so.6.3.0 3273 0.0773 libm-2.23.so 2594 0.0613 glxgears 1218 0.0288 [vdso] (tgid:10292 range:0x7ffc294d2000-0x7ffc294d3fff) 706 0.0167 .glWqJoPX 682 0.0161 libXext.so.6.4.0 366 0.0086 .glhBcsou 68 0.0016 snd_usb_audio 51 0.0012 nvidia 41 9.7e-04 iwlwifi 18 4.3e-04 kvm 15 3.5e-04 x86_pkg_temp_thermal 2 4.7e-05 hid 2 4.7e-05 mac80211 2 4.7e-05 nvidia_uvm 

Исходя из этого, glxgears определенно использует серверную часть nvidia, поэтому я запутался, почему в чисто графическом приложении, использующем gpu, также было бы много загруженных одноядерных процессоров?

0

1 ответ на вопрос

0
Yorik

Я не эксперт по Linux, но kallsyms - это ядро, и я вижу гугл болтовню о высокой загрузке ЦП в ядре / kallsyms на ноутбуках, где есть / была ошибка ядра, связанная с динамическим управлением питанием USB (см., Например: https: // askubuntu.com/questions/1044872/ubuntu-16-04-kworker-using-high-cpu-constantly ).

Похожие вопросы