NVIDIA/nvidia-drivers/ru

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

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

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

Hardware compatibility
The package supports a range of available nVidia cards. Multiple versions are available for installation, depending on the card(s) that the system has. See the official nVidia documentation, What's a legacy driver?, to find out what version of should be used. A pretty decent way to find this out through an interactive form. Enter the graphics card that is used by the system (mind the Legacy option in the 'Product Type' field) and the form should end up with the best supported version.

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

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

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

Модуль ядра (nvidia.ko) состоит из проприетарной части (широко известной как двоичный блоб), которая управляет графическими чипами, и части с открытым исходным кодом (клей — англ. glue), которая во время исполнения работает как посредник между проприетарной частью и ядром. Они должны работать вместе слаженно, иначе вы можете столкнуться с потерей данных (из-за паники ядра, сбоя X-сервера с несохраненными данными в X-приложениях) и даже повреждением аппаратного обеспечения (перегрев и другие проблемы с управлением питания тут же приходят на ум).

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

When a new, incompatible kernel version is released, it is probably best to stick with the newest supported kernel for a while. Nvidia usually takes a few weeks to prepare a new proprietary release they think is fit for general use. Just be patient. If absolutely necessary, then it is possible to use the epatch_user command with the nvidia-drivers ebuilds: this allows the user to patch nvidia-drivers to somehow fit in with the latest, unsupported kernel release. Do note that neither the nvidia-drivers maintainers nor Nvidia will support this situation. The hardware warranty will most likely be void, Gentoo's maintainers cannot begin to fix the issues since it's a proprietary driver that only Nvidia can properly debug, and the kernel maintainers (both Gentoo's and upstream) will certainly not support proprietary drivers, or indeed any "tainted" system that happens to run into trouble.

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

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

Если у вас видеокарта AGP, вы можете дополнительно включить в ядро поддержку драйвера apggart, встроенного в ядро, или в качестве модуля. Если модуль apggart не используется, то драйверы будут использовать собственную реализацию apggart, называемую NvAGP. На определенных системах, это приводит к лучшей производительности, чем встроенный в ядро agpgart, а на некоторых, к худшей. Оцените оба варианта на своей собственной системе для достижения наилучшей производительности. Если вы не уверены что делать, используйте встроенный в ядро agpgart:

Альтернативой для кадрового буфера является uvesafb, который может быть установлен вместе с.

Ebuild-файл nvidia-drivers автоматически обнаруживает версию вашего ядра, основываясь на символьной ссылке. Пожалуйста, убедитесь, что эта символьная ссылка указывает на корректные исходные коды и что ваше ядро сконфигурировано правильно. Обратитесь к разделу «Конфигурация ядра» Настольной книги Gentoo для получения подробностей по конфигурации ядра.

Сперва, выберите правильные исходные тексты ядра используя eselect. Если вы используете gentoo-sources-3.7.10, список доступных ядер может выглядеть следующим образом:

В результате, приведенном выше, заметьте, что ядро linux-3.7.10-gentoo</tt> помечено звездочкой, для того, чтобы продемонстрировать, что это то ядро, на которое указывает символьная ссылка.

Если символьная ссылка не указывает на корректные исходные тексты, обновите ее, выбирая номер требуемых вами исходных текстов ядра, как в приведенном далее примере.

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

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

Драйвера
Теперь самое время установить драйвера. Вы можете это сделать сначала следуя Описанию настройки X-сервера, и, затем, установив VIDEO_CARDS="nvidia" в. После того, как Вы установите X-сервер,, он затем установит правильную версию nvidia-drivers для Вас.

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

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

Запустите eselect, чтобы X-сервер использовал GLX библиотеки nVidia:

Testing the card
To test the nVidia card, fire up X and run glxinfo, which is part of the package. It should say that direct rendering is activated:

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

Enabling 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 и более поздние GPU выходят с поддержкой VDPAU, которая заменила собой поддержку XvMCNVIDIA. Смотри статью VDPAU для включения поддержки VDPAU.

Также есть несколько приложений, которые используют USE-флаг, поэтому было бы неплохо добавить его в файл.

Затем, запустите emerge -uD --newuse @world для пересборки приложений, которые выигрывают от изменения этого USE-флага.

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
Для включения OpenGL и OpenCL.

Убедитесь, что сервер Xorg не запущен во время проведения этих изменений.

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

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

Например:

Getting 2D acceleration to work on machines with 4GB memory or more
When nVidia 2D acceleration is giving problems, then it is likely that the system is unable to set up a write-combining range with MTRR. To verify, check the contents of :

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

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

"no such device" appears when trying to load the kernel module
This is usually caused by one of the following issues:


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

Xorg says it can't find any screens
When after booting the system, it ends up with a black screen or a console prompt instead of the GUI; then press to bring up a console prompt. Next, run:

to see the output of Xorg. If one of the first errors is that Xorg can't find any screens, then follow the following steps to resolve the issue.

It should be enough to run the following command before rebooting:

But if that doesn't work, run lspci and notice that the video card starts off like this:

Take the first bit,  and put it in the  file with the   option:

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

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

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

Documentation
The package also comes with comprehensive documentation. This is installed into and can be viewed with the following command:

Kernel module parameters
The nvidia</tt> kernel module accepts a number of parameters (options) which can be used to tweak the behaviour of the driver. Most of these are mentioned in the documentation. To add or change the values of these parameters, edit the file. Remember to run update-modules after modifying this file, and bear in mind to reload the  module before the new settings take effect.

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

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

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

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

Advanced X configuration
The GLX layer also has a plethora of options which can be configured. These control the configuration of TV out, dual displays, monitor frequency detection, etc. Again, all of the available options are detailed in the documentation.

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

Благодарности
Мы хотим поблагодарить следующих авторов и редакторов за их вклад в это руководство: Sven Vermeulen, Joshua Saddler, M Curtis Napier and Chris Gianelloni.