Виртуализация X86 - X86 virtualization

виртуализация x86 - это использование возможностей виртуализации с аппаратной поддержкой на ЦП x86 / x86-64.

В конце 1990-х годов виртуализация x86 была достигнута с помощью сложных программных технологий, необходимых для компенсации отсутствия у процессора возможностей аппаратной виртуализации при достижении разумной производительности. В 2005 и 2006 годах оба Intel (VT-x ) и AMD (AMD-V ) представила ограниченную поддержку аппаратной виртуализации, которая позволила упростить программное обеспечение виртуализации, но дала очень мало преимуществ в скорости.[1] Расширенная поддержка оборудования, которая позволила существенно улучшить скорость, появилась в более поздних моделях процессоров.

Программная виртуализация

Следующее обсуждение фокусируется только на виртуализации архитектуры x86. защищенный режим.

В защищенном режиме ядро ​​операционной системы работает с более высокими привилегиями, такими как звенеть 0 и приложения с более низкими привилегиями, такие как кольцо 3.[нужна цитата ] В программной виртуализации ОС хоста имеет прямой доступ к оборудованию, тогда как гостевые ОС имеют ограниченный доступ к оборудованию, как и любое другое приложение ОС. Один из подходов, используемых в программной виртуализации x86 для преодоления этого ограничения, называется кольцо лишения, что предполагает запуск гостевой ОС на кольце выше (с меньшими привилегиями), чем 0.[2]

Три метода сделали возможной виртуализацию защищенного режима:

  • Двоичный перевод используется для перезаписи в терминах инструкций кольца 3 определенных инструкций кольца 0, таких как POPF, который в противном случае молча отказал бы или вел бы себя иначе при выполнении выше кольца 0,[3][4]:3 делая классический ловушка и эмуляция виртуализации невозможно.[4]:1[5] Для повышения производительности переведенный базовые блоки должны быть кэшированы последовательным образом, чтобы обнаруживать исправление кода (используется в VxD например), повторное использование страниц гостевой ОС или даже самомодифицирующийся код.[6]
  • Некоторые ключевые структуры данных, используемые процессором, должны быть затененный. Поскольку большинство операционных систем используют выгружаемая виртуальная память, и предоставив гостевой ОС прямой доступ к MMU означало бы потерю контроля со стороны менеджер виртуализации, часть работы MMU x86 необходимо продублировать в программном обеспечении для гостевой ОС с помощью метода, известного как таблицы теневых страниц.[7]:5[4]:2 Это включает в себя отказ гостевой ОС в доступе к фактическим записям таблицы страниц путем перехвата попыток доступа и их эмуляции в программном обеспечении. Архитектура x86 использует скрытое состояние для хранения дескрипторы сегментов в процессоре, поэтому, как только дескрипторы сегмента загружены в процессор, память, из которой они были загружены, может быть перезаписана, и нет никакого способа получить дескрипторы обратно от процессора. Таблицы теневых дескрипторов поэтому должны использоваться для отслеживания изменений, внесенных в таблицы дескрипторов гостевой ОС.[5]
  • Эмуляция устройства ввода-вывода: неподдерживаемые устройства в гостевой ОС должны быть эмулированы эмулятор устройства который работает в основной ОС.[8]

Эти методы влекут за собой некоторые накладные расходы на производительность из-за отсутствия поддержки виртуализации MMU по сравнению с виртуальной машиной, работающей на изначально виртуализуемой архитектуре, такой как IBM System / 370.[4]:10[9]:17 и 21

На традиционных мэйнфреймах классический Тип 1 гипервизор был автономным и не зависел от какой-либо операционной системы и не запускал никаких пользовательских приложений. Напротив, первые продукты виртуализации x86 были нацелены на компьютеры рабочих станций и запускали гостевую ОС внутри ОС хоста путем встраивания гипервизора в модуль ядра, работающий под управлением ОС хоста (гипервизор типа 2).[8]

