NVIDIA/nvidia-drivers/ru

— это проприетарный графический драйвер для видеокарт nVidia. Альтернативой с открытым исходным кодом является nouveau.

Драйвера в дереве Portage выпускаются nVidia и собираются для ядра Linux. Они содержат блоб (от англ. binary linked object — объект двоичной компоновки), который берет на себя основную работу по взаимодействию с платой. Драйвера состоят из двух частей: модуля ядра и драйвера X11. Обе части включаются в один пакет. Вследствие особенностей упаковки драйверов nVidia, необходимо сделать некоторый выбор перед установкой драйверов.

Пакет включает в себя последние драйвера от nVidia с поддержкой всех плат. Имеется в наличии несколько версий пакета в зависимости от того, насколько у вас старая плата. Этот пакет использует eclass для обнаружения типа используемой платы, чтобы установить подходящую версию.

Аппаратная совместимость
Пакет поддерживает целый диапазон доступных плат nVidia. В зависимости от видеокарты, которая имеется в системе, для установки доступно большое число версий. Прочитайте официальную документацию nVidia Что такое устаревший драйвер?, для того, чтобы узнать, какую версию пакета лучше использовать. Достаточно подходящий способ узнать это с помощью интерактивной формы предложенной здесь. Введите видеокарту (учитывая параметр Legacy в поле 'Product Type'), и форма отобразит наилучшую поддерживаемую версию.

Если карта определилась как устаревшая, замаскируйте свежие выпуски, т. е.

Заметьте, что Gentoo не предоставляет версии 71.86.xx. Если в системе установлена видеокарта, которой необходимы эти драйвера, то рекомендуется использовать драйвер nouveau.

Kernel
Как упоминалось выше, драйвер ядра nVidia устанавливается и работает на текущем ядре. Он собирается в виде модуля, поэтому ядро должно поддерживать загрузку модулей ядра (смотрите ниже).

The kernel module consists of a proprietary part (commonly known as the "binary blob") which drives the graphics chip(s), and an open source part (the "glue") which at runtime acts as intermediary between the proprietary part and the kernel. These all need to work nicely together as otherwise the user might be faced with data loss (through kernel panics, X servers crashing with unsaved data in X applications) and even hardware failure (overheating and other power management related issues should spring to mind).

Kernel compatibility
Время от времени, новый релиз ядра изменяет внутренний двоичный интерфейс приложений (англ. ABI, application binary interface) для драйверов, что означает, что все драйвера, которые используют этот интерфейс, должны быть соответствующим образом изменены. Для драйверов с открытым исходным кодом, особенно распространяемых с ядром, эти изменения практически тривиальны для исправления, так как цепочка вызовов между драйверами и другими частями ядра может быть просмотрена достаточно легко. Для проприетарных драйверов типа nvidia.ko, это далеко не так. При изменении внутреннего двойчного интерфейса приложений, невозможно просто исправить используемый клей, потому что неизвестно как этот клей используется проприетарной частью. Если удастся наладить работу и все будет работать исправно, вы все еще рискуете тем, что работа nvidia.ko в новом, неподдерживаемом ядре приведет к потере данных и аппаратному сбою.

Когда выпускается новая, несовместимая версия ядра, лучше некоторое время оставаться на последнем поддерживаемом ядре. Обычно, Nvidia требуется несколько недель для подготовки нового проприетарного релиза, который, по их мнению, подходит для общего использования. Просто будьте терпеливы. Если же обновление совершенно необходимо, ebuild-файл nvidia-drivers поддерживает команду epatch_user из класса eutils.class: это позволит вам исправить nvidia-drivers для их совместимости с последним, неподдерживаемым релизом ядра. Однако заметьте, что ни мейнтейнеры пакета nvidia-drivers, ни Nvidia не оказывают тех. поддержки, в данной ситуации. Гарантия на аппаратное обеспечение, скорее всего, будет аннулирована. Мейнтейнеры Gentoo не смогут исправить ваши проблемы, так как это проприетарный драйвер, который может быть отлажен только Nvidia. Мейнтейнеры ядра (как пакета Gentoo, так и разработчики самого ядра), определенно не будут поддерживать проприетарные драйвера или, любую испорченную систему, которая может вызвать проблемы.

Если для конфигурации ядра был использован genkernel all, тогда все в порядке. Если нет, дважды проверьте конфигурацию ядра, так чтобы поддержка загружаемых модулей была включена:

Также включите в ядро поддержку диапазонных регистров типа памяти (англ. Memory Type Range Register - MTRR):

If the system has an AGP graphics card, then optionally enable agpgart support to the kernel, either compiled in or as a module. If the in-kernel agpgart module is not used, then the drivers will use its own agpgart implementation, called NvAGP. On certain systems, this performs better than the in-kernel agpgart, and on others, it performs worse. Evaluate either choice on the system to get the best performance. When uncertain what to do, use the in-kernel agpgart:

