Менеджер прямого рендеринга - Direct Rendering Manager

Менеджер прямого рендеринга
Оригинальный автор (ы)kernel.org & freedesktop.org
Разработчики)kernel.org & freedesktop.org
Написано вC
Тип
Лицензия
Интернет сайтдри.freedesktop.org/ wiki/ DRM

В Менеджер прямого рендеринга (DRM) является подсистемой Ядро Linux отвечает за взаимодействие с GPU современных видеокарты. DRM предоставляет API который пользовательское пространство программы могут использоваться для отправки команд и данных на графический процессор и выполнения таких операций, как настройка установка режима дисплея. DRM был впервые разработан как пространство ядра компонент X сервер Инфраструктура прямого рендеринга,[1] но с тех пор он использовался другими альтернативами графического стека, такими как Wayland.

Программы пользовательского пространства могут использовать DRM API, чтобы отдавать команду графическому процессору. с аппаратным ускорением 3D рендеринг и декодирование видео, а также GPGPU вычисления.

Обзор

В Ядро Linux уже был API называется fbdev, используется для управления кадровый буфер из графический адаптер,[2] но его нельзя было использовать для удовлетворения потребностей современных 3D-ускоренных GPU -на основе видеооборудования. Эти устройства обычно требуют настройки и управления очередью команд в их собственная память для отправки команд графическому процессору, а также для управления буферами и свободным пространством в этой памяти.[3] Первоначально программы пользовательского пространства (такие как X сервер ) напрямую управляли этими ресурсами, но обычно они действовали так, как если бы они были единственными, кто имел к ним доступ. Когда две или более программы пытались управлять одним и тем же оборудованием одновременно и настраивали ресурсы каждой из них по-своему, в большинстве случаев они заканчивались катастрофически.[3]

Доступ к видеокарте без DRM
Без DRM
Доступ к видеокарте с DRM
С DRM
DRM позволяет нескольким программам одновременно обращаться к 3D-видеокарте, избегая коллизий

Диспетчер прямого рендеринга был создан, чтобы позволить нескольким программам совместно использовать ресурсы видеооборудования.[4] DRM получает эксклюзивный доступ к графическому процессору и отвечает за инициализацию и поддержку очереди команд, памяти и любого другого аппаратного ресурса. Программы, желающие использовать GPU, отправляют запросы в DRM, который действует как арбитр и заботится о предотвращении возможных конфликтов.

Объем DRM был расширен с годами, чтобы охватить больше функций, которые ранее обрабатывались программами пользовательского пространства, такими как управление кадровым буфером и установка режима, объекты с разделением памяти и синхронизация памяти.[5][6] Некоторым из этих расширений были даны конкретные имена, например Менеджер исполнения графики (GEM) или установка режима ядра (KMS), и терминология преобладает, когда конкретно упоминаются предоставляемые ими функции. Но на самом деле они являются частями всей подсистемы DRM ядра.

Тенденция включать в компьютер два графических процессора - дискретный и интегрированный - привела к новым проблемам, таким как Переключение графического процессора это также необходимо было решить на уровне DRM. Чтобы соответствовать Nvidia Optimus Технология DRM была предоставлена ​​с возможностью разгрузки графического процессора, называемой PRIME.[7]

Архитектура программного обеспечения

Процесс, использующий Direct Rendering Manager ядра Linux для доступа к графической карте с 3D-ускорением.

Менеджер прямого рендеринга находится в пространство ядра, поэтому программы пользовательского пространства должны использовать ядро системные вызовы запросить его услуги. Однако DRM не определяет свои собственные настраиваемые системные вызовы. Вместо этого он следует Unix принцип "все это файл "разоблачить GPU через пространство имен файловой системы, используя файлы устройства под / dev иерархия. Каждый графический процессор, обнаруженный DRM, называется DRM устройство, и файл устройства / dev / дри / картаИкс (куда Икс - порядковый номер) создается для взаимодействия с ним.[8][9] Программы пользовательского пространства, которые хотят общаться с GPU, должны открыто этот файл и используйте ioctl звонки для связи с DRM. Разные ioctl соответствуют разным функциям DRM. API.

А библиотека называется libdrm был создан для облегчения интерфейса программ пользовательского пространства с подсистемой DRM. Эта библиотека - просто обертка что обеспечивает функция написано в C для каждого ioctl DRM API, а также констант, структур и других вспомогательных элементов.[10] Использование libdrm не только позволяет избежать прямого доступа к интерфейсу ядра приложениям, но и предоставляет обычные преимущества повторное использование и совместное использование кода между программами.

Детали архитектуры Direct Rendering Manager: ядро ​​DRM и драйвер DRM (включая GEM и KMS) с интерфейсом libdrm

DRM состоит из двух частей: общего «ядра DRM» и особого («DRM-драйвера») для каждого типа поддерживаемого оборудования.[11] Ядро DRM обеспечивает базовую структуру, в которой могут регистрироваться различные драйверы DRM, а также предоставляет пользовательскому пространству минимальный набор ioctl с общими аппаратно-независимыми функциями.[8] Драйвер DRM, с другой стороны, реализует аппаратно-зависимую часть API, зависящую от типа поддерживаемого графического процессора; он должен обеспечивать реализацию остальных ioctl, не охваченных ядром DRM, но он также может расширять API, предлагая дополнительные ioctl с дополнительными функциями, доступными только на таком оборудовании.[8] Когда конкретный драйвер DRM предоставляет расширенный API, libdrm пользовательского пространства также расширяется дополнительной библиотекой libdrm-Водитель который может использоваться пользовательским пространством для взаимодействия с дополнительными ioctl.

API

Ядро DRM экспортирует несколько интерфейсов в приложения пользовательского пространства, обычно предназначенные для использования через соответствующие libdrm функции-обертки. Кроме того, драйверы экспортируют интерфейсы конкретных устройств для использования драйверами пользовательского пространства и приложениями, поддерживающими устройства, через ioctls и sysfs файлы. Внешние интерфейсы включают: отображение памяти, управление контекстом, DMA операции, AGP управление, пустой контроль, управление ограждением, управление памятью и управление выходом.

DRM-Master и DRM-Auth

В DRM API есть несколько операций (ioctls), которые либо в целях безопасности, либо для проблем параллелизма должны быть ограничены для использования одним процессом пользовательского пространства на устройстве.[8] Чтобы реализовать это ограничение, DRM ограничивает такие ioctl вызовы только процессом, который считается «главным» устройства DRM, обычно называемого DRM-Мастер. Только один из всех процессов, у которых есть узел устройства / dev / дри / картаИкс открытый будет иметь свой дескриптор файла отмечен как мастер, в частности, первый вызов SET_MASTER ioctl. Любая попытка использовать один из этих ограниченных ioctl без DRM-Master вернет ошибку. Процесс также может отказаться от своей ведущей роли и позволить другому процессу ее получить, вызвав DROP_MASTER ioctl.

В X сервер —Или любой другой сервер отображения - обычно это процесс, который получает статус DRM-Master в каждом устройстве DRM, которым он управляет, обычно когда он открывает соответствующий узел устройства во время своего запуска, и сохраняет эти привилегии для всего графического сеанса, пока он не завершится или не завершится.

Для оставшихся процессов пользовательского пространства есть другой способ получить привилегию вызывать некоторые ограниченные операции на устройстве DRM, называемом DRM-Auth. По сути, это метод аутентификации устройства DRM, чтобы доказать ему, что процесс имеет одобрение DRM-Master для получения таких привилегий. Процедура состоит из:[12]:13

  • Клиент получает уникальный токен - 32-битное целое число - от устройства DRM, используя GET_MAGIC ioctl и передает его процессу DRM-Master любыми способами (обычно МПК; например, в DRI2 Существует DRI2Authenticate запрос, который любой X-клиент может отправить на X-сервер.[13])
  • Процесс DRM-Master, в свою очередь, отправляет токен обратно на устройство DRM, вызывая AUTH_MAGIC ioctl.
  • Устройство предоставляет специальные права на дескриптор файла процесса, токен аутентификации которого совпадает с токеном, полученным от DRM-Master.

Менеджер исполнения графики

Из-за увеличения размера видеопамять и растущая сложность графических API, таких как OpenGL, стратегия повторной инициализации состояния видеокарты на каждом переключатель контекста было слишком дорого с точки зрения производительности. Также современные Рабочие столы Linux нужен был оптимальный способ поделиться закадровыми буферами с композитор-менеджер. Эти требования привели к разработке новых методов управления графикой. буферы внутри ядра. В Менеджер исполнения графики (GEM) возник как один из таких методов.[6]