Были некоторые разногласия относительно возможности виртуализации архитектуры x86 без аппаратной поддержки, как описано в Попек и Гольдберг. VMware исследователи отметили в 2006 г. АСПЛОС В статье говорится, что описанные выше методы сделали платформу x86 виртуализуемой в смысле соответствия трем критериям Попека и Голдберга, хотя и не с помощью классической техники ловушки и эмуляции.[4]:2–3

Другие системы, такие как Денали, L4, и Xen, известный как паравиртуализация, который включает перенос операционные системы для запуска на полученной виртуальной машине, которая не реализует части фактического набора инструкций x86, которые трудно виртуализировать. Паравиртуализированный ввод-вывод имеет значительные преимущества в производительности, как показано в исходной версии. СОСП Бумага Xen '03.[10]

Первоначальная версия x86-64 (AMD64 ) не допускал программной полной виртуализации из-за отсутствия поддержки сегментации в длинный режим, что сделало невозможной защиту памяти гипервизора, в частности, защиту обработчика прерываний, который выполняется в адресном пространстве гостевого ядра.[11][12]:11 и 20 Версия D и более поздние 64-битные процессоры AMD (как правило, производимые с длиной волны 90 нм или меньше) добавили базовую поддержку сегментации в длинном режиме, что позволило запускать 64-битные гостевые системы на 64-битных хостах посредством двоичной трансляции . Intel не добавила поддержку сегментации в свою реализацию x86-64 (Intel 64 ), что делает невозможной виртуализацию только 64-разрядного программного обеспечения на процессорах Intel, но поддержка Intel VT-x делает возможной виртуализацию с 64-разрядной аппаратной поддержкой на платформе Intel.[13][14]:4

На некоторых платформах можно запустить 64-разрядную гостевую систему в 32-разрядной ОС, если базовый процессор является 64-разрядным и поддерживает необходимые расширения виртуализации.

Аппаратная виртуализация

В 2005 и 2006 гг. Intel и AMD (работая самостоятельно) создал новый расширения процессора к архитектуре x86. Первое поколение аппаратной виртуализации x86 решало проблему привилегированных инструкций. Проблема низкой производительности виртуализированной системной памяти решена с помощью MMU виртуализация, которая была добавлена ​​в чипсет позже.

Центральное процессорное устройство

Виртуальный режим 8086

На основе болезненные переживания с 80286 защищенный режим, который сам по себе не подходил для одновременной работы ДОС приложений хорошо, Intel представила виртуальный режим 8086 в их 80386 чип, который предлагал виртуализированные процессоры 8086 на чипах 386 и более поздних версий. Однако аппаратная поддержка виртуализации самого защищенного режима стала доступной 20 лет спустя.[15]

Виртуализация AMD (AMD-V)

AMD Phenom ЦПУ

AMD разработала свои расширения виртуализации первого поколения под кодовым названием Pacifica и первоначально опубликовала их как AMD Secure Virtual Machine (SVM),[16] но позже продавал их под торговой маркой Виртуализация AMD, сокращенно AMD-V.

23 мая 2006 г. AMD выпустила Athlon 64 ("Орлеан" ), Athlon 64 X2 ("Виндзор" ) и Athlon 64 FX ("Виндзор" ) как первые процессоры AMD, поддерживающие эту технологию.

Возможности AMD-V также присутствуют на Athlon 64 и Athlon 64 X2 семейство процессоров с ревизиями "F" или "G" на розетка AM2, Turion 64 X2, и Opteron 2-е поколение[17] и третье поколение,[18] Феном и Феном II процессоры. В APU Fusion процессоры поддерживают AMD-V. AMD-V не поддерживается никакими процессорами Socket 939. Единственный Семпрон поддерживающие его процессоры - это APU и Гурон, Регор, Саргас настольные процессоры.

Процессоры AMD Opteron, начиная с линейки Family 0x10 Barcelona, ​​и процессоры Phenom II, поддерживают технологию аппаратной виртуализации второго поколения, называемую Индексирование быстрой виртуализации (ранее называвшиеся вложенными таблицами страниц во время разработки), позже принятые Intel как Расширенные таблицы страниц (EPT).

