Kernel mode setting (Русский)
Kernel Mode Setting (KMS) представляет собой метод для задания разрешения дисплея и глубины в пространстве ядра, а не в пространстве пользователя.
Реализация KMS в ядре Linux активирует родное расширение в framebuffer и допускает мгновенное переключение консолей (tty). KMS содержит новые технологии (такие как DRI2) которые помогают снизить количество артефактов и увеличить производительность в 3D, даже при включенном режиме энергосбережения.
История
Ранее настройками видео карты занимался непосредственно X сервер. По этой причине достигнуть высокого качества графики в tty консолях было непросто. Кроме того, каждый раз при переключении из X в виртуальную консоль с помощью комбинации клавиш (Ctrl+Alt+F1
) сервер должен был передавать управление видеокартой ядру, что было медленным и вызывало мерцания. Особенно "болезненным" был переход управления обратно к X серверу (Ctrl+Alt+F7
).
С использованием Kernel Mode Setting (KMS) ядру стала доступна установка режимов видео карты. Наряду с другими достоинствами это улучшает визуальные эффекты при установке параметров графики, а также позволяет быстрее переключаться между виртуальными консолями и X.
Установка
Обратите внимание - для любых используемых Вами методов необходимо всегда отключать:
- Любые
vga=
режимы в загрузчике, так как это вызовет конфликт с разрешением, активированным в KMS. - Любые
video=
строки, активирующие framebuffer, что вызовет конфликт с драйвером. - Любые другие драйвера framebuffer (такие как uvesafb).
Поздний запуск KMS
Драйвера Intel, Nouveau и ATI и AMDGPU уже активируют KMS автоматически для всех чипсетов и не требуют ручной настройки.
Проприетарный драйвер NVIDIA поддерживает KMS с версии 364.12, но нужно включить его вручную.
Ранний запуск KMS
Обычно KMS инициализируется после этапа initramfs. Однако можно включить KMS уже на этапе initramfs. Добавьте нужный модуль для видеодрайвера в конфигурационный файл initramfs:
- для AMDGPU ли для старого драйвера ATI.
- для Intel graphics.
- для открытого драйвера Nouveau.
mgag200
для Matrox.- Для QEMU в зависимости от используемого режима графики:
virtio-gpu
для VirtIO, для QXL или для Cirrus. - для проприетарного драйвера . Смотрите NVIDIA (Русский)#DRM kernel mode setting для подробностей.
Инструкции по настройке initramfs немного отличаются в зависимости от генератора initramfs, который вы используете.
mkinitcpio
Пример раннего запуска KMS для Intel graphics:
/etc/mkinitcpio.conf
MODULES=(... i915 ...)
Если Вы используете изменённый файл EDID (не совпадающий с преднастроенными разрешениями), следует встроить его в initramfs:
После изменений пересоберите образ initramfs.
Booster
Пример настройки Booster:
Добавление дополнительных файлов в образ:
После изменений пересоберите образы booster.
Решение проблем
Мои шрифты слишком маленькие
В статье Консоль Linux#Шрифты вы можете узнать, как изменить шрифт в консоли на более крупный. Например, шрифт Terminus (terminus-font) доступен в нескольких размерах, в том числе и в большом .
Или можно отключить modesetting, что приведёт к использованию меньшего разрешения экрана, и шрифты станут выглядеть крупнее.
Проблемы во время загрузки и dmesg
Опрос подключенных дисплеев на старых системах может быть довольно громоздким. Опрос происходит периодически и может занять несколько сотен миллисекунд в зависимости от оборудования. Это может приводить к заметным задержкам, например, при воспроизведении видео. Такие задержки могут происходить, даже если видео выводится на HDP-выход, но в конфигурации оборудования есть другие выходы, не HDP. Если у вас наблюдаются задержки в выводе изображения на экран каждые 10 секунд, отключение опроса может помочь.
Если выскакивает ошибка с кодом во время процесса загрузки (Вы можете получить около 10 строк текста, последняя часть содержит этот код), используйте:
Принудительный режим и EDID
В случае когда Ваш дисплей не отправляет соответствующий EDID или вызывает какие-либо проблемы, Вы будете уведомлены, что родное разрешение автоматически не настроено или не отображается вообще. Ядро пытается отловить проблемы и устанавливает одно из наиболее типичных разрешений.
Если у вас есть EDID-файл для вашего монитора, то вам просто нужно явно указать его (смотрите ниже). Однако чаще всего прямого доступа к нормальному файлу нет, и приходится либо извлекать существующий и исправлять его, либо генерировать новый.
Создание новых бинарных файлов EDID для различных разрешений и конфигураций возможно во время компиляции ядра, следуя документации (также здесь есть краткое руководство). Другие решения подробно описаны в этой статье. Извлечение существующего в большинстве случаев проще, например, если ваш монитор нормально работает под Windows, вам может повезти извлечь EDID из соответствующего драйвера, или есть похожий монитор, который успешно работает с такими же настройками, вы можете использовать из пакета . Можно также попробовать поискать в .
После подготовки EDID поместите его в подкаталог, например, с названием edid
в каталоге и скопируйте в него свой бинарный файл.
Для запуска во время загрузки пропишите параметр ядра:
drm.edid_firmware=edid/your_edid.bin
Для ядер старее 4.13 используется другой параметр:
drm_kms_helper.edid_firmware=edid/your_edid.bin
Также, можно указать только для заданного дисплея:
drm.edid_firmware=VGA-1:edid/your_edid.bin
Для преднастроенные разрешений, смотри таблицу имён спецификаций:
Разрешение | Имя спецификации |
---|---|
800x600 | edid/800x600.bin |
1024x768 | edid/1024x768.bin |
1280x1024 | edid/1280x1024.bin |
1600x1200 (ядро 3.10 или новее) | edid/1600x1200.bin |
1680x1050 | edid/1680x1050.bin |
1920x1080 | edid/1920x1080.bin |
Если осуществлён ранний запуск KMS, необходимо включить кастомизированный файл EDID в initramfs иначе возможны проблемы.
Значение параметра также может быть изменено после загрузки путём записи в /sys/module/drm/parameters/edid_firmware
:
# echo edid/your_edid.bin > /sys/module/drm/parameters/edid_firmware
Это повлияет только на вновь подключенные мониторы; ранее подключенные продолжат использовать старые настройки EDID. Однако для внешних мониторов достаточно переподключить их, чтобы новый EDID применился.
Начиная с ядра 3.15, для изменения EDID после загрузки системы можно использовать debugfs вместо параметра ядра, если ядро не находится в Lockdown-режиме. Это очень полезно, если вы меняете местами мониторы на разъёме или просто для тестирования.
# cat correct-edid.bin > /sys/kernel/debug/dri/0/HDMI-A-2/edid_override
Отключение:
# echo -n reset > /sys/kernel/debug/dri/0/HDMI-A-2/edid_override
Взято из nouveau wiki:
- Режим может быть принудительным в командной строке ядра. К сожалению, опция командной строки видео бедно документирована в случае с DRM. Части и куски того как это использовать можно найти в
В формате:
video=<conn>:<xres>x<yres>[M][R][-<bpp>][@<refresh>][i][m][eDd]
- : Коннектор, т.н. DVI-I-1, смотри доступные здесь
- : разрешение
- : посчитать режим CVT?
R
: снижение мерцания?- : глубина цвета
- : частота обновления
- : чересстрочный (non-CVT mode)
m
: поля?- : принудительный вывод on
- : принудительный вывод off
- : принудительный цифровой вывод on (т.н. DVI-I коннектор)
Вы можете переопределять режимы нескольких выходов использующих "video" несколько раз, в частности, для вывода DVI в 1024x768 на 85 Hz и отключения TV-out:
video=DVI-I-1:1024x768@85 video=TV-1:d
Для получения имени и текущего статуса коннекторов, Вы можете использовать однострочную команду:
Отключение modesetting
Вы можете захотеть отключить KMS по различным причинам. Для отключения KMS добавьте в параметры ядра.
Наряду с параметром , для карт Intel необходимо добавить , а для Nvidia nouveau.modeset=0
. Для систем двойной графики (dual-graphics system) Nvidia Optimus, нужно добавить все три параметра ядра ().