GEM предоставляет API с явным управление памятью примитивы.[6] С помощью GEM программа пользовательского пространства может создавать, обрабатывать и уничтожать объекты памяти, находящиеся в видеопамяти графического процессора. Эти объекты, называемые «объектами GEM»,[14] являются постоянными с точки зрения программы пользовательского пространства и не нуждаются в перезагрузке каждый раз, когда программа восстанавливает контроль над графическим процессором. Когда программе пользовательского пространства требуется фрагмент видеопамяти (для хранения кадровый буфер, текстура или любые другие данные, требуемые GPU[15]), он запрашивает выделение для DRM-драйвера с помощью GEM API. Драйвер DRM отслеживает используемую видеопамять и может выполнить запрос, если имеется свободная память, возвращая «дескриптор» пользовательского пространства для дальнейшего обращения к выделенной памяти в предстоящих операциях.[6][14] GEM API также предоставляет операции по заполнению буфера и освобождению его, когда он больше не нужен. Память из невыпущенных дескрипторов GEM восстанавливается, когда процесс пользовательского пространства закрывает устройство DRM. дескриптор файла - намеренно или по причине прекращения действия.[16]

GEM также позволяет два или более пользовательских пространства процессы использование того же устройства DRM (следовательно, того же драйвера DRM) для совместного использования объекта GEM.[16] Дескрипторы GEM - это локальные 32-битные целые числа, уникальные для процесса, но повторяемые в других процессах, поэтому не подходят для совместного использования. Что необходимо, так это глобальное пространство имен, и GEM предоставляет его с помощью глобальных дескрипторов, называемых Имена GEM. Имя GEM относится к одному и только одному объекту GEM, созданному в одном устройстве DRM одним и тем же драйвером DRM с использованием уникального 32-разрядного целое число. GEM обеспечивает операцию мигать для получения имени GEM из дескриптора GEM.[16][12]:16 Затем процесс может передать это имя GEM (32-битное целое число) другому процессу, используя любое МПК механизм доступен.[12]:15 Имя GEM может использоваться процессом-получателем для получения локального дескриптора GEM, указывающего на исходный объект GEM.

К сожалению, использование имен GEM для совместного использования буферов небезопасно.[12]:16[17][18] Вредоносный сторонний процесс, обращающийся к тому же устройству DRM, может попытаться угадать имя GEM буфера, совместно используемого двумя другими процессами, просто путем проверки 32-разрядных целых чисел.[19][18] Как только имя GEM найдено, его содержимое может быть доступно и изменено, что нарушает конфиденциальность и целостность информации буфера. Этот недостаток был преодолен позже путем введения DMA-BUF поддержка в DRM.

Другая важная задача для любой системы управления видеопамятью, помимо управления пространством видеопамяти, - это обработка синхронизации памяти между GPU и CPU. Текущий архитектуры памяти очень сложны и обычно включают различные уровни тайники для системной памяти, а иногда и для видеопамяти. Следовательно, менеджеры видеопамяти также должны обрабатывать согласованность кеша для обеспечения согласованности данных, совместно используемых ЦП и ГП.[20] Это означает, что часто внутреннее управление видеопамятью сильно зависит от аппаратных характеристик графического процессора и архитектуры памяти и, следовательно, зависит от драйвера.[21]

GEM изначально был разработан Intel инженеры предоставили диспетчер видеопамяти для драйвера i915.[20] В Intel GMA 9xx семья встроенные графические процессоры с унифицированной архитектурой памяти (UMA), где графический процессор и процессор совместно используют физическую память, а выделенная видеопамять отсутствует.[22] GEM определяет «домены памяти» для синхронизации памяти, и хотя эти домены памяти не зависят от GPU,[6] они специально разработаны с учетом архитектуры памяти UMA, что делает их менее подходящими для других архитектур памяти, например, с отдельной VRAM. По этой причине другие драйверы DRM решили предоставить программам пользовательского пространства GEM API, но внутри они реализовали другой диспетчер памяти, лучше подходящий для их конкретного оборудования и архитектуры памяти.[23]

GEM API также предоставляет ioctls для управления потоком выполнения (буферы команд), но они специфичны для Intel и предназначены для использования с Intel i915 и более поздними графическими процессорами.[6] Ни один другой драйвер DRM не пытался реализовать какую-либо часть GEM API, кроме специфичных для управления памятью ioctl.

Карты таблиц переводов

Карты таблиц переводов (TTM) - это название универсального менеджера памяти для графических процессоров, который был разработан до GEM.[5][14] Он был специально разработан для управления различными типами памяти, к которой может обращаться графический процессор, включая выделенную Видео RAM (обычно устанавливается в видеокарту) и системная память доступный через Блок управления памятью ввода / вывода называется Таблица преобразования адресов графики (GART).[5] TTM также должен обрабатывать части видеопамяти, которые напрямую не адресуются ЦП, и делать это с максимально возможной производительностью, учитывая, что графические приложения пользовательского пространства обычно работают с большими объемами видеоданных. Еще одним важным вопросом было поддержание согласованности между различными воспоминаниями и задействованными тайниками.

Основная концепция TTM - это «буферные объекты», области видеопамяти, которые в какой-то момент должны быть адресованы графическому процессору.[5] Когда графическому приложению пользовательского пространства требуется доступ к определенному объекту буфера (обычно для заполнения его содержимым), TTM может потребовать переместить его в тип памяти, адресуемой ЦП. Дальнейшие перемещения - или операции сопоставления GART - могут происходить, когда графическому процессору требуется доступ к объекту буфера, но он еще не находится в адресном пространстве графического процессора. Каждая из этих операций перемещения должна обрабатывать любые связанные данные и проблемы с согласованностью кеша.[5]

Еще одна важная концепция ТТМ: заборы. По сути, заборы - это механизм управления параллелизмом между ЦП и ГП.[24] Забор отслеживает, когда объект буфера больше не используется графическим процессором, обычно для уведомления любого процесса пользовательского пространства, имеющего к нему доступ.[5]

Тот факт, что TTM пытался управлять всеми видами архитектур памяти, в том числе с выделенной видеопамятью и без нее, подходящим способом, а также предоставлять все мыслимые функции в диспетчере памяти для использования с любым типом оборудования, привел к чрезмерно сложному решение с API, намного большим, чем необходимо.[24][14] Некоторые разработчики DRM думали, что это не подходит для какого-либо конкретного драйвера, особенно для API. Когда GEM превратился в более простой менеджер памяти, его API был предпочтительнее, чем API TTM. Но некоторые разработчики драйверов посчитали, что подход, принятый TTM, больше подходит для дискретных видеокарт с выделенной видеопамятью и IOMMU, поэтому они решили использовать TTM внутренне, выставляя свои буферные объекты как объекты GEM и, таким образом, поддерживая GEM API.[23] Примерами текущих драйверов, использующих TTM в качестве диспетчера внутренней памяти, но предоставляющих GEM API, являются драйвер Radeon для видеокарт AMD и модерн драйвер для видеокарт NVIDIA.

Совместное использование буфера DMA и PRIME

В API совместного использования буфера DMA (часто сокращенно DMA-BUF) - это Ядро Linux внутренний API разработан, чтобы предоставить общий механизм для обмена DMA буферы на нескольких устройствах, возможно, управляемые разными типами драйверов устройств.[25][26] Например, Video4Linux устройство и устройство графического адаптера могут совместно использовать буферы через DMA-BUF для достижения нулевая копия данных видеопотока, создаваемого первым и потребляемого вторым. Любой Linux драйвер устройства может реализовать этот API как экспортер, как пользователь (потребитель) или как оба.

Эта функция впервые была использована в DRM для реализации PRIME, решения для Разгрузка GPU который использует DMA-BUF для совместного использования результирующих кадровых буферов между драйверами DRM дискретного и интегрированного графического процессора.[27]:13 Важной особенностью DMA-BUF является то, что общий буфер представлен в пользовательском пространстве как дескриптор файла.[14][12]:17 Для разработки PRIME в DRM API были добавлены два новых файла ioctl: один для преобразования локального дескриптора GEM в файловый дескриптор DMA-BUF, а другой - для совершенно противоположной операции.

Эти два новых файла ioctl были позже повторно использованы как способ исправить внутреннюю небезопасность совместного использования буфера GEM.[12]:17 В отличие от имен GEM, файловые дескрипторы невозможно угадать (они не являются глобальным пространством имен), а операционные системы Unix предоставляют безопасный способ их передачи через Доменный сокет Unix используя семантику SCM_RIGHTS.[14][28]:11 Процесс, который хочет поделиться объектом GEM с другим процессом, может преобразовать свой локальный дескриптор GEM в файловый дескриптор DMA-BUF и передать его получателю, который, в свою очередь, может получить свой собственный дескриптор GEM из полученного файлового дескриптора.[12]:16 Этот метод используется DRI3 для совместного использования буферов между клиентом и X-сервером[29] а также Wayland.

Настройка режима ядра

В пользовательском пространстве должен быть «мастер DRM», эта программа имеет эксклюзивный доступ к KMS.

Для правильной работы видеокарта или графический адаптер должны установить Режим - сочетание разрешение экрана, глубина цвета и Частота обновления - то есть в пределах диапазона значений, поддерживаемых им самим и прилагаемым экран монитора. Эта операция называется установка режима,[30] и обычно требуется прямой доступ к графическому оборудованию, т.е. возможность записи в определенные регистры видеокарты.[31][32] Перед началом использования устройства необходимо выполнить настройку режима. кадровый буфер, а также когда режим требуется изменить приложением или пользователем.

