Kernel mode setting (Русский)

Kernel Mode Setting (KMS) представляет собой метод для задания разрешения дисплея и глубины в пространстве ядра, а не в пространстве пользователя.

Состояние перевода: На этой странице представлен перевод статьи Kernel mode setting. Дата последней синхронизации: 9 февраля 2022. Вы можете помочь синхронизировать перевод, если в английской версии произошли изменения.

Реализация KMS в ядре Linux активирует родное расширение в framebuffer и допускает мгновенное переключение консолей (tty). KMS содержит новые технологии (такие как DRI2) которые помогают снизить количество артефактов и увеличить производительность в 3D, даже при включенном режиме энергосбережения.

Примечание: Проприетарный драйвер NVIDIA (с версии 364.12) также поддерживает KMS, но не использует встроенную реализацию ядра и не обеспечивает работу драйвера FBdev для отображения консоли с высоким разрешением.

История

Ранее настройками видео карты занимался непосредственно 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

Для преднастроенные разрешений, смотри таблицу имён спецификаций:

РазрешениеИмя спецификации
800x600edid/800x600.bin
1024x768edid/1024x768.bin
1280x1024edid/1280x1024.bin
1600x1200 (ядро 3.10 или новее)edid/1600x1200.bin
1680x1050edid/1680x1050.bin
1920x1080edid/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, нужно добавить все три параметра ядра ().

gollark: What am I meant to do?
gollark: I think so, why?
gollark: Yes hello I exist bee.
gollark: py-goto?! OOOO!
gollark: Maybe I should factor out all the `except`s into functions.
This article is issued from Archlinux. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.