NVIDIA/nvidia-drivers/ru

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

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

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

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

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

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

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

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

Совместимость ядра
Время от времени, новый релиз ядра изменяет внутренний двоичный интерфейс приложений (англ. 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):

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

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

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

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

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

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

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

Once the installation has finished, run modprobe nvidia</tt> to load the kernel module into memory. If this is an upgrade, remove the previous module first.

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

X-сервер
Как только подходящие драйвера установленны, настройте X-сервер для использования драйвера nvidia</tt> вместо драйвера по умолчанию nv</tt>.

Run eselect</tt> so that the X server uses the nVidia GLX libraries:

Тестирование видеокарты
To test the nVidia card, fire up X and run glxinfo</tt>, which is part of the package. It should say that direct rendering is activated:

To monitor the FPS, run glxgears</tt>.

Включение поддержки nvidia
Некоторые инструменты, такие как и, используют локальный USE-флаг, называемый  , включающий поддержку XvMCNVIDIA. Это полезно при просмотре видео высокого разрешения. Добавьте  в список USE-флагов в, или добавьте его как USE-флаг в    и/или    в файле.

Серии GeForce 8 и более поздние GPU выходят с поддержкой VDPAU, которая заменила собой поддержку XvMCNVIDIA. Смотри статью VDPAU для включения поддержки VDPAU.

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

Then, run emerge -uD --newuse @world</tt> to rebuild the applications that benefit from the USE flag change.

Использование инструмента управления настройками от NVidia
nVidia также предоставляет вам инструмент для управления настройками. Этот инструмент разрешает вам просматривать и изменять настройки графики без перезапуска X-сервера и доступен через Portage как. Как упомянуто ранее, он будет установлен автоматически, если вы установили драйвера с USE-флагом, прописанным в файле  или в.

Включение OpenGL/OpenCL
Для включения OpenGL и OpenCL.

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

Драйвер не инициализируется, если включены прерывания 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) The system does not have a nVidia card at all.  Check lspci</tt> output to confirm that the system has a nVidia graphics card installed and detected.
 * 2) The currently installed version of  does not support the installed graphics card model.  Check the README file in /usr/share/nvidia-drivers-*/ for a list of supported devices, or use the driver search at http://www.geforce.com/drivers.
 * 3) Another kernel driver has control of the hardware.  Check <tt>lspci -k</tt> to see if another driver like "nouveau" is bound to the graphics card.  If so, disable or blacklist this driver.

Xorg сообщает, что не может найти какие-либо экраны
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 virtual console. Next, run:

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

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

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

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

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

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

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

Video playback stuttering or slow
Lately there seems to be some breaking with playback of some types of video with the NVidia binary drivers, causing slow video playback or significant stuttering. This problem seems to be occurring within the Intel CPU Idle replacement instead of the common ACPI CPU idling method for certain CPU's.

Disable the Intel CPU idling method using  on the kernel command line boot method, which should cause the kernel to automatically fall back to the normal or older ACPI CPU idling method. Also, disabling the NVidia Powermizer feature, or setting Powermizer to maximum performance within <tt>nvidia-settings</tt> has been said to help. Although the Intel CPU idling method recently was introduced as the default CPU idling method for i5 and i7 CPUs (versus using ACPI CPU idling) is the root cause here. This idling method significantly solves the problem, however some minimal stuttering or slow video is encountered if deinterlacing was enabled; this is when the video is likely already deinterlaced (ie. alias <tt>mplayer-nodeint</tt> with something similar to <tt>mplayer -vo vdpau:deint=0:denoise=0:nochroma-deint:colorspace=0:hqscaling=1, video.mpg</tt> as a work around.)

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

Параметры модуля ядра
The <tt>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 <tt>update-modules</tt> after modifying this file, and bear in mind to reload the  module before the new settings take effect.

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

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

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

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

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

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

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

 * nouveau & nvidia-drivers switching/ru
 * NVIDIA Driver with Optimus Laptops/ru