Раньше программы пользовательского пространства, которые хотели использовать графический буфер кадра, также отвечали за обеспечение операций по установке режима,[3] и поэтому им нужно было работать с привилегированным доступом к видеооборудованию. В операционных системах типа Unix X сервер был наиболее ярким примером, и его реализация настройки режима жила в Драйвер DDX для каждого конкретного типа видеокарты.[33] Этот подход, позже названный Настройка режима пользовательского пространства или UMS,[34][35] создает несколько проблем.[36][30] Это не только нарушает изоляцию, которую операционные системы должны обеспечивать между программами и оборудованием, вызывая проблемы стабильности и безопасности, но также может оставить графическое оборудование в несогласованном состоянии, если две или более программы пользовательского пространства попытаются установить режим в то же время. Чтобы избежать этих конфликтов, X-сервер стал практически единственной программой пользовательского пространства, которая выполняла операции установки режима; остальные программы пользовательского пространства полагались на X-сервер для установки соответствующего режима и обработки любых других операций, связанных с установкой режима. Первоначально установка режима выполнялась исключительно во время процесса запуска X-сервера, но позже X-сервер получил возможность делать это во время работы.[37] Расширение XFree86-VidModeExtension было представлено в XFree86 3.1.2 разрешить любой запрос X-клиента модельная линия (разрешение) изменяется на X-сервер.[38][39] Расширение VidMode было позже заменено более общим XRandR расширение.

Однако это был не единственный код, устанавливающий режим в Linux система. В процессе загрузки системы ядро ​​Linux должно установить минимальный текстовый режим для виртуальная консоль (на основе стандартных режимов, определенных VESA BIOS расширения).[40] Так же Драйвер фреймбуфера ядра Linux содержал код установки режима для настройки устройств фреймбуфера.[2] Чтобы избежать конфликтов при настройке режима, Сервер XFree86 - а позже Сервер X.Org - обработан случай, когда пользователь перешел из графической среды в текстовую виртуальная консоль сохраняя состояние настройки режима и восстанавливая его, когда пользователь снова переключается на X.[41] Этот процесс вызвал раздражающее мерцание при переходе, а также может дать сбой, что приведет к повреждению или непригодности вывода на дисплее.[42]

Подход к настройке режима пользовательского пространства также вызвал другие проблемы:[43][42]

  • В приостановить / возобновить процесс вынужден полагаться на инструменты пользовательского пространства, чтобы восстановить предыдущий режим. Один единственный сбой или сбой одной из этих программ может оставить систему без рабочего дисплея из-за неправильной конфигурации режима и, следовательно, непригодной для использования.
  • Ядро также не могло отображать сообщения об ошибках или отладочных сообщениях, когда экран был в графическом режиме - например, когда работал X - поскольку ядро ​​знало только стандартные текстовые режимы VESA BIOS.
  • Более насущной проблемой было распространение графических приложений в обход X-сервера и появление других альтернативных графических стеков для X, что еще больше расширило дублирование кода установки режима в системе.

Для решения этих проблем код установки режима был перемещен в одно место внутри ядра, в частности, в существующий модуль DRM.[36][37][44][42][43] Затем каждый процесс, включая X-сервер, должен иметь возможность отдавать команду ядру на выполнение операций по настройке режима, и ядро ​​должно гарантировать, что параллельные операции не приведут к несогласованному состоянию. Новый API ядра и код, добавленный в модуль DRM для выполнения этих операций по настройке режима, назывались Настройка режима ядра (KMS).[30]

Настройка режима ядра дает несколько преимуществ. Самым незамедлительным, конечно же, является удаление повторяющегося кода установки режима как из ядра (консоль Linux, fbdev), так и из пользовательского пространства (драйверы X Server DDX). KMS также упрощает написание альтернативных графических систем, которым теперь не нужно реализовывать собственный код установки режима.[42][43] Предоставляя централизованное управление режимами, KMS решает проблемы мерцания при переключении между консолью и X, а также между различными экземплярами X (быстрое переключение пользователей).[41][44] Поскольку он доступен в ядре, его также можно использовать в начале процесса загрузки, сохраняя мерцание из-за изменений режима на этих ранних этапах.

Тот факт, что KMS является частью ядра, позволяет ему использовать ресурсы, доступные только в пространстве ядра, такие как прерывает.[45] Например, восстановление режима после приостановки / возобновления процесса значительно упрощается за счет управления самим ядром и, в частности, повышает безопасность (больше нет инструментов пользовательского пространства, требующих прав root). Ядро также позволяет горячая вилка новых устройств отображения легко, решая давнюю проблему.[45] Настройка режима также тесно связана с управлением памятью, поскольку фреймбуферы в основном являются буферами памяти, поэтому настоятельно рекомендуется тесная интеграция с менеджером графической памяти. Это основная причина, по которой код настройки режима ядра был включен в DRM, а не как отдельная подсистема.[44]

Чтобы избежать нарушения обратной совместимости DRM API, настройка режима ядра предоставляется в качестве дополнительного функция драйвера некоторых драйверов DRM.[46] Любой драйвер DRM может предоставить DRIVER_MODESET при регистрации в ядре DRM, чтобы указать, что поддерживает KMS API.[8] Те драйверы, которые реализуют настройку режима ядра, часто называют Драйверы KMS как способ отличить их от устаревших - без KMS - драйверов DRM.

KMS был принят до такой степени, что некоторые драйверы, в которых отсутствует 3D-ускорение (или для которых поставщик оборудования не хочет предоставлять или реализовывать его), тем не менее, реализуют KMS API без остального DRM API.

Модель устройства KMS

KMS моделирует устройства вывода и управляет ими как серию абстрактных аппаратных блоков, которые обычно встречаются в конвейере вывода дисплея контроллер дисплея. Эти блоки:[47]

  • CRTC: каждый CRTC (от ЭЛТ Контроллер[48][33]) представляет собой модуль сканирования контроллера дисплея, указывающий на буфер сканирования (кадровый буфер ).[47] Целью CRTC является считывание пиксельных данных, находящихся в данный момент в буфере сканирования, и генерация из них сигнал синхронизации видеорежима с помощью Схема ФАПЧ.[49] Количество доступных CRTC определяет, сколько независимых устройств вывода может обрабатывать оборудование одновременно, поэтому для использования многоголовый конфигурации требуется по крайней мере один CRTC для каждого устройства отображения.[47] Два или более CRTC также могут работать в режим клонирования если они сканируют из одного и того же фреймбуфера, чтобы отправить одно и то же изображение на несколько устройств вывода.[49][48]
  • Разъемы: коннектор представляет, куда контроллер дисплея отправляет видеосигнал от операции сканирования для отображения. Обычно понятие соединителя в KMS соответствует физическому соединителю (VGA, DVI, FPD-Link, HDMI, DisplayPort, S-Video ...) в оборудовании, где устройство вывода (монитор, ноутбук панель, ...) постоянно или временно. Информация, относящаяся к текущему физически подключенному устройству вывода, например, состояние подключения, EDID данные, DPMS состояние или поддерживаемые режимы видео - также хранятся в разъеме.[47]
  • Энкодеры: контроллер дисплея должен кодировать синхронизирующий сигнал видеорежима от CRTC, используя формат, подходящий для предполагаемого разъема.[47] Кодировщик представляет собой аппаратный блок, способный выполнять одно из этих кодировок. Примеры кодирования для цифровых выходов: TMDS и LVDS; для аналоговых выходов, таких как VGA и ТВ-выход, специфический ЦАП блоки обычно используются. Разъем может принимать сигнал только от одного кодировщика за раз,[47] и каждый тип коннектора поддерживает только некоторые кодировки. Также могут быть дополнительные физические ограничения, в соответствии с которыми не каждый CRTC подключен ко всем доступным кодировщикам, ограничивая возможные комбинации CRTC-кодировщик-разъем.
  • Самолеты: плоскость - это не аппаратный блок, а объект памяти, содержащий буфер, из которого загружается механизм сканирования (CRTC). Самолет, на котором кадровый буфер называется первичная плоскость, и каждый CRTC должен иметь один связанный,[47] поскольку это источник для CRTC для определения видеорежима - разрешение дисплея (ширина и высота), размер пикселя, формат пикселя, частота обновления и т. д. CRTC может также иметь плоскости курсора связан с ним, если контроллер дисплея поддерживает аппаратные наложения курсора, или второстепенные самолеты если он может сканировать из дополнительных аппаратные накладки и компоновка или смешивание «на лету» окончательного изображения, отправляемого на устройство вывода.[33]

Атомный дисплей

В последние годы предпринимаются постоянные усилия по обеспечению атомарность к некоторым регулярным операциям, относящимся к KMS API, в частности к установка режима и листание страницы операции.[33][50] Этот усовершенствованный KMS API называется Атомный дисплей (ранее известный как установка атомарного режима и атомный или же ядерный pageflip).