A framebuffer alternative is uvesafb, which can be installed parallel to.

For (U)EFI systems, uvesafb will not work. Be warned that enabling efifb support in kernel causes intermittent problems with the initialization of the nvidia drivers. There is no known alternative framebuffer for (U)EFI systems.

The nvidia-drivers ebuild automatically discovers the kernel version based on the symlink. Please ensure that this symlink is pointing to the correct sources and that the kernel is correctly configured. Please refer to the "Configuring the Kernel" section of the Gentoo Handbook for details on configuring the kernel.

First, choose the right kernel source using eselect. When using gentoo-sources-3.7.10, the kernel listing might look something like this:

In the above output, notice that the linux-3.7.10-gentoo kernel is marked with an asterisk to show that it is the symlinked kernel.

If the symlink is not pointing to the correct sources, update the link by selecting the number of the desired kernel sources, as in the example above.

Drivers
Теперь самое время установить драйвера. Сперва, следуйте Xorg/Руководство и установите   в. Во время установки X-сервера, он установит правильную версию.

После завершения установки, запустите modprobe nvidia для загрузки модуля ядра в память. Если вы обновляете ядро, то сначала удалите предыдущий модуль.

Чтобы, не загружать модуль вручную, после каждой перезагрузки. Добавьте  в, для его автоматической загрузки, при старте системы.

Kernel module signing (optional)
If you are using secure boot kernel signing then you will need to sign the Nvidia kernel modules before they can be loaded.

You do this by using the kernel provided perl script as follows.

As of driver version 358.09 a new module has been made to handle monitor mode setting and for this driver version this module must also be signed.

Once you have signed these modules then the driver will load as expected on boot up. This module signing method can be used to sign other modules not only your nvidia-drivers. You would have to modify the path and corresponding module accordingly.

The X server
Once the appropriate drivers are installed, configure the X server to use the nvidia driver instead of the default nv driver.

Run eselect so that the X server uses the nVidia GLX libraries:

Enabling global nvidia support
Some tools, such as and, use a local USE flag called   which enables XvMCNVIDIA support, useful when watching high resolution movies. Add in  in the USE variable in  or add it as USE flag to  and/or  in.

GeForce 8 series and later GPUs do come with VDPAU support which superseded XvMCNVIDIA support. See the VDPAU article for enabling VDPAU support.

There are also some applications that use the  USE flag, so it might be a good idea to add it to.

Then, run to rebuild the applications that benefit from the USE flag change.

Using the nVidia settings tool
nVidia also provides a settings tool. This tool allows the user to monitor and change graphical settings without restarting the X server and is available through Portage as. As mentioned earlier, it will be pulled in automatically when installing the drivers with the  USE flag set in  or in.

Включение OpenGL/OpenCL
To enable OpenGL and OpenCL though the device, run:

Make sure that the Xorg server is not running during these changes.

Testing the card
Для того, чтобы протестировать вашу видеокарту, запустите X и введите команду glxinfo</tt>, которая является частью пакета. Она должна сообщить, что direct rendering активирован:

Для проверки кадровой частоты — FPS, запустите glxgears</tt>.

Драйвер не инициализируется, если включены прерывания MSI
Драйвер NVIDIA в Linux по умолчанию использует Message Signaled Interrupts (прерывания инициируемые сообщениями, MSI). В результате этого мы получаем совместимость и расширяемость, в основном из-за отсутствия необходимости разделения IRQ. На некоторых системах наблюдаются проблемы с поддержкой MSI, хотя они хорошо работают с прерываниями virtual wire (виртуальные провода). Это приводит к невозможности запустить X вместе с драйвером NVIDIA, либо к проблемам инициализации CUDA.

Прерывания MSI можно запретить параметром модуля ядра NVIDIA. Это можно сделать в командной строке при загрузке модуля, либо (более правильно) через файлы конфигурации модулей дистрибутива (например, через те, что находятся в ).

Например:

Работа с 2D ускорением на машинах с 4 Гб памяти и больше.
Если вы испытываете проблемы с ускорением 2D графики nVidia, скорее всего системе не удалось настроить диапазон совмещения записи (write-combining range) в MTRR. Чтобы это проверить, пересмотрите содержимое следующих файлов

Каждая строка должна содержать write-back</tt> или write-combining</tt>. При появлении строки со словом uncachable</tt>, необходимо изменить настройки BIOS, чтобы это исправить.

Перезагрузитесь и войдите в BIOS, затем найдите настройки MTRR (возможно, под CPU Settings). Измените настройки с continuous</tt> на discrete</tt> и перезагрузитесь обратно в Linux. Теперь записи со словом uncachable</tt> больше нет и 2D-ускорение работает без каких-либо неполадок.

