Пример демонстрирует установку соединения между запущенными в KasperskyOS программами через TCP-сокеты с использованием loopback-интерфейса.
Директория примера в SDK
Код примера и скрипты для сборки находятся по следующему пути:
/opt/KasperskyOS-Community-Edition-<platform>-<version>/examples/net_with_separate_vfs
Список программ
Client – прикладная программа, которая создает TCP-сокет, подключается к серверу через loopback-интерфейс, отправляет серверу данные и закрывает соединение.Server – прикладная программа, которая принимает запрос на создание соединения через TCP-сокет, получает данные от клиента, после чего закрывает соединение.VfsNet – системная программа, поддерживающая сетевые протоколы.DCM – системная программа, позволяющая динамически создавать IPC-каналы.EntropyEntity – системная программа, реализующая генератор случайных чисел.DNetSrv – драйвер сетевой карты.При сборке примера для целевой аппаратной платформы в решение автоматически включаются платформенно-зависимые драйверы:
BSP – пакет поддержки аппаратной платформы (Board Support Package), обеспечивающий кросс-платформенную настройку периферии для Radxa ROCK 3A.Bcm2711MboxArmToVc – драйвер для работы с сопроцессором VideoCore (VC6) через технологию mailbox для Raspberry Pi 4 B.Описание инициализации
Файл описания инициализации решения init.yaml генерируется в процессе сборки решения на основе шаблона ./einit/src/init.yaml.in. Макросы вида @INIT_*@, которые содержатся в шаблоне, автоматически раскрываются в итоговом файле init.yaml. Подробнее см. "Шаблон init.yaml.in".
Описание политики безопасности
Файл security.psl содержит описание политики безопасности решения на базе KasperskyOS и находится в директории ./einit/src. Декларации в PSL-файле снабжены комментариями, которые поясняют назначение этих деклараций.
Ресурсы
В директории ./resources/xdl/net_with_separate_vfs расположены файлы Client.edl и Server.edl – EDL-описания программ Client и Server соответственно.
В директории ./resources/romfs/etc расположен файл конфигурации hosts для программы VfsNet.
Сценарий работы
Программы Client и Server устанавливают TCP-соединение через loopback-интерфейс. Для этого они используют один экземпляр сетевого стека, то есть взаимодействуют с "общей" программой VFS (в примере это программа VfsNet). В коде обеих программ применяются стандартные POSIX-функции: программа Server ожидает входящие данные с использованием функции recv(), а программа Client отправляет данные по установленному TCP-соединению с использованием функции send().
Сборка и запуск примера
Для сборки и запуска примера используется система CMake из состава KasperskyOS Community Edition.
См. "Сборка и запуск примеров".
В начало