Цель установка атомарного режима заключается в обеспечении правильного изменения режима в сложных конфигурациях с множеством ограничений, избегая промежуточных шагов, которые могут привести к несогласованному или недопустимому состоянию видео;[50] это также позволяет избежать рискованных состояний видео, когда необходимо отменить неудачный процесс установки режима («откат»).[51]:9 Атомарная настройка режима позволяет заранее узнать, подходит ли конкретная конфигурация режима, предоставляя возможности тестирования режима.[50] Когда атомарный режим протестирован и его валидность подтверждена, его можно применять с одним неделимым (атомарным) совершить операция. Обе операции тестирования и фиксации предоставляются одним и тем же новым ioctl с разными флагами.

Атомарный переворот страницы с другой стороны, позволяет обновлять несколько плоскостей на одном и том же выходе (например, первичную плоскость, плоскость курсора и, возможно, некоторые наложения или вторичные плоскости), все синхронизированные в одном и том же VBLANK интервал, обеспечивающий надлежащее отображение без разрывов.[51]:9,14[50] Это требование особенно актуально для мобильных и встроенных контроллеров дисплея, которые обычно используют несколько плоскостей / наложений для экономии энергии.

Новый атомарный API построен на старом KMS API. Он использует ту же модель и объекты (CRTC, кодировщики, соединители, плоскости и т. Д.), Но с увеличивающимся числом свойств объекта, которые можно изменять.[50] Атомарная процедура основана на изменении соответствующих свойств для создания состояния, которое мы хотим протестировать или зафиксировать. Свойства, которые мы хотим изменить, зависят от того, хотим ли мы выполнить настройку режима (в основном CRTC, свойства кодировщиков и соединителей) или переворачивание страницы (обычно свойства плоскостей). Ioctl одинаков для обоих случаев, разница заключается в списке свойств, передаваемых с каждым из них.[52]

Узлы рендеринга

В исходном API DRM устройство DRM / dev / дри / картаИкс используется как для привилегированных (установка режима, другое управление отображением), так и для непривилегированных (рендеринг, ГПГПУ вычислить) операции.[9] По соображениям безопасности открытие связанного файла устройства DRM требует особых привилегий, «эквивалентных привилегиям root».[53] Это приводит к архитектуре, в которой только некоторые надежные программы пользовательского пространства (X-сервер, графический редактор ...) имеют полный доступ к DRM API, включая привилегированные части, такие как API набора режимов. Остальные приложения пользовательского пространства, которые хотят отображать или производить вычисления GPGPU, должны быть предоставлены владельцем устройства DRM («DRM Master») посредством использования специального интерфейса аутентификации.[54] Затем аутентифицированные приложения могут отображать или производить вычисления с использованием ограниченной версии API DRM без привилегированных операций. Этот дизайн налагает серьезное ограничение: всегда должен быть работающий графический сервер (X-сервер, композитор Wayland, ...), действующий как DRM-Master устройства DRM, чтобы другим программам пользовательского пространства можно было разрешить использование устройства, даже в случаях, когда графический дисплей не используется, например, вычисления GPGPU.[53][54]

Концепция «узлов рендеринга» пытается решить эти сценарии путем разделения API пространства пользователя DRM на два интерфейса - один привилегированный и один непривилегированный - и используя отдельные файлы устройств (или «узлы») для каждого из них.[9] Для каждого найденного графического процессора соответствующий драйвер DRM - если он поддерживает функцию узлов рендеринга - создает файл устройства. / dev / dri / renderDИкс, называется узел рендеринга, в дополнение к основному узлу / dev / дри / картаИкс.[54][9] Клиенты, использующие модель прямого рендеринга и приложения, которые хотят воспользоваться вычислительными возможностями графического процессора, могут сделать это без дополнительных привилегий, просто открыв любой существующий узел рендеринга и отправив операции графического процессора с использованием ограниченного подмножества DRM API, поддерживаемого эти узлы - при условии, что они разрешения файловой системы , чтобы открыть файл устройства. Серверы отображения, композиторы и любая другая программа, для которой требуется API набора мод или любая другая привилегированная операция, должны открыть стандартный основной узел, который предоставляет доступ к полному API DRM, и использовать его как обычно. Узлы рендеринга явно запрещают GEM мигать операция по предотвращению совместного использования буфера с использованием небезопасных глобальных имен GEM; только PRIME (DMA-BUF) файловые дескрипторы может использоваться для совместного использования буферов с другим клиентом, включая графический сервер.[9][54]

Поддержка оборудования

DRM должен использоваться драйвером графического устройства пользовательского режима, например AMD Catalyst или же Меса 3D. Программы пользовательского пространства используют Интерфейс системного вызова Linux для доступа к DRM. DRM дополняет интерфейс системных вызовов Linux собственными системными вызовами.[55]

Подсистема Linux DRM включает бесплатно и с открытым исходным кодом драйверы для поддержки оборудования от 3 основных производителей графических процессоров для настольных компьютеров (AMD, NVIDIA и Intel), а также от растущего числа мобильных графических процессоров и Система на микросхеме (SoC) интеграторы. Качество каждого драйвера сильно различается в зависимости от степени сотрудничества производителя и других вопросов.

Драйверы DRM
ВодительПоскольку ядроПоддерживаемое оборудованиеПоддержка поставщикаСтатус / Примечания
radeon2.4.1AMD (ранее ATi) Radeon Серия графических процессоров с архитектурами TeraScale и GCN 1-й & 2-е поколение. Включая модели из R100 /200 /300 /400, Radeon X1000, HD 2000 /4000 /5000 /6000 /7000 /8000, R5 / R7 / R9 200 /300 серии и Кавери ВСУ.даАктивный
i9152.6.9Intel GMA Чипсеты 830M, 845G, 852GM, 855GM, 865G, 915G, 945G, 965G, G35, G41, G43, G45. Intel HD и графика Iris Встроенные графические процессоры HD Graphics 2000/3000/2500/4000/4200/4400/4600 / P4600 / P4700 / 5000, Iris Graphics 5100, Iris Pro Graphics 5200.даАктивный
модерн2.6.33[56][57]NVIDIA Тесла, Ферми, Кеплер, Максвелл основан GeForce Графические процессоры, Тегра К1, X1 SoCЧастичноеАктивный
Exynos3.2[58]Samsung SoC Exynos на базе ARM
vmwgfx3,2 (от постановки)[59]Виртуальный графический процессор для VMware SVGA2виртуальный водитель
gma5003.3 (от постановки)[60][61]Intel GMA 500 и другие Воображение Технологии (PowerVR ) на основе графических процессоровэкспериментальный 2D-драйвер KMS
аст3.5[62]ASpeed ​​Technologies 2000 серииэкспериментальный
мгаг2003.5[63]Matrox Серверные дисплеи MGA-G200Только KMS
шмобиль3.7[64]Renesas SH Mobile
тегра3.8[65]Nvidia Тегра 20, SoC Tegra30даАктивный
omapdrm3.9[66]Инструменты Техаса OMAP 5 SoC
rcar-du3.11[67]Renesas Блоки отображения R-Car SoC
мсм3.12[68][69]Qualcomm с Адрено Семейства графических процессоров A2xx / A3xx / A4xx (Львиный зев SOC)[70]
армада3.13[71][72]Марвелл Armada 510 SoC
Bochs3.14[73]Виртуальный VGA карты с использованием Bochs интерфейс dispi vga (например, QEMU stdvga)виртуальный водитель
sti3.17[74][75]STMicroelectronics SoC серии stiH41x
imx3,19 (от постановки)[76][77]Freescale i.MX SoC
рокчип3.19[76][78]Rockchip GPU на базе SoCТолько KMS
amdgpu[55]4.2[79][80]AMD Radeon Серия графических процессоров с архитектурами GCN 3-й & 4-е поколение. Включая модели от Radeon Rx 200 /300 /400 /500[81] серии и Карризо и Бристоль и Стоуни-Ридж ВСУ.даАктивный
virtio4.2[82]драйвер виртуального графического процессора для QEMU менеджеры виртуальных машин (например, KVM или же Xen )виртуальный водитель
vc44.4[83][84][85]Raspberry Pi с Broadcom BCM2835 и BCM2836 SoC (VideoCore IV ГПУ)
этнавив4.5[86][87][88]Виванте Ядра графического процессора найдены в нескольких SoC, таких как Марвелл ARMADA и Freescale i.MX6 серии
sun4i4.7[89][90]Allwinner SoC (ARM Мали-400 GPU)
кирин4.7[91][90]HiSilicon Кирин hi6220 SoC (ARM Мали 450-MP4 GPU)
mediatek4.7[92][90]MediaTek MT8173 SoC (Воображение PowerVR GX6250 GPU)
hibmc4.10[93]HiSilicon hi1710 Huawei iBMC SoC (Кремниевое изображение Ядро графического процессора SM750[94])Только KMS
Лима5.2[95]ARM Мали Графические процессоры 4xx
жаровня5.2[96]Графические процессоры ARM Mali Txxx (Midgard) и Gxx (Bifrost)

