The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

Начальная реализация горячего подключения видеоадаптеров без перезапуска X-сервера

23.10.2011 20:14

Дэвид Эирлай (David Airlie), работающий в компании Red Hat, представил результаты первых экспериментов по реализации режима горячего подключения видеодрайверов в X.org, позволяющего подключать дополнительные видеокарты без перезапуска X-сервера. На представленном демонстрационном видеоролике, к компьютеру через порт USB подключается внешний видеоадаптер DisplayLink, при этом на него сразу начинает транслироваться текущее содержимое экрана.

В конфигурации использован драйвер xf86-video-modesetting и модифицированный X-сервер, поддерживающий новый экспериментальный ABI для взаимодействия с драйверами. При запуске X-сервера драйвер загружается через udev, после чего для работы X-клиентов экспортируется экран Screen, к которому присоединяется представление низкоуровневого экрана DrvScreen1. После горячего подключения видеокарты создаётся ещё один низкоуровневый экран DrvScreen2, связанный с новым драйвером, который также подключается к общему экрану Screen, работающему через стандартный протокол X11. Вся экранная активность, связанная со взаимодействием Screen и прослойкой драйверов, дублируется для всех низкоуровневых экранов (DrvScreen1 и DrvScreen2). Таким образом единый X11 экран Screen выступает в роли надстройки, занимающейся мультиплексированием вывода для экранов DrvScreen.