По состоянию на 2019 год все современные Дзен -процессоры AMD поддерживают AMD-V.

В Флаг процессора для AMD-V это "svm". Это можно проверить в Производные BSD через dmesg или же sysctl И в Linux через / proc /cpuinfo.[19] Инструкции в AMD-V включают VMRUN, VMLOAD, VMSAVE, CLGI, VMMCALL, INVLPGA, SKINIT и STGI.

Виртуализация Intel (VT-x)

Intel Core i7 (Блумфилд) ЦП

Ранее под кодовым названием Vanderpool, VT-x представляет технологию Intel для виртуализации на платформе x86. 13 ноября 2005 г. Intel выпустила две модели Pentium 4 (Модели 662 и 672) как первые процессоры Intel, поддерживающие VT-x. Флаг ЦП для возможности VT-x - «vmx»; в Linux это можно проверить через / proc / cpuinfo, или в macOS через sysctl machdep.cpu.features.[19]

«VMX» означает расширения виртуальной машины, которые добавляют 13 новых инструкций: VMPTRLD, VMPTRST, VMCLEAR, VMREAD, VMWRITE, VMCALL, VMLAUNCH, VMRESUME, VMXOFF, VMXON, INVEPT, INVVPID и VMFUNC.[20] Эти инструкции позволяют войти в виртуальный режим выполнения и выйти из него, в котором гостевая ОС воспринимает себя как работающую с полными привилегиями (кольцо 0), но ОС хоста остается защищенной.

По состоянию на 2015 год, почти все новые серверные, настольные и мобильные процессоры Intel поддерживают VT-x, а некоторые из Intel Atom процессоры в качестве основного исключения.[21] С некоторыми материнские платы, пользователи должны включить функцию Intel VT-x в BIOS до того, как приложения смогут его использовать.[22]

Intel начала включать Расширенные таблицы страниц (EPT),[23] технология виртуализации таблиц страниц,[24] так как Nehalem архитектура,[25][26] выпущен в 2008 году. В 2010 году Westmere добавлена ​​поддержка запуска логического процессора прямо в реальный режим - функция под названием «неограниченный гость», для работы которой требуется EPT.[27][28]

Поскольку Haswell микроархитектура (анонсирована в 2013 г.), Intel начала включать VMCS затенение как технология, которая ускоряет вложенная виртуализация виртуальных машин.[29]В структура управления виртуальной машиной (VMCS) - это структура данных в памяти, которая существует ровно один раз для каждой виртуальной машины, пока она управляется VMM. При каждом изменении контекста выполнения между различными виртуальными машинами VMCS восстанавливается для текущей виртуальной машины, определяя состояние виртуального процессора виртуальной машины.[30] Как только используется более одного VMM или вложенных VMM, возникает проблема, аналогичная тому, что требуется изобрести управление теневой таблицей страниц, как описано над. В таких случаях VMCS необходимо дублировать несколько раз (в случае вложения) и частично реализовывать в программном обеспечении, если процессор не поддерживает аппаратное обеспечение. Чтобы сделать обработку теневой VMCS более эффективной, Intel реализовала аппаратную поддержку теневого копирования VMCS.[31]

Виртуализация через VIA (VIA VT)

ВИА Нано Процессоры серии 3000 и выше поддерживают технологию виртуализации VIA VT, совместимую с Intel VT-x.[32] EPT присутствует в Чжаосинь ZX-C, потомок ЧЕРЕЗ QuadCore-E & Eden X4 похож на Nano C4350AL.[33]

Виртуализация прерываний (AMD AVIC и Intel APICv)

В 2012 году AMD объявила о своем Расширенный виртуальный контроллер прерываний (AVIC), направленный на снижение накладных расходов на прерывание в средах виртуализации.[34] Эта технология, как заявлено, не поддерживает x2APIC.[35]В 2016 году AVIC доступен на процессорах AMD семейства 15h, 6Xh (Carrizo) и новее.[36]