Существует также ряд драйверов для старого устаревшего оборудования, которые подробно описаны в следующей таблице для исторических целей. Некоторые из них все еще остались в коде ядра, а другие уже удалены.

Исторические драйверы DRM
ВодительПоскольку ядроПоддерживаемое оборудованиеСтатус / Примечания
гамма2.3.183Dlabs GLINT GMX 2000Удалено с 2.6.14[97]
ffb2.4Creator / Creator3D (используется Sun Microsystems Ультра рабочие станции)Удалено с 2.6.21[98]
tdfx2.43dfx Банши /Voodoo3 +
mga2.4Matrox G200 /G400 / G450
r1282.4ATI Rage 128
i8102.4Intel i810
сестренка2.4.17SiS 300 /630/540
i8302.4.20Intel 830M / 845G / 852GM / 855GM / 865GУдалено с 2.6.39[99] (заменен драйвером i915)
через2.6.13[100]ЧЕРЕЗ Унихром / Unichrome Pro
дикий2.6.14[101]S3 Графика дикий 3D / MX / IX / 4 / SuperSavage / Pro / Твистер

Разработка

Менеджер прямого рендеринга разработан в рамках Ядро Linux, и это исходный код проживает в / драйверы / GPU / DRM каталог исходного кода Linux. Сопровождающим подсистемы является Дэйв Эрли, а другие сопровождающие заботятся о конкретных драйверах.[102] Как обычно при разработке ядра Linux, субмастерны DRM и участники присылают свои патчи с новыми функциями и ошибка исправления основного сопровождающего DRM, который интегрирует их в свой собственный Linux хранилище. Сопровождающий DRM, в свою очередь, отправляет все эти исправления, которые готовы к использованию в Линус Торвальдс всякий раз, когда будет выпущена новая версия Linux. Торвальдс, как главный сопровождающий всего ядра, держит последнее слово за то, подходит ли патч для включения в ядро.

По историческим причинам исходный код библиотеки libdrm поддерживается под эгидой Меса проект.[103]

История

In 1999, while developing DRI за XFree86, Precision Insight created the first version of DRM for the 3dfx video cards, as a Ядро Linux пластырь included within the Меса исходный код.[104] Later that year, the DRM code was mainlined in Linux kernel 2.3.18 under the /drivers/char/drm/ directory for character devices.[105] During the following years the number of supported video cards grew. When Linux 2.4.0 was released in January 2001 there was already support for Creative Labs GMX 2000, Intel i810, Matrox G200/G400 and ATI Rage 128, in addition to 3dfx Voodoo3 cards,[106] and that list expanded during the 2.4.x series, with drivers for ATI Radeon cards, some SiS video cards and Intel 830M and subsequent integrated GPUs.

The split of DRM into two components, DRM core and DRM driver, called DRM core/personality split was done during the second half of 2004,[11][107] and merged into kernel version 2.6.11.[108] This split allowed multiple DRM drivers for multiple devices to work simultaneously, opening the way to multi-GPU support.

The idea of putting all the video mode setting code in one place inside the kernel had been acknowledged for years,[109][110] but the graphics card manufacturers had argued that the only way to do the mode-setting was to use the routines provided by themselves and contained in the Видео BIOS of each graphics card. Such code had to be executed using x86 реальный режим, which prevented it from being invoked by a kernel running in protected mode.[44] The situation changed when Luc Verhaegen and other developers found a way to do the mode-setting natively instead of BIOS-based,[111][44] showing that it was possible to do it using normal kernel code and laying the groundwork for what would become Kernel Mode Setting. In May 2007 Jesse Barnes (Intel ) published the first proposal for a drm-modesetting API and a working native implementation of mode-setting for Intel GPUs within the i915 DRM driver.[42] In December 2007 Jerome Glisse started to add the native mode-setting code for ATI cards to the radeon DRM driver.[112][113] Work on both the API and drivers continued during 2008, but got delayed by the necessity of a memory manager also in kernel space to handle the framebuffers.[114]

In October 2008 the Linux kernel 2.6.27 brought a major исходный код reorganization, prior to some significant upcoming changes. The DRM source code tree was moved to its own source directory /drivers/gpu/drm/ and the different drivers were moved into their own subdirectories. Headers were also moved into a new /include/drm каталог.[115]

The increasing complexity of video memory management led to several approaches to solving this issue. Первая попытка была Translation Table Maps (TTM) memory manager, developed by Thomas Hellstrom (Tungsten Graphics ) in collaboration with Eric Anholt (Intel) and Dave Airlie (Красная шляпа ).[5] TTM was proposed for inclusion into mainline kernel 2.6.25 in November 2007,[5] and again in May 2008, but was ditched in favor of a new approach called Graphics Execution Manager (GEM).[24] GEM was first developed by Keith Packard and Eric Anholt from Intel as simpler solution for memory management for their i915 driver.[6] GEM was well received and merged into the Linux kernel version 2.6.28 released in December 2008.[116] Meanwhile, TTM had to wait until September 2009 to be finally merged into Linux 2.6.31 as a requirement of the new Radeon KMS DRM driver.[117]

With memory management in place to handle buffer objects, DRM developers could finally add to the kernel the already finished API and code to do установка режима. This expanded API is what is called Kernel Mode-setting (KMS) and the drivers which implement it are often referred to as KMS drivers. In March 2009, KMS was merged into the Linux kernel version 2.6.29,[30][118] along with KMS support for the i915 driver.[119] The KMS API have been exposed to user space programs since libdrm 2.4.3.[120] The userspace X.Org DDX driver for Intel graphics cards was also the first to use the new GEM and KMS APIs.[121] KMS support for the radeon DRM driver was added to Linux 2.6.31 release of September 2009.[122][123][124] The new radeon KMS driver used the TTM memory manager but exposed GEM-compatible interfaces and ioctls instead of TTM ones.[23]

С 2006 г. nouveau project had been developing a бесплатно программное обеспечение DRM driver for NVIDIA GPUs outside of the official Linux kernel. In 2010 the nouveau source code was merged into Linux 2.6.33 as an experimental driver.[56][57] At the time of merging, the driver had been already converted to KMS, and behind the GEM API it used TTM as its memory manager.[125]

The new KMS API—including the GEM API—was a big milestone in the development of DRM, but it didn't stop the API for being enhanced in the following years. KMS gained support for page flips in conjunction with asyncronous VBLANK notifications in Linux 2.6.33[126][127]—only for the i915 driver, radeon and nouveau added it later during Linux 2.6.38 release.[128] The new page flip interface was added to libdrm 2.4.17.[129] In early 2011, during the Linux 2.6.39 release cycle, the so-called dumb buffers—a hardware-independent non-accelerated way to handle simple buffers suitable for use as framebuffers—were added to the KMS API.[130][131] The goal was to reduce the complexity of applications such as Плимут that don't need to use special accelerated operations provided by driver-specific ioctls.[132] The feature was exposed by libdrm from version 2.4.25 onwards.[133] Later that year it also gained a new main type of objects, called самолеты. Planes were developed to represent hardware overlays supported by the scanout engine.[134][135] Plane support was merged into Linux 3.3.[136] and libdrm 2.4.30. Another concept added to the API—during Linux 3.5[137] and libdrm 2.4.36[138] releases—were generic object properties, a method to add generic values to any KMS object. Properties are specially useful to set special behaviour or features to objects such as CRTCs and planes.

An early proof of concept to provide GPU offloading between DRM drivers was developed by Dave Airlie in 2010.[7][139] Since Airlie was trying to mimic the NVIDIA Optimus technology, he decided to name it "PRIME".[7] Airlie resumed his work on PRIME in late 2011, but based on the new DMA-BUF buffer sharing mechanism introduced by Linux kernel 3.3.[140] The basic DMA-BUF PRIME infrastructure was finished in March 2012[141] and merged into the Linux 3.4 release,[142][143][144] as well as into libdrm 2.4.34.[145] Later during the Linux 3.5 release, several DRM drivers implemented PRIME support, including i915 for Intel cards, radeon for AMD cards and nouveau for NVIDIA cards.[146][147]

In recent years, the DRM API has incrementally expanded with new and improved features. In 2013, as part of GSoC, David Herrmann developed the multiple render nodes особенность.[53] His code was added to the Linux kernel version 3.12 as an experimental feature[148][149] supported by i915,[150] radeon[151] and nouveau[152] drivers, and enabled by default since Linux 3.17.[75] In 2014 Matt Roper (Intel) developed the universal planes (или же unified planes) concept by which framebuffers (primary planes), overlays (secondary planes) and cursors (cursor planes) are all treated as a single type of object with an unified API.[153] Universal planes support provides a more consistent DRM API with fewer, more generic ioctls.[33] In order to maintain the API обратно совместимый, the feature is exposed by DRM core as an additional capability that a DRM driver can provide. Universal plane support debuted in Linux 3.15[154] and libdrm 2.4.55.[155] Several drivers, such as the Intel i915,[156] have already implemented it.

