Как повысить эффективность межпроцессорного обмена данными с помощью эмуляции Intel NTB Gen3?

Создание виртуального двойника Intel NTB Gen3 в QEMU позволяет разработчикам тестировать и отлаживать протоколы межпроцессорного обмена данными без необходимости использования реального оборудования. Такой подход обеспечивает симметричную конфигурацию, высокую скорость разработки и возможность отладки с помощью gdb. Модель QEMU полностью совместима с драйверами Linux и поддерживает работу с регистрами, прерываниями и окнами памяти, что является ключевым для реализации различных сценариев обмена данными.
Как повысить эффективность межпроцессорного обмена данными с помощью эмуляции Intel NTB Gen3?
Изображение носит иллюстративный характер

Использование Memory Windows (MW) в NTB позволяет передавать данные между узлами через PCIe. Существует несколько способов обмена: через сообщения с адресами и данными, через общую память BAR, alias в общее пространство памяти, и предоставление оперативной памяти в качестве BAR для соседнего узла. Наиболее эффективным методом является предоставление оперативной памяти как BAR для соседнего узла, обеспечивающее высокую скорость обмена без лишнего копирования данных, но при этом требуется экспорт всей памяти. Гибридный метод, использующий DMA, обеспечивает контроль адресов и изоляцию памяти, но может замедлять производительность.

Для работы с прерываниями в QEMU, модель использует регистры Doorbell, при записи в которые вызываются прерывания на противоположной стороне. Модель также эмулирует регистры Scratchpad для обмена простыми данными и Message для более эффективного обмена через очередь сообщений. Прерывания передаются между машинами через сокеты, что позволяет корректно эмулировать их работу. Для полной совместимости с драйверами Intel NTB требуется передавать информацию о статусе прерываний, что решается путём передачи ссылки на область памяти, содержащую состояние вектора прерываний.

Производительность модели Intel NTB Gen3 в QEMU позволяет успешно разрабатывать и тестировать различные транспорты обмена данными, такие как RPMSG, Virtio/Vhost и NTRDMA, что является ключевым фактором для создания высокоскоростных и надежных систем. Тесты производительности, проведенные с помощью утилит ntb_perf и iperf3, показывают, что модель обеспечивает высокую скорость передачи данных и низкую задержку, особенно при использовании методов, связанных с передачей оперативной памяти между узлами, что сопоставимо с реальным оборудованием.


Новое на сайте

19717NASA показало невиданные снимки кометы 3I/ATLAS и запечатлело старт лунной миссии Artemis... 19716Сифилис появился 4000 лет назад — или его находили не там, где искали? 19715Энергетический дисбаланс земли зашкаливает, и учёные не могут это объяснить 19714Cisco закрыла две критические уязвимости с рейтингом 9.8 из 10 в системах IMC и SSM 19713Водород из хлебных крошек: реакция, которая может потеснить ископаемое топливо 19712Китайский спутник с «рукой осьминога» прошёл орбитальный тест дозаправки 19711Кто такие поэты и почему поэзия важна сегодня? 19710Фальшивые установщики и ISO-файлы: как киберпреступники зарабатывают на майнинге и троянах 19709Почему большие языковые модели так и не научились думать 19708WhatsApp предупредил 200 пользователей о поддельном iOS-приложении со шпионским по:... 19707Открытый код под давлением ИИ: уязвимостей стало втрое больше за один квартал 19706Мышей с диабетом первого типа вылечили, создав «смешанный» иммунитет 19705Кости для азартных игр придумали коренные американцы 12 тысяч лет назад? 19704Артемида II летит навстречу солнцу на пике его ярости 19703Комета, которая вращается задом наперёд
Ссылка