Также в 2012 году Intel анонсировала аналогичную технологию для прерывания и APIC виртуализация, у которой на момент анонса не было торговой марки.[37]Позже он был известен как Виртуализация APIC (APICv)[38]и он стал коммерчески доступным в Айви Бридж EP серия процессоров Intel, которая продается как Xeon E5-26xx v2 (запущена в конце 2013 года) и как Xeon E5-46xx v2 (запущена в начале 2014 года).[39]

Блок обработки графики

Виртуализация графики не является частью архитектуры x86. Intel Технология виртуализации графики (GVT) обеспечивает виртуализацию графики как часть графических архитектур последнего поколения. Несмотря на то что AMD APU реализовать x86-64 набор команд, они реализуют собственные графические архитектуры AMD (TeraScale, GCN и RDNA ), которые не поддерживают виртуализацию графики. Ларраби была единственная графика микроархитектура основан на x86, но, вероятно, не включает поддержку виртуализации графики.

Чипсет

Виртуализация памяти и ввода-вывода выполняется чипсет.[40] Обычно эти функции должны быть включены в BIOS, которая должна поддерживать их, а также должна быть настроена на их использование.

Виртуализация ввода-вывода MMU (AMD-Vi и Intel VT-d)

Блок управления памятью ввода / вывода (IOMMU) позволяет гостю виртуальные машины напрямую использовать периферийный устройства, такие как Ethernet, графические карты с ускорением и контроллеры жестких дисков, через DMA и прерывать переназначение. Иногда это называют Сквозной PCI.[41]

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

И AMD, и Intel опубликовали свои спецификации IOMMU:

  • Технология виртуализации ввода-вывода AMD, «AMD-Vi», первоначально называвшаяся «IOMMU»[42]
  • Intel «Технология виртуализации для направленного ввода-вывода» (VT-d),[43] входит в большинство дорогих (но не во все) Nehalem и более новые процессоры Intel[44]

Помимо поддержки процессора, оба материнская плата чипсет и системная прошивка (BIOS или же UEFI ) должны полностью поддерживать функциональность виртуализации ввода-вывода IOMMU, чтобы ее можно было использовать. Только PCI или же PCI Express устройства, поддерживающие сброс функционального уровня (FLR) можно виртуализировать таким образом, так как это требуется для переназначения различных функции устройства между виртуальными машинами.[45][46] Если назначаемое устройство не поддерживает Сообщения о прерываниях (MSI), он не должен делиться прерывать линии с другими устройствами, чтобы назначение было возможным.[47]Все обычный PCI устройства, маршрутизируемые за PCI /PCI-X мост -to-PCI Express можно назначить гостевой виртуальной машине только сразу; Устройства PCI Express не имеют такого ограничения.

Сетевая виртуализация (VT-c)

  • Intel «Технология виртуализации для подключения» (VT-c).[48]
Виртуализация ввода-вывода с одним корнем PCI-SIG (SR-IOV)

Виртуализация ввода-вывода с одним корнем PCI-SIG (SR-IOV) предоставляет набор общих (не связанных с x86) методов виртуализации ввода-вывода на основе PCI Express (PCIe) собственное оборудование, стандартизированное PCI-SIG:[49]

  • Услуги перевода адресов (АТС) поддерживает собственный ввод ввода-вывода через PCI Express через преобразование адресов. Для настройки таких переводов требуется поддержка новых транзакций.
  • Однокорневой IOV (SR-IOV или SRIOV) поддерживает собственный ввод ввода-вывода в существующих однокорневых сложных топологиях PCI Express. Для настройки нескольких виртуализированных пространств конфигурации требуется поддержка возможностей новых устройств.[50]
  • Многокорневой IOV (MR-IOV) поддерживает собственный IOV в новых топологиях (например, блейд-серверах), опираясь на SR-IOV, чтобы предоставить несколько корневых комплексов, которые разделяют общую иерархию PCI Express.