The most recent DRM API enhancement is the atomic mode-setting API, which brings атомарность to the mode-setting and page flipping operations on a DRM device. The idea of an atomic API for mode-setting was first proposed in early 2012.[157] Ville Syrjälä (Intel) took over the task of designing and implementing such atomic API.[158] Based on his work, Rob Clark (Инструменты Техаса ) took a similar approach aiming to implement atomic page flips.[159] Later in 2013 both proposed features were reunited in a single one using a single ioctl for both tasks.[160] Since it was a requirement, the feature had to wait for the support of universal planes to be merged in mid-2014.[156] During the second half of 2014 the atomic code was greatly enhanced by Daniel Vetter (Intel) and other DRM developers[161]:18 in order to facilitate the transition for the existing KMS drivers to the new atomic framework.[162] All of this work was finally merged into Linux 3.19[163] and Linux 4.0[164][165][166] releases, and enabled by default since Linux 4.2.[167] libdrm exposed the new atomic API since version 2.4.62.[168] Multiple drivers have already been converted to the new atomic API.[169] By 2018 ten new DRM drivers based on this new atomic model had been added to the Linux kernel.[170]

Принятие

The Direct Rendering Manager kernel subsystem was initially developed to be used with the new Инфраструктура прямого рендеринга из XFree86 4.0 display server, later inherited by its successor, the Сервер X.Org. Therefore, the main users of DRM were DRI clients that link to the hardware-accelerated OpenGL implementation that lives in the Меса 3D library, as well as the X Server itself. Nowadays DRM is also used by several Композиторы Wayland, включая Вестон reference compositor. кмскон is a virtual console implementation that runs in user space using DRM KMS facilities.[171]

In 2015, version 358.09 (beta) of the proprietary Nvidia GeForce driver received support for the DRM mode-setting interface implemented as a new kernel blob called nvidia-modeset.ko. This new driver component works in conjunction with the nvidia.ko kernel module to program the display engine (i.e. display controller) of the GPU.[172]

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