Технология отличается от Xinerama тем, что дублирование операций производится не на уровне протокола X11, а на более низком уровне взаимодействия с оборудованием. При этом изменение кода рендеринга даёт возможность не заботиться о том, с какого GPU сформирован вывод, т.е. можно выполнять все ресурсоёмкие операции на GPU основной карты и затем просто транслировать получившееся изображение на маломощную внешнюю карту (без необходимости повторного рендеринга на этой карте). Разработка пока находится на ранней стадии, по словам Дэвида Эирлая он лишь увидел небольшой свет в конце туннеля. Тем не менее, это первый видимый результат после года работы над решением данной задачи. В дальнейшем планируется реализовать поддержку добавления и удаления DrvScreen, а также возможность динамического переключения GPU.

  1. Главная ссылка к новости (http://www.phoronix.com/scan.p...)
  2. OpenNews: В Linux ядре 2.6.34 будет представлен обновленный драйвер для адаптеров DisplayLink
  3. OpenNews: Вышел релиз драйвера для USB-мониторов - xf86-video-displaylink 0.3
  4. OpenNews: Открыт код для поддержки USB мониторов DisplayLink и документация для Marvell PXA3x0 SoC
  5. Использование двух видеокарт на ноутбуках с поддержкой NVIDIA Optimus в Linux
  6. OpenNews: Для Linux обеспечена возможность переключения видеоадаптеров на ноутбуках с NVIDIA Optimus
Лицензия: CC BY 3.0
Короткая ссылка: https://opennet.ru/32110-xorg
Ключевые слова: xorg, video
При перепечатке указание ссылки на opennet.ru обязательно


Обсуждение (43) Ajax | 1 уровень | Линейный | +/- | Раскрыть всё | RSS
  • 1.1, Аноним (-), 20:28, 23/10/2011 [ответить] [﹢﹢﹢] [ · · · ]  
  • –4 +/
    Круто! Не прошло и полгода!
     
     
  • 2.2, Аноним (-), 20:34, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +2 +/
    прошло
     

  • 1.3, Аноним (-), 20:36, 23/10/2011 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    "Не прошло и полгода" - можно подумать, что где-то такое было вообще реализовано...
     
     
  • 2.6, koloboid (ok), 20:45, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • –1 +/
    осмелюсь предположить, что в каких-нибудь виндовсах. нет?
     
     
  • 3.8, Аноним (-), 21:09, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Нет, в венде видео на горячую не меняли. Ни AGP, ни PCI-X не хотплаговые.
     
     
  • 4.10, oppium (?), 21:23, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +1 +/
    В винде нет горячего подключения, но она может спокойно переключаться между дискретной и встроенной. В linux это если работает, то через очень глубокую жопу
     
     
  • 5.16, all_glory_to_the_hypnotoad (ok), 21:46, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +1 +/
    это только всё из-за глубоко закрытых методов переключения между GPU в блобах.
     
     
  • 6.19, oppium (?), 21:53, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    да пофиг на блобы, хотя бы в открытых дровах сделали - была бы киллер-фича. При попытке сменить текущую видеокарту в amdcc навечно отвалилась графика (переустановка иксов и дров ничего не дала - хрен пойми где они эти настройки хранят)
     
  • 6.28, skybon (ok), 00:18, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Дадада, во всём виноваты блобы.
     
     
  • 7.44, Xasd (ok), 01:05, 25/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    сарказм? %)
     
     
  • 8.47, 1 (??), 07:27, 25/10/2011 [^] [^^] [^^^] [ответить]  
  • +1 +/
    маразм ... текст свёрнут, показать
     
  • 4.12, koloboid (ok), 21:24, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    > Нет, в венде видео на горячую не меняли. Ни AGP, ни PCI-X
    > не хотплаговые.

    а USB?

     
     
  • 5.24, Below (ok), 22:45, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • –4 +/
    А что есть usb-видеокарты?
    По-моему там пропускной способности не хватит.
    Нет, ну на вывод иксов конечно сгодиться, но это как-то узковато
     
     
  • 6.25, koloboid (ok), 22:49, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    настоящий Ъ. даже до второго предложения не дошел :)

    >к компьютеру через порт USB подключается внешний видеоадаптер DisplayLink

     
     
  • 7.29, Below (ok), 00:47, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • –3 +/
    прочитал заголовок, подумал что прододжение байды с переключением видеокарт,бегло просмотрел содержание и прочел парочку комментариев))
     
  • 6.27, Ананимуз (?), 23:28, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Вышеозвученный DisplayLink делает как раз USB-видюхи.
    Конечно С FullHD и игрушками тяжело, но в целом работает.
     
  • 6.35, Аноним (-), 05:54, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +2 +/
    >А что есть usb-видеокарты?
    >По-моему там пропускной способности не хватит.
    >Нет, ну на вывод иксов конечно сгодиться, но это как-то узковато

    Обалдеть. Тут люди комментируют то чего не читают. Интересно, такие ... по заголовку ориентируются или как?

     
     
  • 7.48, hhg (ok), 11:43, 25/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    такие ... ориентируются по своей ориентации :(
     

  • 1.4, koloboid (ok), 20:45, 23/10/2011 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    эй там, на bleedingedge! а ваш wayland так умеет?
     
     
  • 2.39, Аноним (-), 14:06, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    > эй там, на bleedingedge! а ваш wayland так умеет?

    Зачем такие сложности? Достаточно лишь сломать сетевую прозрачность и запихнуть весь графический вывод в ядро, и вуаля - инновационное решение!

     

  • 1.5, Anonimous (?), 20:45, 23/10/2011 [ответить] [﹢﹢﹢] [ · · · ]  
  • +3 +/
    Даешь X12 !
     
  • 1.7, Zenitur (ok), 20:56, 23/10/2011 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Круто. Сначала горячее подключение PCI, теперь горячее подключение видеокарт. Хорошая система.
     
     
  • 2.9, Аноним (-), 21:10, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    > Круто. Сначала горячее подключение PCI, теперь горячее подключение видеокарт. Хорошая
    > система.

    Осталось горячее подключение матерей, CPU и памяти реализовать. Как в SPARC. Архитектура sun4u. 1983 год.

     
     
  • 3.11, koloboid (ok), 21:23, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +2 +/
    CONFIG_HOTPLUG=y
    CONFIG_HOTPLUG_CPU=y
    CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y
    CONFIG_ACPI_HOTPLUG_CPU=y
    CONFIG_HOTPLUG_PCI=y
     
     
  • 4.14, BratSinot (?), 21:35, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • –5 +/
    CONFIG_HOTPLUG_BRAIN=n ?
     
     
  • 5.18, koloboid (ok), 21:50, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    эммм, да. а у вас?
     
  • 4.17, all_glory_to_the_hypnotoad (ok), 21:48, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    очевидно, это всё на обычном x86 работать не будет

    железо не позволяет.

     
     
  • 5.20, koloboid (ok), 21:53, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +3 +/
    > очевидно, это всё на обычном x86 работать не будет
    > железо не позволяет.

    ну так и неча сравнивать тогда с "Архитектура sun4u. 1983 год.". То, что x86 чего-то там не умеет, не характеризует ядерную архитектуру. И вообще, можно вспомнить Xeon со всеми своими приблудами.

     
     
  • 6.41, Аноним (-), 20:36, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    >> очевидно, это всё на обычном x86 работать не будет
    >> железо не позволяет.
    > ну так и неча сравнивать тогда с "Архитектура sun4u. 1983 год.". То,
    > что x86 чего-то там не умеет, не характеризует ядерную архитектуру. И
    > вообще, можно вспомнить Xeon со всеми своими приблудами.

    Это хорошо характеризует экосистему x86 в целом. Писюк - он и есть писюк. Серверные решения ему недоступны иначе, чем в виде костылей - и те не работают.

     
  • 5.33, pavlinux (ok), 02:12, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    > очевидно, это всё на обычном x86 работать не будет
    > железо не позволяет.

    Работает, мать TYAN K8W http://www.tyan.com/archive/products/html/thunderk8we.html


     
     
  • 6.40, Аноним (-), 20:36, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Одна-единственная? Я вообще о целой архитектуре говорю. В семейство которой входит свыше 350 моделей серверов и станций.
     
     
  • 7.46, pavlinux (ok), 04:20, 25/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    > Одна-единственная?

    Да не, полно серверных материнок, если не большинство.
      

     
  • 3.32, pavlinux (ok), 02:08, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Здрасте нафиг, VAX х...й знает какого года весь был модульный  
     
     
  • 4.42, Аноним (-), 20:38, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    > Здрасте нафиг, VAX х...й знает какого года весь был модульный

    О, один-единственный поймал иронию "инновационных" находок Линукс! Который "прогрессивны" в 2011м году, а о том, что все это существовало в других системах курнадцать лет назад, никто про сто не знает из апологетов - их тогда и на свете-то не было!

     
     
  • 5.45, pavlinux (ok), 04:19, 25/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    >> Здрасте нафиг, VAX х...й знает какого года весь был модульный
    > О, один-единственный поймал иронию "инновационных" находок Линукс! Который "прогрессивны"
    > в 2011м году, а о том, что все это существовало в
    > других системах курнадцать лет назад, никто про сто не знает из
    > апологетов - их тогда и на свете-то не было!

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

     
  • 2.21, Gadd (?), 21:54, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Горячее подключение видеодрайвера, а не видеокарты.
     
  • 2.23, СуперАноним (?), 22:39, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    >Сначала горячее подключение PCI

    А физический уровень обычного PCI это позволяет? Чтобы было возможно горячее подключение, необходимо, чтобы штырьки питания были длиннее сигнальных. Что-то я этого на PCI картах не замечал.

     
     
  • 3.26, dalco (ok), 22:58, 23/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Обычный PCI - не факт. Впрочем, никто не мешает включить его через какой-нибудь коммутатор. В обычном состоянии - разъем обесточен. Воткнули плату расширения - софтварно/аппаратно даем коммутатору сигнал и вуаля - все сигналы/питание/аппаратный сброс на плату пошли.

    А вот в PCIe может и штатной фичей быть (я просто не в курсе),там же архитектура "точка-точка" используется? Если да, то реализация несложная для hot-plug'а вырисовывается.

     
     
  • 4.38, Frank (ok), 10:46, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Как правило, БИОСы тестируют слоты на предмет наличия девайсов, инициализируют найденные девайсы, а слоты без ответа просто гасит.
     
  • 3.30, Zenitur (ok), 01:16, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    Я об этом задавал вопрос на ЛОР. Мне ответили, что можно сжечь плату, как материнскую, так и расширения. Однажны я запнулся о провод Wi-Fi антенны и плата вылетела из компьютера - система даже ничего не заметила! Но я всё равно её экстренно выключил.

    Вот та тема: http://www.linux.org.ru/forum/linux-hardware/5767483

     
     
  • 4.34, koloboid (ok), 02:51, 24/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    аналогично "выдергивал" сетевуху, и не раз. все работает.
     

  • 1.43, Piter_Ring (ok), 23:32, 24/10/2011 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    а у меня видяхи выпадали с АГП (давно было), горели при этом пчему-то именно видяхи. С вероятностью 95%.
     
     
  • 2.49, Клыкастый (ok), 00:07, 26/10/2011 [^] [^^] [^^^] [ответить]  
  • +/
    95%... это в штуках выжила 1 из 20 видях. Ты опасный человек... По-моему, они не выпадали из слота, а в страхе выпрыгивали ;)
     

     Добавить комментарий
    Имя:
    E-Mail:
    Текст:



    Партнёры:
    PostgresPro
    Inferno Solutions
    Hosting by Hoster.ru
    Хостинг:

    Закладки на сайте
    Проследить за страницей
    Created 1996-2024 by Maxim Chirkov
    Добавить, Поддержать, Вебмастеру