В SR-IOV, наиболее распространенном из них, хост VMM настраивает поддерживаемые устройства для создания и выделения виртуальных «теней» их пространств конфигурации, чтобы гости виртуальных машин могли напрямую настраивать такие ресурсы «теневых» устройств и получать доступ к ним.[51] При включенном SR-IOV виртуализированные сетевые интерфейсы напрямую доступны для гостей,[52]избегая участия VMM и приводя к высокой общей производительности;[50] например, SR-IOV достигает более 95% оголенный метал пропускная способность сети в НАСА виртуализированный центр обработки данных[53] и в Публичное облако Amazon.[54][55]

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

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

  1. ^ Сравнение программных и аппаратных средств виртуализации x86, Кейт Адамс и Оле Агесен, VMware, ASPLOS’06, 21–25 октября 2006 г., Сан-Хосе, Калифорния, США В архиве 2010-08-20 на Wayback Machine «Удивительно, но мы обнаружили, что поддержка оборудования первого поколения редко дает преимущества в производительности по сравнению с существующими программными технологиями. Мы объясняем эту ситуацию высокими затратами на переход между VMM и гостевой системой и жесткой моделью программирования, которая оставляет мало места для гибкости программного обеспечения при управлении частотой или стоимость этих переходов.
  2. ^ «Intel Virtualization Technology Processor Virtualization Extensions и Intel Trusted Execution Technology» (PDF). Intel.com. 2007 г. В архиве (PDF) из оригинала от 21.05.2015. Получено 2016-12-12.
  3. ^ "Техническая программа USENIX - Тезисы - Симпозиум по безопасности - 2000". Usenix.org. 2002-01-29. В архиве из оригинала от 10.06.2010. Получено 2010-05-02.
  4. ^ а б c d е «Сравнение программных и аппаратных средств виртуализации x86» (PDF). VMware. В архиве (PDF) из оригинала от 20 августа 2010 г.. Получено 8 сентября 2010.
  5. ^ а б Патент США 6397242
  6. ^ Патент США 6,704,925
  7. ^ «Виртуализация: архитектурные аспекты и другие критерии оценки» (PDF). VMware. В архиве (PDF) из оригинала от 6 февраля 2011 г.. Получено 8 сентября 2010.
  8. ^ а б Патент США 6,496,847
  9. ^ «VMware и технология поддержки оборудования» (PDF). В архиве (PDF) из оригинала от 17.07.2011. Получено 2010-09-08.
  10. ^ «Xen и искусство виртуализации» (PDF). В архиве (PDF) из оригинала от 29.09.2014.
  11. ^ «Как отказ от сегментации в длинном режиме AMD64 сломал VMware». Pagetable.com. 2006-11-09. В архиве из оригинала от 18.07.2011. Получено 2010-05-02.
  12. ^ «VMware и технология виртуализации ЦП» (PDF). VMware. В архиве (PDF) из оригинала от 17.07.2011. Получено 2010-09-08.
  13. ^ «VMware KB: Требования к оборудованию и микропрограммному обеспечению для 64-битных гостевых операционных систем». Kb.vmware.com. В архиве из оригинала от 19.04.2010. Получено 2010-05-02.
  14. ^ «Программные и аппаратные средства для виртуализации x86» (PDF). Архивировано из оригинал (PDF) на 2010-01-05. Получено 2010-05-02.
  15. ^ Ягер, Том (2004-11-05). «Отправка программного обеспечения для работы с оборудованием | Оборудование - InfoWorld». Images.infoworld.com. В архиве из оригинала 18.10.2014. Получено 2014-01-08.
  16. ^ "33047_SecureVirtualMachineManual_3-0.book" (PDF). В архиве (PDF) из оригинала от 05.03.2012. Получено 2010-05-02.
  17. ^ «В чем заключаются основные различия между процессорами AMD Opteron второго поколения и процессорами AMD Opteron первого поколения?». amd.com. Архивировано из оригинал 15 апреля 2009 г.. Получено 2012-02-04.
  18. ^ «Какие улучшения виртуализации есть в четырехъядерных процессорах AMD Opteron?». amd.com. Архивировано из оригинал 16 апреля 2009 г.. Получено 2012-02-04.
  19. ^ а б Чтобы узнать, поддерживает ли ваш процессор аппаратную виртуализацию В архиве 2012-11-25 в Wayback Machine Intel 2012 г.
  20. ^ INTEL (октябрь 2019 г.). «Руководство разработчика программного обеспечения для архитектур Intel® 64 и IA-32». intel.com. Корпорация Intel. Получено 2020-01-04.
  21. ^ «Список технологий виртуализации Intel». Ark.intel.com. В архиве с оригинала от 27.10.2010. Получено 2010-05-02.
  22. ^ «Windows Virtual PC: настройка BIOS». Microsoft. Архивировано из оригинал на 2010-09-06. Получено 2010-09-08.
  23. ^ Neiger, Gil; А. Сантони; Ф. Люнг; Д. Роджерс; Р. Улиг. «Технология виртуализации Intel: аппаратная поддержка для эффективной виртуализации процессора» (PDF). Intel Technology Journal. Intel. 10 (3): 167–178. Дои:10.1535 / itj.1003.01. Архивировано из оригинал (PDF) на 2012-09-25. Получено 2008-07-06.
  24. ^ Гиллеспи, Мэтт (12 ноября 2007 г.). «Лучшие практики для улучшений паравиртуализации от Intel Virtualization Technology: EPT и VT-d». Сеть программного обеспечения Intel. Intel. В архиве из оригинала 26.12.2008. Получено 2008-07-06.
  25. ^ "Сначала тик, а теперь тик: микроархитектура Intel нового поколения (Nehalem)" (PDF) (Пресс-релиз). Intel. В архиве (PDF) из оригинала от 26.01.2009. Получено 2008-07-06.
  26. ^ «Краткое описание технологии: технология виртуализации Intel Microarchitecture Nehalem» (PDF). Intel. 2009-03-25. В архиве (PDF) из оригинала 2011-06-07. Получено 2009-11-03.
  27. ^ http://2013.asiabsdcon.org/papers/abc2013-P5A-paper.pdf:[постоянная мертвая ссылка ] «Intel добавила неограниченный гостевой режим для микроархитектуры Westmere и более поздних процессоров Intel, он использует EPT для преобразования доступа к физическому адресу гостя в физический адрес хоста. В этом режиме разрешен VMEnter без включения разбиения по страницам».
  28. ^ http://download.intel.com/products/processor/manual/326019.pdf:[постоянная мертвая ссылка ] «Если« неограниченное гостевое »управление выполнением ВМ равно 1, то« разрешить EPT »управление выполнением ВМ также должно быть 1»
  29. ^ «Процессоры Intel Core vPro 4-го поколения с Intel VMCS Shadowing» (PDF). Intel. 2013. Получено 2014-12-16.
  30. ^ Понимание технологии виртуализации Intel (VT). В архиве 8 сентября 2014 г. Wayback Machine Дата обращения 1 сентября 2014.
  31. ^ «Что, где и почему» слежки за VMCS. В архиве 2014-09-03 на Wayback Machine Дата обращения 1 сентября 2014 г.
  32. ^ VIA представляет новые процессоры VIA Nano серии 3000 В архиве 22 января 2013 г. Wayback Machine
  33. ^ «Решение для ноутбука: процессор Kaixian ZX-C + набор микросхем VX11PH» (PDF).
  34. ^ Вэй Хуанг, Представление AMD Advanced Virtual Interrupt Controller В архиве 2014-07-14 в Wayback Machine, XenSummit 2012
  35. ^ Йорг Рёдел (август 2012 г.). «Виртуализация прерываний нового поколения для KVM» (PDF). AMD. В архиве (PDF) из оригинала от 04.03.2016. Получено 2014-07-12.
  36. ^ «[Xen-devel] [RFC PATCH 0/9] Представьте AMD SVM AVIC». www.mail-archive.com. В архиве из оригинала 2 февраля 2017 г.. Получено 4 мая 2018.
  37. ^ Дзюн Накадзимаа (13 декабря 2012 г.). «Обзор неиспользуемых и новых функций для виртуализации прерываний / APIC» (PDF). Intel. В архиве (PDF) из оригинала от 21.04.2015. Получено 2014-07-12.
  38. ^ Кханг Нгуен (17 декабря 2013 г.). «Тестирование производительности виртуализации APIC и Iozone». software.intel.com. В архиве из оригинала 2014-07-14. Получено 2014-07-12.
  39. ^ "Краткое описание семейства процессоров Intel Xeon E5-4600 v2" (PDF). Intel. 2014-03-14. В архиве (PDF) из оригинала 2014-07-14. Получено 2014-07-12.
  40. ^ «Аппаратная поддержка платформы Intel для виртуализации ввода-вывода». Intel.com. 10 августа 2006 г. В архиве из оригинала от 20.01.2007. Получено 2012-02-04.
  41. ^ «Виртуализация Linux и сквозная передача PCI». IBM. В архиве из оригинала 1 ноября 2009 г.. Получено 10 ноября 2010.
  42. ^ «Спецификация технологии виртуализации ввода-вывода AMD (IOMMU), версия 1.26» (PDF). В архиве (PDF) из оригинала от 24.01.2011. Получено 2011-05-24.
  43. ^ «Спецификация архитектуры Intel Virtualization для направленного ввода-вывода (VT-d)». В архиве из оригинала 2013-04-03. Получено 2012-02-04.
  44. ^ «Список поддерживаемых процессоров Intel Virtualization для направленного ввода-вывода (VT-d)». Ark.intel.com. В архиве с оригинала от 27.10.2010. Получено 2012-02-04.
  45. ^ «Уведомление о технических изменениях PCI-SIG: сброс функционального уровня (FLR)» (PDF). pcisig.com. 2006-06-27. В архиве (PDF) из оригинала от 04.03.2016. Получено 2014-01-10.
  46. ^ "Xen VT-d". xen.org. 2013-06-06. В архиве из оригинала от 09.02.2014. Получено 2014-01-10.
  47. ^ «Как назначить устройства с VT-d в KVM». linux-kvm.org. 2014-04-23. В архиве из оригинала от 10.03.2015. Получено 2015-03-05.
  48. ^ «Технология виртуализации Intel для подключения (VT-c)» (PDF). Intel.com. В архиве (PDF) из оригинала от 22.02.2016. Получено 2018-02-14.
  49. ^ «Спецификации виртуализации ввода-вывода PCI-SIG (IOV)». Pcisig.com. 2011-03-31. В архиве из оригинала от 15.01.2012. Получено 2012-02-04.
  50. ^ а б «Intel Look Inside: Intel Ethernet» (PDF). Intel. 27 ноября 2014 г. с. 104. В архиве (PDF) из оригинала 4 марта 2016 г.. Получено 26 марта, 2015.
  51. ^ Яозу Донг, Чжао Ю, Грег Роуз (2008). «Сеть SR-IOV в Xen: архитектура, дизайн и реализация». usenix.org. USENIX. В архиве из оригинала от 09.01.2014. Получено 2014-01-10.CS1 maint: использует параметр авторов (связь)
  52. ^ Патрик Катч; Брайан Джонсон; Грег Роуз (сентябрь 2011 г.). «Введение в гибкое разделение портов Intel с использованием технологии SR-IOV» (PDF). Intel. В архиве (PDF) с оригинала 7 августа 2015 г.. Получено 24 сентября, 2015.
  53. ^ «Гибкая облачная структура НАСА: перенос кластерных приложений в облако» (PDF). Intel. В архиве (PDF) из оригинала от 22.12.2012. Получено 2014-01-08.
  54. ^ «Расширенные возможности сети в облаке AWS». Масштабируемая логика. 2013-12-31. В архиве из оригинала от 09.01.2014. Получено 2014-01-08.
  55. ^ «Расширенные сети в облаке AWS - Часть 2». Масштабируемая логика. 2013-12-31. В архиве из оригинала 10.01.2014. Получено 2014-01-08.

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