no such device, при попытке загрузить модуль ядра
Это обычно вызвано одной из следующих проблем:


 * 1) В системе отсутствует, какая лиюл видеокарта nVidia. Проверьте вывод lspci</tt>, чтобы убедиться, что видеокарта nVidia подключена и обнаружена.
 * 2) Установленная версия  не поддерживает подключенную модель видеокарты. Проверьте файл README в  на наличие списка поддерживаемых устройств, или используйте поиск драйверов в http://www.geforce.com/drivers.
 * 3) Карта используется другим драйвером ядра. Проверьте, с помощью lspci -k</tt>, если другой драйвер, вроде "nouveau", привязан к текущей карте. Если да, то отключите его или добавте в черный список.

Xorg сообщает, что не может найти какие-либо экраны
Когда после загрузки системы, вместо графического интерфейса пользователя, вы получаете черный экран или командную строку в консоли; нажмите ++, чтобы вызвать командную строку (если она отсутствует). Затем запустите:

чтобы увидеть вывод работы Xorg. Если одной из первых ошибок идет сообщение о том, что Xorg не может найти какие-либо экраны, следуйте следующим инструкциям, чтобы разрешить проблему.

Должно быть достаточно запуска следующей команды перед перезагрузкой:

Но если это не работает, запустите lspci</tt> и найдите вашу видеокарту, начинающуюся примерно так:

Возьмите первую часть,  и поместите ее в  вместе с параметром  :

Direct rendering не активирован
Если direct rendering не работает, это может быть потому, что Direct Rendering Manager включен в ядро, что вызывает конфликт с драйвером. Проверьте статус Direct Rendering следуя инструкциям раздела Тестирование видеокарты.

Во-первых, отключите Direct Rendering Manager в ядре :

Далее, соберите заново, так как драйвер мог быть пересобран с DRM-символами ядра. Это должно исправить проблему.

Замедленное или заикающееся проигрывание видео
В последнее время можно наблюдать сбои с проигрыванием некоторых типов видео на бинарных драйверах NVidia, вызывающие медленное воспроизведение или значительное заикание. Эта проблема происходит при замене для определенных процессоров общего ACPI метода холостого хода на метод от Intel.

Отключите метод холостого хода для процессора Intel, используя  в методе загрузки командной строки ядра, что должно дать основание для ядра автоматически откатится до нормального или более старого ACPI метода холостого хода процессора. Также, отключение NVidia Powermizer, или установка Powermizer на максимальную производительность с nvidia-settings</tt>, также может помочь. Хотя метод холостого хода для процессора Intel был представлен как стандарт для процессоров i5 и i7 (против использования ACPI метода), есть серьезная причина. Этот метод существенно решает проблему, однако некоторые небольшие заикания или медленное воспроизведение встречаются при включенном деинтерлейсинге; это происходит когда видео уже деинтерлейсировано (т.е. псевдоним mplayer-nodeint</tt> с чем-то похожим для mplayer -vo vdpau:deint=0:denoise=0:nochroma-deint:colorspace=0:hqscaling=1, video.mpg</tt>).

No vertical synchronization (no VSync, tearing) in OpenGL applications
Adding the following option to the screen section prevents tearing on GTX 660, 660 Ti, and probably some other GPUs (reference):

Документация
Пакет также поставляется с исчерпывающей документацией. Она устанавливается в каталог и может быть просмотрена с помощью следующей команды:

Параметры модуля ядра
Модуль ядра nvidia</tt> принимает набор параметров (options), которые позволяют настроить поведение драйвера. Большинство из них упомянуто в документации. Для того, чтобы добавить или изменить значения этих параметров, отредактируйте файл. Не забудьте запустить update-modules</tt> после изменения этого файла и помните, что вам потребуется перезагрузить модуль   перед тем, как новые настройки вступят в силу.

Отредактируйте :

Обновите информацию о модулях:

Выгрузите модуль <tt>nvidia</tt>...

...и загрузите его снова:

Расширенная конфигурация X-сервера
GLX-интерфейс также имеет огромное количество параметров, которые можно настроить. Они управляют конфигурацией выхода TV, одновременным выводом на два монитора, определением частоты монитора, и так далее. Опять же, все доступные параметры подробно описаны в документации.

Чтобы использовать какие-либо из этих параметров, необходимо перечислить их в соответственном разделе Device в файле конфигурации X (обычно находящемся в ). Например, чтобы отключить всплывающий логотип — splash logo:

Смотрите также

 * nouveau & nvidia-drivers switching - Hybrid graphics mode using open-source drivers.
 * NVIDIA Optimus - Configure a system to use closed-source drivers for hybrid graphics (modesetting).