Рекомендации

  1. ^ "Linux kernel/drivers/gpu/drm/README.drm". kernel.org. Архивировано из оригинал on 2014-02-26. Получено 2014-02-26.
  2. ^ а б Uytterhoeven, Geert. "The Frame Buffer Device". Kernel.org. Получено 28 января 2015.
  3. ^ а б c White, Thomas. "How DRI and DRM Work". Получено 22 июля 2014.
  4. ^ Faith, Rickard E. (11 May 1999). "The Direct Rendering Manager: Kernel Support for the Direct Rendering Infrastructure". Получено 12 мая 2016.
  5. ^ а б c d е ж грамм час Corbet, Jonathan (6 November 2007). "Memory management for graphics processors". LWN.net. Получено 23 июля 2014.
  6. ^ а б c d е ж грамм Packard, Keith; Anholt, Eric (13 May 2008). "GEM - the Graphics Execution Manager". dri-devel mailing list. Получено 23 июля 2014.
  7. ^ а б c Airlie, Dave (12 March 2010). "GPU offloading - PRIME - proof of concept". Архивировано из оригинал 10 февраля 2015 г.. Получено 10 февраля 2015.
  8. ^ а б c d е Kitching, Simon. "DRM and KMS kernel modules". Получено 13 мая 2016.
  9. ^ а б c d е Herrmann, David (1 September 2013). "Splitting DRM and KMS device nodes". Получено 23 июля 2014.
  10. ^ "README.rst - mesa/drm - Direct Rendering Manager headers and kernel modules". 2020-03-21. Архивировано из оригинал на 2020-03-21.
  11. ^ а б Airlie, Dave (4 September 2004). "New proposed DRM interface design". dri-devel (Список рассылки).
  12. ^ а б c d е ж грамм Peres, Martin; Ravier, Timothée (2 February 2013). "DRI-next/DRM2: A walkthrough the Linux Graphics stack and its security" (PDF). Получено 13 мая 2016.
  13. ^ Høgsberg, Kristian (4 September 2008). "The DRI2 Extension - Version 2.0". X.Org. Получено 23 мая 2016.
  14. ^ а б c d е ж Barnes, Jesse; Pinchart, Laurent; Vetter, Daniel; Wunner, Lukas. "Linux GPU Driver Developer's Guide - Memory management". Получено 31 августа 2016.
  15. ^ Vetter, Daniel. "i915/GEM Crashcourse by Daniel Vetter". Центр технологий открытого исходного кода Intel. Получено 31 января 2015. GEM essentially deals with graphics buffer objects (which can contain textures, renderbuffers, shaders, or all kinds of other state objects and data used by the gpu)
  16. ^ а б c Vetter, Daniel (4 May 2011). "GEM Overview". Получено 13 февраля 2015.
  17. ^ Packard, Keith (28 September 2012). "Thoughts about DRI.Next". Получено 26 мая 2016. GEM flink has lots of issues. The flink names are global, allowing anyone with access to the device to access the flink data contents.
  18. ^ а б Herrmann, David (2 July 2013). "DRM Security". The 2013 X.Org Developer's Conference (XDC2013) Proceedings. Получено 13 февраля 2015. gem-flink doesn't provide any private namespaces to applications and servers. Instead, only one global namespace is provided per DRM node. Malicious authenticated applications can attack other clients via brute-force "name-guessing" of gem buffers
  19. ^ Kerrisk, Michael (25 September 2012). "XDC2012: Graphics stack security". LWN.net. Получено 25 ноября 2015.
  20. ^ а б Packard, Keith (4 July 2008). "gem update". Получено 25 апреля 2016.
  21. ^ "drm-memory man page". Ubuntu manuals. Получено 29 января 2015. Many modern high-end GPUs come with their own memory managers. They even include several different caches that need to be synchronized during access. [...] . Therefore, memory management on GPUs is highly driver- and hardware-dependent.
  22. ^ "Intel Graphics Media Accelerator Developer's Guide". Корпорация Intel. Получено 24 ноября 2015.
  23. ^ а б c Larabel, Michael (26 August 2008). "A GEM-ified TTM Manager For Radeon". Фороникс. Получено 24 апреля 2016.
  24. ^ а б c Corbet, Jonathan (28 May 2008). "GEM v. TTM". LWN.net. Получено 10 февраля 2015.
  25. ^ Corbet, Jonathan (11 January 2012). "DMA buffer sharing in 3.3". LWN.net. Получено 14 мая 2016.
  26. ^ Clark, Rob; Semwal, Sumit. "DMA Buffer Sharing Framework: An Introduction" (PDF). Получено 14 мая 2016.
  27. ^ Peres, Martin (26 September 2014). "The Linux graphics stack, Optimus and the Nouveau driver" (PDF). Получено 14 мая 2016.
  28. ^ Pinchart, Laurent (20 February 2013). "Anatomy of an Embedded KMS Driver" (PDF). Получено 27 июн 2016.
  29. ^ Edge, Jake (9 October 2013). "DRI3 and Present". LWN.net. Получено 28 мая 2016.
  30. ^ а б c d "Linux 2.6.29 - Kernel Modesetting". Linux Kernel Newbies. Получено 19 ноября 2015.
  31. ^ "VGA Hardware". OSDev.org. Получено 23 ноября 2015.
  32. ^ Rathmann, B. (15 February 2008). "The state of Nouveau, part I". LWN.net. Получено 23 ноября 2015. Graphics cards are programmed in numerous ways, but most initialization and mode setting is done via memory-mapped IO. This is just a set of registers accessible to the CPU via its standard memory address space. The registers in this address space are split up into ranges dealing with various features of the graphics card such as mode setup, output control, or clock configuration.
  33. ^ а б c d е Paalanen, Pekka (5 June 2014). "From pre-history to beyond the global thermonuclear war". Получено 29 июля 2014.
  34. ^ "drm-kms man page". Ubuntu manuals. Получено 19 ноября 2015.
  35. ^ Corbet, Jonathan (13 January 2010). "The end of user-space mode setting?". LWN.net. Получено 20 ноября 2015.
  36. ^ а б "Mode Setting Design Discussion". X.Org Wiki. Получено 19 ноября 2015.
  37. ^ а б Corbet, Jonathan (22 January 2007). "LCA: Updates on the X Window System". LWN.net. Получено 23 ноября 2015.
  38. ^ "XF86VIDMODE manual page". X.Org. Получено 23 апреля 2016.
  39. ^ "X11R6.1 Release Notes". X.Org. 14 марта 1996 г.. Получено 23 апреля 2016.
  40. ^ Corbet, Jonathan (20 July 2004). "Kernel Summit: Video Drivers". LWN.net. Получено 23 ноября 2015.
  41. ^ а б "Fedora - Features/KernelModeSetting". Fedora Project. Получено 20 ноября 2015. Historically, the X server was responsible for saving output state when it started up, and then restoring it when it switched back to text mode. Fast user switching was accomplished with a VT switch, so switching away from the first user's X server would blink once to go to text mode, then immediately blink again to go to the second user's session.
  42. ^ а б c d е Barnes, Jesse (17 May 2007). "[RFC] enhancing the kernel's graphics subsystem". Linux-ядро (Список рассылки).
  43. ^ а б c "DrmModesetting - Enhancing kernel graphics". DRI Wiki. Получено 23 ноября 2015.
  44. ^ а б c d е Packard, Keith (16 September 2007). "kernel-mode-drivers". Получено 30 апреля 2016.
  45. ^ а б Packard, Keith (24 April 2000). "Sharpening the Intel Driver Focus". Получено 23 мая 2016. A more subtle limitation is that the driver couldn't handle interrupts, so there wasn't any hot-plug monitor support.
  46. ^ Barnes, Jesse; Pinchart, Laurent; Vetter, Daniel; Wunner, Lukas. "Linux GPU Driver Developer's Guide - Driver Initialization". Получено 31 августа 2016.
  47. ^ а б c d е ж грамм Barnes, Jesse; Pinchart, Laurent; Vetter, Daniel; Wunner, Lukas. "Linux GPU Driver Developer's Guide - KMS Initialization and Cleanup". Получено 31 августа 2016.
  48. ^ а б "Video Cards". X.Org Wiki. Получено 11 апреля 2016.
  49. ^ а б Deucher, Alex (15 April 2010). "Notes about radeon display hardware". Архивировано из оригинал 5 апреля 2016 г.. Получено 8 апреля 2016.
  50. ^ а б c d е Vetter, Daniel (5 August 2015). "Atomic mode setting design overview, part 1". LWN.net. Получено 7 мая 2016.
  51. ^ а б Reding, Thierry (1 February 2015). "Atomic Mode-Setting" (PDF). FOSDEM Archives. Получено 7 мая 2016.
  52. ^ Vetter, Daniel (12 August 2015). "Atomic mode setting design overview, part 2". LWN.net. Получено 7 мая 2016.
  53. ^ а б c Herrmann, David (29 May 2013). "DRM Render- and Modeset-Nodes". Получено 21 июля 2014.
  54. ^ а б c d Barnes, Jesse; Pinchart, Laurent; Vetter, Daniel; Wunner, Lukas. "Linux GPU Driver Developer's Guide - Render nodes". Получено 31 августа 2016.
  55. ^ а б Deucher, Alex (20 April 2015). "Initial amdgpu driver release". dri-devel (Список рассылки).
  56. ^ а б "Linux 2.6.33 - Nouveau, a driver for Nvidia graphic cards". Linux Kernel Newbies. Получено 26 апреля 2016.
  57. ^ а б "drm/nouveau: Add DRM driver for NVIDIA GPUs". Kernel.org. Получено 27 января 2015.
  58. ^ "DRM: add DRM Driver for Samsung SoC EXYNOS4210". Kernel.org. Получено 3 марта 2016.
  59. ^ "vmwgfx: Take the driver out of staging". Kernel.org. Получено 3 марта 2016.
  60. ^ "Linux 3.3 - DriverArch - Graphics". Linux Kernel Newbies. Получено 3 марта 2016.
  61. ^ Larabel, Michael (10 January 2012). "The Linux 3.3 DRM Pull Is Heavy On Enhancements". Фороникс. Получено 3 марта 2016.
  62. ^ "drm: Initial KMS driver for AST (ASpeed Technologies) 2000 series (v2)". Kernel.org. Получено 3 марта 2016.
  63. ^ Airlie, Dave (17 May 2012). "mgag200: initial g200se driver (v2)". Получено 24 января 2018.
  64. ^ "drm: Renesas SH Mobile DRM driver". Kernel.org. Получено 3 марта 2016.
  65. ^ "drm: Add NVIDIA Tegra20 support". Kernel.org. Получено 3 марта 2016.
  66. ^ "drm/omap: move out of staging". Kernel.org. Получено 3 марта 2016.
  67. ^ "drm: Renesas R-Car Display Unit DRM driver". Kernel.org. Получено 3 марта 2016.
  68. ^ "drm/msm: basic KMS driver for snapdragon". Kernel.org. Получено 3 марта 2016.
  69. ^ Larabel, Michael (28 August 2013). "Snapdragon DRM/KMS Driver Merged For Linux 3.12". Фороникс. Получено 26 января 2015.
  70. ^ Edge, Jake (8 April 2015). "Обновление графического драйвера freedreno". LWN.net. Получено 23 апреля 2015.
  71. ^ King, Russell (18 October 2013). "[GIT PULL] Armada DRM support". dri-devel (Список рассылки).
  72. ^ "DRM: Armada: Add Armada DRM driver". Kernel.org. Получено 3 марта 2016.
  73. ^ "drm/bochs: new driver". Kernel.org. Получено 3 марта 2016.
  74. ^ Larabel, Michael (8 August 2014). "Linux 3.17 DRM Pull Brings New Graphics Driver". Фороникс. Получено 3 марта 2016.
  75. ^ а б Corbet, Jonathan (13 August 2014). "3.17 merge window, part 2". LWN.net. Получено 7 октября 2014.
  76. ^ а б Corbet, Jonathan (17 December 2014). "3.19 Merge window part 2". LWN.net. Получено 9 февраля 2015.
  77. ^ "drm: imx: Move imx-drm driver out of staging". Kernel.org. Получено 9 февраля 2015.
  78. ^ "drm: rockchip: Add basic drm driver". Kernel.org. Получено 3 марта 2016.
  79. ^ Larabel, Michael (25 June 2015). "Linux 4.2 DRM Updates: Lots Of AMD Attention, No Nouveau Driver Changes". Фороникс. Получено 31 августа 2015.
  80. ^ Corbet, Jonathan (1 July 2015). "4.2 Merge window part 2". LWN.net. Получено 31 августа 2015.
  81. ^ Deucher, Alex (3 August 2015). "[PATCH 00/11] Add Fiji Support". dri-devel (Список рассылки).
  82. ^ "Add virtio gpu driver". Kernel.org. Получено 3 марта 2016.
  83. ^ Corbet, Jonathan (11 November 2015). "4.4 Merge window, part 1". LWN.net. Получено 11 января 2016.
  84. ^ Larabel, Michael (15 November 2015). "A Look At The New Features Of The Linux 4.4 Kernel". Фороникс. Получено 11 января 2016.
  85. ^ "drm/vc4: Add KMS support for Raspberry Pi". Kernel.org.
  86. ^ "Linux 4.5-DriversArch - Graphics". Linux Kernel Newbies. Получено 14 марта 2016.
  87. ^ Larabel, Michael (24 January 2016). "The Many New Features & Improvements Of The Linux 4.5 Kernel". Фороникс. Получено 14 марта 2016.
  88. ^ Corbet, Jonathan (20 January 2016). "4.5 merge window part 2". LWN.Net. Получено 14 марта 2016.
  89. ^ "Merge tag 'sun4i-drm-for-4.7'". Kernel.org.
  90. ^ а б c Airlie, Dave (23 May 2016). "[git pull] drm for v4.7". dri-devel (Список рассылки).
  91. ^ "Merge tag 'drm-hisilicon-next-2016-04-29'". Kernel.org.
  92. ^ "Merge tag 'mediatek-drm-2016-05-09'". Kernel.org.
  93. ^ Larabel, Michael (22 November 2016). "Hisilicon Hibmc DRM Driver Being Added For Linux 4.10". Фороникс. Получено 24 января 2018.
  94. ^ "Huawei FusionServer RH5885 V3 Technical White Paper". 18 ноября 2016 г. uses an onboard display chip that is integrated into the management chip Hi1710 and uses the IP core of the SM750
  95. ^ "kernel/git/torvalds/linux.git - Linux kernel source tree". git.kernel.org. Получено 2019-11-28.
  96. ^ "kernel/git/torvalds/linux.git - Linux kernel source tree". git.kernel.org. Получено 2019-11-28.
  97. ^ "drm: remove the gamma driver". Kernel.org. Получено 27 января 2015.
  98. ^ "[DRM]: Delete sparc64 FFB driver code that never gets built". Kernel.org. Получено 27 января 2015.
  99. ^ "drm: remove i830 driver". Kernel.org. Получено 27 января 2015.
  100. ^ "drm: Add via unichrome support". Kernel.org. Получено 27 января 2015.
  101. ^ "drm: add savage driver". Kernel.org. Получено 27 января 2015.
  102. ^ "List of maintainers of the linux kernel". Kernel.org. Получено 14 июля 2014.
  103. ^ "libdrm git repository". Получено 23 июля 2014.
  104. ^ "First DRI release of 3dfx driver". Меса 3D. Получено 15 июля 2014.
  105. ^ "Import 2.3.18pre1". The History of Linux in GIT Repository Format 1992-2010 (2010). Получено 15 июля 2014.
  106. ^ Torvalds, Linus. "Linux 2.4.0 source code". Kernel.org. Получено 29 июля 2014.
  107. ^ Airlie, Dave (30 December 2004). "[bk pull] drm core/personality split". Linux-ядро (Список рассылки).
  108. ^ Torvalds, Linus (11 января 2005 г.). "Linux 2.6.11-rc1". Linux-ядро (Список рассылки).
  109. ^ Gettys, James; Packard, Keith (15 June 2004). "The (Re)Architecture of the X Window System". Получено 30 апреля 2016.
  110. ^ Smirl, Jon (30 August 2005). "The State of Linux Graphics". Получено 30 апреля 2016. I believe the best solution to this problem is for the kernel to provide a single, comprehensive device driver for each piece of video hardware. This means that conflicting drivers like fbdev and DRM must be merged into a cooperating system. It also means that poking hardware from user space while a kernel based device driver is loaded should be prevented.
  111. ^ Verhaegen, Luc (2 March 2006). "X and Modesetting: Atrophy illustrated" (PDF). Получено 30 апреля 2016.
  112. ^ Glisse, Jerome (4 December 2007). "Radeon kernel modesetting". Получено 30 апреля 2016.
  113. ^ Larabel, Michael (1 October 2008). "The State of Kernel Mode-Setting". Фороникс. Получено 30 апреля 2016.
  114. ^ Packard, Keith (21 July 2008). "X output status july 2008". Получено 1 мая 2016.
  115. ^ "drm: reorganise drm tree to be more future proof". Kernel.org.
  116. ^ "Linux 2.6.28 - The GEM Memory Manager for GPU memory". Linux Kernel Newbies. Получено 23 июля 2014.
  117. ^ "drm: Add the TTM GPU memory manager subsystem". Kernel.org.
  118. ^ "DRM: add mode setting support". Kernel.org.
  119. ^ "DRM: i915: add mode setting support". Kernel.org.
  120. ^ Anholt, Eric (22 December 2008). "[ANNOUNCE] libdrm-2.4.3". dri-devel (Список рассылки).
  121. ^ Barnes, Jesse (20 October 2008). "[ANNOUNCE] xf86-video-intel 2.5.0". xorg-announce (Список рассылки).
  122. ^ "Linux 2.6.31 - ATI Radeon Kernel Mode Setting support". Linux Kernel Newbies. Архивировано из оригинал 5 ноября 2015 г.. Получено 28 апреля 2016.
  123. ^ Torvalds, Linus (9 сентября 2009 г.). "Linux 2.6.31". Linux-ядро (Список рассылки).
  124. ^ "drm/radeon: introduce kernel modesetting for radeon hardware". Kernel.org.
  125. ^ "The irregular Nouveau Development Companion #40". Nouveau project. Получено 3 мая 2016.
  126. ^ "Linux 2.6.33 - Graphic improvements". Linux Kernel Newbies. Получено 28 апреля 2016.
  127. ^ "drm/kms: add page flipping ioctl". Kernel.org.
  128. ^ "Linux 2.6.38 - Graphics". Linux Kernel Newbies. Получено 28 апреля 2016.
  129. ^ Airlie, Dave (21 December 2009). "[ANNOUNCE] libdrm 2.4.17". dri-devel (Список рассылки).
  130. ^ "drm: dumb scanout create/mmap for intel/radeon (v3)". Kernel.org.
  131. ^ "Linux 2 6 39-DriversArch". Linux Kernel Newbies. Получено 19 апреля 2016.
  132. ^ Barnes, Jesse; Pinchart, Laurent; Vetter, Daniel; Wunner, Lukas. "Linux GPU Driver Developer's Guide - Dumb Buffer Objects". Получено 31 августа 2016.
  133. ^ Wilson, Chris (11 April 2011). "[ANNOUNCE] libdrm 2.4.25". dri-devel (Список рассылки).
  134. ^ Barnes, Jesse (25 April 2011). "[RFC] drm: add overlays as first class KMS objects". dri-devel (Список рассылки).
  135. ^ Barnes, Jesse (13 May 2011). "[RFC] drm: add overlays as first class KMS objects". dri-devel (Список рассылки).
  136. ^ "drm: add plane support v3". Kernel.org.
  137. ^ "drm: add generic ioctls to get/set properties on any object". Kernel.org.
  138. ^ Widawsky, Ben (27 June 2012). "[ANNOUNCE] libdrm 2.4.36". xorg-announce (Список рассылки).
  139. ^ Ларабель, Майкл. "Proof Of Concept: Open-Source Multi-GPU Rendering!". Фороникс. Получено 14 апреля 2016.
  140. ^ Larabel, Michael (23 February 2012). "DRM Base PRIME Support Part Of VGEM Work". Фороникс. Получено 14 апреля 2016.
  141. ^ Airlie, Dave (27 March 2012). "[PATCH] drm: base prime/dma-buf support (v5)". dri-devel (Список рассылки).
  142. ^ Larabel, Michael (30 March 2012). "Last Minute For Linux 3.4: DMA-BUF PRIME Support". Фороникс. Получено 15 апреля 2016.
  143. ^ "drm: base prime/dma-buf support (v5)". Kernel.org.
  144. ^ "Linux 3.4 DriverArch". Linux Kernel Newbies. Получено 15 апреля 2016.
  145. ^ Anholt, Eric (10 May 2012). "[ANNOUNCE] libdrm 2.4.34". dri-devel (Список рассылки).
  146. ^ Larabel, Michael (12 May 2012). "DMA-BUF PRIME Coming Together For Linux 3.5". Фороникс. Получено 15 апреля 2016.
  147. ^ "Linux 3.5 DriverArch". Linux Kernel Newbies. Получено 15 апреля 2016.
  148. ^ Corbet, Jonathan (11 September 2013). "3.12 merge window, part 2". LWN.net. Получено 21 июля 2014.
  149. ^ "drm: implement experimental render nodes". Kernel.org.
  150. ^ "drm/i915: Support render nodes". Kernel.org.
  151. ^ "drm/radeon: Support render nodes". Kernel.org.
  152. ^ "drm/nouveau: Support render nodes". Kernel.org.
  153. ^ Roper, Matt (7 March 2014). "[RFCv2 00/10] Universal plane support". dri-devel (Список рассылки).
  154. ^ Larabel, Michael (2 April 2014). "Universal Plane Support Set For Linux 3.15". Фороникс. Получено 14 апреля 2016.
  155. ^ Lankhorst, Maarten (25 July 2014). "[ANNOUNCE] libdrm 2.4.55". dri-devel (Список рассылки).
  156. ^ а б Vetter, Daniel (7 August 2014). "Neat stuff for 3.17". Получено 14 апреля 2016.
  157. ^ Barnes, Jesse (15 February 2012). "[RFC] drm: atomic mode set API". dri-devel (Список рассылки).
  158. ^ Syrjälä, Ville (24 May 2012). "[RFC][PATCH 0/6] WIP: drm: Atomic mode setting idea". dri-devel (Список рассылки).
  159. ^ Clark, Rob (9 September 2012). "[RFC 0/9] nuclear pageflip". dri-devel (Список рассылки).
  160. ^ Clark, Rob (6 October 2013). "[RFCv1 00/12] Atomic/nuclear modeset/pageflip". dri-devel (Список рассылки).
  161. ^ Vetter, Daniel (3 February 2016). "Embrace the Atomic Display Age" (PDF). Получено 4 мая 2016.
  162. ^ Vetter, Daniel (2 November 2014). "Atomic Modeset Support for KMS Drivers". Получено 4 мая 2016.
  163. ^ Airlie, Dave (14 December 2014). "[git pull] drm for 3.19-rc1". dri-devel (Список рассылки).
  164. ^ Vetter, Daniel (28 January 2015). "Update for Atomic Display Updates". Получено 4 мая 2016.
  165. ^ Airlie, Dave (15 February 2015). "[git pull] drm pull for 3.20-rc1". dri-devel (Список рассылки).
  166. ^ "Linux 4.0 - DriverArch - Graphics". Linux Kernel Newbies. Получено 3 мая 2016.
  167. ^ "Linux 4.2 - Atomic modesetting API enabled by default". Linux Kernel Newbies. Получено 3 мая 2016.
  168. ^ Velikov, Emil (29 June 2015). "[ANNOUNCE] libdrm 2.4.62". dri-devel (Список рассылки).
  169. ^ Vetter, Daniel (6 June 2016). "Awesome Atomic Advances". Получено 7 июн 2016. right now there's 17 drivers supporting atomic modesetting merged into the DRM subsystem
  170. ^ Stone, Daniel (20 March 2018). "A new era for Linux's low-level graphics - Part 1". Получено 5 мая 2018.
  171. ^ Herrmann, David (10 December 2012). "KMSCON Introduction". Получено 22 ноября 2015.
  172. ^ "Linux, Solaris, and FreeBSD driver 358.09 (beta)". 2015-12-10.

внешняя ссылка