Содержание
Сборка решения на базе KasperskyOS
Этот раздел содержит следующие сведения:
- описание процесса сборки решения на базе KasperskyOS;
- описания скриптов, библиотек и шаблонов сборки, поставляемых в KasperskyOS Community Edition;
- сведения о том, как использовать динамические библиотеки в решении на базе KasperskyOS.
Сборка образа решения
Решение на базе KasperskyOS – системное ПО (включая ядро KasperskyOS и модуль безопасности Kaspersky Security Module) и прикладное ПО, интегрированные для работы в составе программно-аппаратного комплекса.
Подробнее см. "Структура и запуск решения на базе KasperskyOS".
Системные и прикладные программы
Программы по назначению делятся на два типа:
- Системные программы создают инфраструктуру для прикладных программ (например, обеспечивают работу с аппаратурой, поддерживают механизм IPC, реализуют файловые системы и сетевые протоколы). Системные программы поставляются в составе KasperskyOS Community Edition. При необходимости вы можете разрабатывать собственные системные программы.
- Прикладные программы предназначены для взаимодействия с пользователем решения и выполнения пользовательских задач. Прикладные программы отсутствуют в составе KasperskyOS Community Edition.
Сборка программ в процессе сборки решения
При сборке решения программы делятся на два типа:
- Системные программы, поставляемые в составе KasperskyOS Community Edition в виде исполняемых файлов;
- Системные или прикладные программы, требующие компоновки в исполняемый файл.
При этом программы, требующие компоновки, делятся на следующие типы:
- Системные программы, реализующие IPC-интерфейс, для которого в составе KasperskyOS Community Edition поставляются готовые транспортные библиотеки.
- Прикладные программы, реализующие собственный IPC-интерфейс. Для их сборки необходимо генерировать транспортные методы и типы с помощью компилятора NK.
- Клиентские программы, не предоставляющие служб.
Сборка образа решения
В составе KasperskyOS Community Edition поставляются образ ядра KasperskyOS, а также исполняемые файлы некоторых системных программ и программ-драйверов, готовые к использованию в решении.
Специальная программа Einit, предназначенная для запуска всех остальных программ, а также модуль безопасности Kaspersky Security Module собираются под каждое конкретное решение и не поставляются в составе KasperskyOS Community Edition. Вместо этого в тулчейн KasperskyOS Community Edition включены утилиты для их сборки.
Общая пошаговая схема сборки описана в статье "Общая схема сборки". Сборку образа решения можно осуществлять:
- [Рекомендовано] при помощи скриптов системы сборки
CMake
, которые поставляются в составе KasperskyOS Community Edition. - без использования CMake: с помощью других систем автоматизированной сборки или вручную, используя скрипты и компиляторы, поставляемые в составе KasperskyOS Community Edition.
Общая схема сборки
Для того чтобы собрать образ решения, необходимо выполнить следующие действия:
- Подготовить EDL-, CDL- и IDL-описания прикладных программ, а также файл init-описания (по умолчанию
init.yaml
) и файлы с описанием политики безопасности решения (по умолчаниюsecurity.psl
).При сборке с
CMake
EDL-описание можно генерировать используя командуgenerate_edl_file()
. - Для всех программ, кроме системных программ, поставляемых в составе KasperskyOS Community Edition, сгенерировать файлы *.edl.h.
- При сборке с
CMake
для этого используются командуnk_build_edl_files()
. - При сборке без
CMake
для этого необходимо использовать компилятор NK.
- При сборке с
- Для программ, реализующих собственный IPC-интерфейс, сгенерировать код транспортных методов и типов, используемых для формирования, отправки, приема и обработки IPC-сообщений.
- При сборке с
CMake
для этого используются командыnk_build_idl_files()
,nk_build_cdl_files()
. - При сборке без
CMake
для этого необходимо использовать компилятор NK.
- При сборке с
- Собрать все программы, входящие в решение, при необходимости скомпоновав их с транспортными библиотеками системных или прикладных программ. Для сборки прикладных программ, реализующих собственный IPC-интерфейс, потребуются сгенерированный на шаге 3 код, содержащий транспортные методы и типы.
- При сборке с
CMake
для этого используются стандартные команды сборки. Необходимые настройки кросс-компиляции производятся автоматически. - При сборке без
CMake
для этого необходимо вручную использовать кросс-компиляторы, входящие в состав KasperskyOS Community Edition.
- При сборке с
- Собрать инициализирующую программу Einit.
- При сборке с
CMake
программаEinit
собирается в процессе сборки образа решения командамиbuild_kos_qemu_image()
иbuild_kos_hw_image()
. - При сборке без
CMake
для генерации кода программыEinit
необходимо использовать утилиту einit. ПрограммуEinit
затем необходимо собрать с помощью кросс-компилятора, поставляемого в KasperskyOS Community Edition.
- При сборке с
- Собрать модуль Kaspersky Security Module.
- При сборке с
CMake
модуль безопасности собирается в процессе сборки образа решения командамиbuild_kos_qemu_image()
иbuild_kos_hw_image()
. - При сборке без
CMake
для этого необходимо использовать скриптmakekss
.
- При сборке с
- Создать образ решения.
- При сборке с
CMake
для этого используются командыbuild_kos_qemu_image()
иbuild_kos_hw_image()
. - При сборке без
CMake
для этого необходимо использовать скриптmakeimg
.
- При сборке с
Пример 1
Для простейшего примера hello
, входящего в состав KasperskyOS Community Edition, в котором содержится одна прикладная программа, не предоставляющая служб, схема сборки выглядит следующим образом:
Пример 2
Пример echo
, входящий в состав KasperskyOS Community Edition, описывает простейший случай взаимодействия двух программ с помощью механизма IPC. Чтобы организовать такое взаимодействие, потребуется реализовать на сервере интерфейс с методом Ping
и "поместить" службу Ping
в новый компонент (например, Responder
), а экземпляр этого компонента – в EDL-описание программы Server
.
В случае наличия в решении программ, использующих механизм IPC, схема сборки выглядит следующим образом:
Использование CMake из состава KasperskyOS Community Edition
Для автоматизации процесса подготовки образа решения нужно настроить систему сборки CMake
. За основу можно взять параметры системы сборки, используемые в примерах из состава KasperskyOS Community Edition.
В файлах CMakeLists.txt
используется стандартный синтаксис CMake
, а также команды и макросы из библиотек, поставляемых в KasperskyOS Community Edition.
Рекомендованная структура директорий проекта
При создании решения на базе KasperskyOS рекомендуется использовать следующую структуру директорий в проекте:
- В корне проекта создать корневой файл CMakeLists.txt, содержащий общие инструкции сборки для всего решения.
- Исходный код каждой из разрабатываемых программ следует разместить в отдельной директории, в поддиректории
src
. - Создать файлы CMakeLists.txt для сборки каждой прикладной программы в соответствующих директориях.
- Для генерации исходного кода программы
Einit
следует создать отдельную директориюeinit
, содержащую поддиректориюsrc
, в которую следует поместить шаблоны init.yaml.in и security.psl.in.Также в эту директорию можно поместить любые другие файлы, которые необходимо включить в образ решения.
- Создать файл CMakeLists.txt для сборки программы
Einit
в директорииeinit
. - Файлы EDL-, CDL- и IDL-описаний следует разместить в директории
resources
в корне проекта.
Пример структуры директорий проекта
Сборка образа решения
Чтобы выполнить сборку образа решения, нужно использовать утилиту cmake
(исполняемый файл toolchain/bin/cmake
из состава KasperskyOS Community Edition).
Пример скрипта сборки:
build.sh
Корневой файл CMakeLists.txt
Корневой файл CMakeLists.txt
содержит общие инструкции сборки для всего решения.
Корневой файл CMakeLists.txt
должен содержать следующие команды:
cmake_minimum_required (VERSION 3.25)
– указание минимальной поддерживаемой версииCMake
.Для сборки решения на базе KasperskyOS требуется
CMake
версии не ниже 3.25.Требуемая версия
CMake
поставляется в составе KasperskyOS Community Edition и используется по умолчанию.include (platform)
– подключениеCMake
-библиотекиplatform
.initialize_platform()
– инициализация библиотекиplatform
.project_header_default("STANDARD_GNU_11:YES" "STRICT_WARNINGS:NO"
) – установка флагов компилятора и компоновщика.- [Опционально] Подключение и настройка пакетов для поставляемых системных программ и драйверов, которые необходимо включить в решение:
- Подключение пакета выполняется с помощью команды
find_package()
. - После подключения пакета необходимо добавить директории, связанные с этим пакетом, в список директорий поиска с помощью команды
include_directories()
. - Для некоторых пакетов также требуется установить значения свойств с помощью команды
set_target_properties()
.
CMake
-описания системных программ и драйверов, поставляемых в составе KasperskyOS Community Edition, а также их экспортируемых переменных и свойств находятся в соответствующих файлах/opt/KasperskyOS-Community-Edition-<version>/sysroot-aarch64-kos/lib/cmake/<имя программы>/<имя программы>-config.cmake
- Подключение пакета выполняется с помощью команды
- Сборка инициализирующей программы
Einit
должна быть выполнена с помощью командыadd_subdirectory(einit)
. - Все прикладные программы, сборку которых необходимо выполнить, должны быть добавлены с помощью команды
add_subdirectory(<имя директории программы>)
.
Пример корневого файла CMakeLists.txt
CMakeLists.txt
Файлы CMakeLists.txt для сборки прикладных программ
Файл CMakeLists.txt
для сборки прикладной программы должен содержать следующие команды:
include (platform/nk)
– подключение библиотекиCMake
для работы с компилятором NK.project_header_default ("STANDARD_GNU_11:YES" "STRICT_WARNINGS:NO"
) – установка флагов компилятора и компоновщика.- EDL-описание класса процессов для программы можно сгенерировать, используя команду
generate_edl_file()
. - Если программа предоставляет службы, используя механизм IPC, необходимо сгенерировать транспортный код:
- idl.h-файлы генерируются командой
nk_build_idl_files()
- cdl.h-файлы генерируются командой
nk_build_cdl_files()
- edl.h-файлы генерируются командой
nk_build_edl_files()
- idl.h-файлы генерируются командой
add_executable (<имя программы> "<путь к файлу исходного кода программы>")
– добавление цели для сборки программы.add_dependencies (<имя программы> <имя цели сборки edl.h файла>
) – добавление зависимости сборки программы от генерации edl.h-файла.target_link_libraries (<имя программы> <список библиотек>)
– определяет библиотеки, с которыми необходимо скомпоновать программу при сборке.Например, если программа использует файловый или сетевой ввод/вывод, то она должна быть скомпонована с транспортной библиотекой
${vfs_CLIENT_LIB}
.CMake
-описания системных программ и драйверов, поставляемых в составе KasperskyOS Community Edition, а также их экспортированных переменных и свойств находятся в соответствующих файлах/opt/KasperskyOS-Community-Edition-<version>/sysroot-aarch64-kos/lib/cmake/<имя программы>/<имя программы>-config.cmake
- Для автоматического добавления описаний IPC-каналов в файл
init.yaml
при сборке решения необходимо определить свойствоEXTRA_CONNECTIONS
и присвоить ему значение с описаниями нужных IPC-каналов.Обратите внимание на отступы в начале строк в свойстве
EXTRA_CONNECTIONS
. Эти отступы необходимы для корректной подстановки значений в файлinit.yaml
и должны соответствовать требованиям к его синтаксису.Пример создания IPC-канала между процессами
Client
иServer
:set_target_properties (Client PROPERTIES EXTRA_CONNECTIONS " - target: Server id: server_connection")В результате, при сборке решения, описание этого IPC-канала будет автоматически добавлено в файл
init.yaml
на этапе обработки макросов шаблона init.yaml.in. - Для автоматического добавления списка аргументов функции
main()
и словаря переменных окружения в файлinit.yaml
при сборке решения, необходимо определить свойстваEXTRA_ARGS
иEXTRA_ENV
и присвоить им соответствующие значения.Обратите внимание на отступы в начале строк в свойствах
EXTRA_ARGS
иEXTRA_ENV
. Эти отступы необходимы для корректной подстановки значений в файлinit.yaml
и должны соответствовать требованиям к его синтаксису.Пример передачи программе
Client
аргумента"-v"
функцииmain()
и переменной окруженияVAR1
со значениемVALUE1
:set_target_properties (Client PROPERTIES EXTRA_ARGS " - \"-v\"" EXTRA_ENV " VAR1: VALUE1")В результате, при сборке решения, описание аргумента функции
main()
и значение переменной окружения будут автоматически добавлены в файлinit.yaml
на этапе обработки макросов шаблона init.yaml.in.
Пример файла CMakeLists.txt для сборки простой прикладной программы
CMakeLists.txt
Файл CMakeLists.txt для сборки программы Einit
Файл CMakeLists.txt
для сборки инициализирующей программы Einit
должен содержать следующие команды:
include (platform/image)
– подключение библиотекиCMake
, содержащей скрипты сборки образа решения.project_header_default ("STANDARD_GNU_11:YES" "STRICT_WARNINGS:NO"
) – установка флагов компилятора и компоновщика.- Настройка пакетов системных программ и драйверов, которые необходимо включить в решение.
- Подключение пакета выполняется с помощью команды
find_package ()
. - Для некоторых пакетов также требуется установить значения свойств с помощью команды
set_target_properties ()
.
CMake
-описания системных программ и драйверов, поставляемых в составе KasperskyOS Community Edition, а также их экспортированных переменных и свойств находятся в соответствующих файлах/opt/KasperskyOS-Community-Edition-<version>/sysroot-aarch64-kos/lib/cmake/<имя программы>/<имя программы>-config.cmake
- Подключение пакета выполняется с помощью команды
- Для автоматического добавления описаний IPC-каналов между процессами системных программ в файл
init.yaml
при сборке решения необходимо добавить эти каналы в свойствоEXTRA_CONNECTIONS
для соответствующих программ.Обратите внимание на отступы в начале строк в свойстве
EXTRA_CONNECTIONS
. Эти отступы необходимы для корректной подстановки значений в файлinit.yaml
и должны соответствовать требованиям к его синтаксису.Например, программа
VFS
по умолчанию не имеет канала для соединения с программойEnv
. Чтобы описание такого канала автоматически добавилось в файл init.yaml при сборке решения, необходимо добавить следующий вызов в файлCMakeLists.txt
для сборки программыEinit
:set_target_properties (${vfs_ENTITY} PROPERTIES EXTRA_CONNECTIONS " - target: env.Env id: {var: ENV_SERVICE_NAME, include: env/env.h}"В результате, при сборке решения, описание этого IPC-канала будет автоматически добавлено в файл
init.yaml
на этапе обработки макросов шаблона init.yaml.in. - Для автоматического добавления списка аргументов функции
main()
и словаря переменных окружения в файлinit.yaml
при сборке решения, необходимо определить свойстваEXTRA_ARGS
иEXTRA_ENV
и присвоить им соответствующие значения.Обратите внимание на отступы в начале строк в свойствах
EXTRA_ARGS
иEXTRA_ENV
. Эти отступы необходимы для корректной подстановки значений в файлinit.yaml
и должны соответствовать требованиям к его синтаксису.
Пример передачи программе VfsEntity
аргумента "-f fstab"
функции main()
и переменной окружения ROOTFS
со значением ramdisk0,0 / ext2 0
:
В результате, при сборке решения, описание аргумента функции main()
и значение переменной окружения будут автоматически добавлены в файл init.yaml
на этапе обработки макросов шаблона init.yaml.in.
set(ENTITIES <полный список программ, входящих в решение>)
– определение переменнойENTITIES
со списком исполняемых файлов всех программ, входящих в решение.- Одна или обе команды для сборки образа решения:
- build_kos_hw_image() – создает цель сборки образа решения для аппаратной платформы.
- build_kos_qemu_image() – создает цель сборки образа решения для QEMU.
Пример файла CMakeLists.txt для сборки программы Einit
CMakeLitsts.txt
Шаблон init.yaml.in
Шаблон init.yaml.in
используется для автоматической генерации части файла init.yaml
перед сборкой программы Einit
средствами CMake
.
Использование шаблона init.yaml.in
позволяет не добавлять описания системных программ и IPC-каналов для соединения с ними в файл init.yaml
вручную.
Шаблон init.yaml.in
должен содержать следующие данные:
- Корневой ключ
entities
. - Список всех прикладных программ, входящих в решение.
- Для прикладных программ, использующих механизм IPC, необходимо указать список IPC-каналов, соединяющих эту программу с другими программами.
IPC-каналы, соединяющие эту программу с другими прикладными программами указываются вручную или в файле CMakeLists.txt этой программы с помощью свойства
EXTRA_CONNECTIONS
.Для указания списка IPC-каналов, соединяющих эту программу с системными программами, входящими в состав KasperskyOS Community Edition, используются следующие макросы:
@INIT_<имя программы>_ENTITY_CONNECTIONS@
– при сборке заменяется на список IPC-каналов со всеми системными программами, с которыми скомпонована прикладная программа. Поляtarget
иid
заполняются в соответствии с файламиconnect.yaml
из состава KasperskyOS Community Edition, расположенными в/opt/KasperskyOS-Community-Edition-<version>/sysroot-aarch64-kos/include/<имя системной программы>
).Этот макрос нужно использовать, если прикладная программа не имеет соединений с другими прикладными программами и соединяется только с системными программами. Этот макрос добавляет корневой ключ
connections
.@INIT_<имя программы>_ENTITY_CONNECTIONS+@
– при сборке добавляет список IPC-каналов со всеми системными программами, с которыми скомпонована прикладная программа, к списку IPC-каналов, заданному вручную. Этот макрос не добавляет корневой ключconnections
.Этот макрос нужно использовать, если прикладная программа имеет соединения с другими прикладными программами, которые были указаны в шаблоне
init.yaml.in
вручную.
- Макросы
@INIT_<имя программы>_ENTITY_CONNECTIONS@
и@INIT_<имя программы>_ENTITY_CONNECTIONS+@
также добавляют список соединений для каждой программы, заданный в свойствеEXTRA_CONNECTIONS
при сборке этой программы. - Если необходимо передать программе аргументы функции
main()
, заданные в свойствеEXTRA_ARGS
при сборке этой программы, то необходимо использовать следующие макросы:@INIT_<имя программы>_ENTITY_ARGS@
– при сборке заменяется на список аргументов функцииmain()
, заданный в свойствеEXTRA_ARGS
. Этот макрос добавляет корневой ключargs
.@INIT_<имя программы>_ENTITY_ARGS+@
– при сборке добавляет список аргументов функцииmain()
, заданный в свойствеEXTRA_ARGS
, к списку аргументов заданному вручную. Этот макрос не добавляет корневой ключargs
.
- Если необходимо передать программе значения переменных окружения, заданные в свойстве
EXTRA_ENV
при сборке этой программы, то необходимо использовать следующие макросы:@INIT_<имя программы>_ENTITY_ENV@
– при сборке заменяется на словарь переменных окружения и их значений, заданный в свойствеEXTRA_ENV
. Этот макрос добавляет корневой ключenv
.@INIT_<имя программы>_ENTITY_ENV+@
– при сборке добавляет словарь переменных окружения и их значений, заданный в свойствеEXTRA_ENV
, к переменным заданным вручную. Этот макрос не добавляет корневой ключenv
.
- Макрос
@INIT_EXTERNAL_ENTITIES@
, который при сборке заменяется на список системных программ, с которыми скомпонована прикладная программа, и их IPC-каналов, аргументов функцииmain()
и значений переменных окружения.
Пример шаблона init.yaml.in
init.yaml.in
При сборке программы Einit
из этого шаблона будет сгенерирован следующий файл init.yaml:
init.yaml
Шаблон security.psl.in
Шаблон security.psl.in
используется для автоматической генерации части файла security.psl
перед сборкой программы Einit
средствами CMake
.
Файл security.psl
содержит часть описания политики безопасности решения.
Использование шаблона security.psl.in
позволяет не добавлять EDL-описания системных программ в файл security.psl
вручную.
Шаблон security.psl.in
должен содержать описание политики безопасности решения, созданное вручную, включая следующие декларации:
- установка глобальных параметров политики безопасности решения;
- включение PSL-файлов в описание политики безопасности решения;
- включение EDL-файлов прикладных программ в описание политики безопасности решения;
- создание объектов моделей безопасности;
- привязка методов моделей безопасности к событиям безопасности;
- создание профилей аудита безопасности.
Для автоматического включения системных программ, необходимо использовать макрос @INIT_EXTERNAL_ENTITIES@
.
Пример шаблона security.psl.in
security.psl.in
Библиотеки CMake в составе KasperskyOS Community Edition
Этот раздел содержит описание библиотек, поставляемых в KasperskyOS Community Edition и предназначенных для автоматизации сборки решения на базе KasperskyOS.
Библиотека platform
Библиотека platform
содержит следующие команды:
initialize_platform()
– команда для инициализации библиотекиplatform
.Команда
initialize_platform()
может вызываться с параметромFORCE_STATIC
, который включает принудительную статическую компоновку исполняемых файлов:- По умолчанию, если тулчейн в составе KasperskyOS SDK поддерживает динамическую компоновку, то команда
initialize_platform()
делает так, что для сборки всех исполняемых файлов, заданных черезCMake
-командыadd_executable()
, флаг-rdynamic
используется автоматически. - При вызове
initialize_platform (FORCE_STATIC)
в корневом файлеCMakeLists.txt
тулчейн, поддерживающий динамическую компоновку, выполняет статическую компоновку исполняемых файлов.
Команда
initialize_platform()
может вызываться с параметромNO_NEW_VERSION_CHECK
, который отключает проверку наличия обновлений SDK и передачу версии SDK на сервер "Лаборатории Касперского".Чтобы отключить проверку наличия обновлений SDK и передачу данных версии SDK на сервер Kaspersky при сборке решения используйте следующий вызов:
initialize_platform(NO_NEW_VERSION_CHECK)
. Подробнее о политике предоставления данных см. "Предоставление данных".- По умолчанию, если тулчейн в составе KasperskyOS SDK поддерживает динамическую компоновку, то команда
project_static_executable_header_default()
– команда для включения принудительной статической компоновки исполняемых файлов, заданных через последующиеCMake
-командыadd_executable()
в одном файлеCMakeLists.txt
. Тулчейн, поддерживающий динамическую компоновку, выполняет статическую компоновку этих исполняемых файлов.platform_target_force_static()
– команда для включения принудительной статической компоновки исполняемого файла, заданного черезCMake
-командуadd_executable()
. Тулчейн, поддерживающий динамическую компоновку, выполняет статическую компоновку этого исполняемого файла. Например, если вызываютсяCMake
-командыadd_executable(client "src/client.c")
иplatform_target_force_static(client)
, то для программыclient
выполняется статическая компоновка.project_header_default()
– команда для указания флагов компиляции.Параметры команды задаются в виде пар, состоящих из флага компиляции и его значения:
"FLAG_1:VALUE_1"
"FLAG_2:VALUE_2"
..."FLAG_N:VALUE_N"
.CMake
-библиотекаplatform
преобразует эти пары в параметры компилятора. Часто используемые флаги компиляции для компиляторов С и С++ из набора GCC, а также значения этих флагов приведены в таблице ниже.Флаг компиляции
Значение
YES
Значение
NO
Значение по умолчанию
STANDARD_ANSI
Используются стандарты ISO C90 и 1998 ISO C++.
Для компиляторов C и C++ значение преобразуется в параметр:
-ansi
.Стандарты ISO C90 и 1998 ISO C++ не используются.
STANDARD_ANSI:NO
STANDARD_C99
Используется стандарт ISO C99.
Для компилятора C значение преобразуется в параметр:
-std=c99
.Стандарт ISO C99 не используется.
STANDARD_C99:NO
STANDARD_GNU_C99
Используется стандарт ISO C99 с расширениями GNU.
Для компилятора C значение преобразуется в параметр:
-std=gnu99
.Стандарт ISO C99 с расширениями GNU не используется.
STANDARD_GNU_C99:NO
STANDARD_11
Используются стандарты ISO C11 и 2011 ISO C++.
Для C-компилятора значение преобразуется в параметр
-std=c11
или-std=c1x
в зависимости от версии компилятора.Для компилятора C++ значение преобразуется в параметр
-std=c++11
или-std=c++0x
в зависимости от версии компилятора.Стандарты ISO C11 и 2011 ISO C++ не используются.
STANDARD_11:NO
STANDARD_GNU_11
Используются стандарты ISO C11 и 2011 ISO C++ с расширениями GNU.
Для C-компилятора значение преобразуется в параметр
-std=gnu1x
или-std=gnu11
в зависимости от версии компилятора.Для компилятора C++ значение преобразуется в параметр
-std=gnu++0x
или-std=gnu++11
в зависимости от версии компилятора.Стандарты ISO C11 и 2011 ISO C++ с расширениями GNU не используются.
STANDARD_GNU_11:NO
STANDARD_14
Используется стандарт 2014 ISO C++.
Для компилятора C++ значение преобразуется в параметр
-std=c++14
.Стандарт 2014 ISO C++ не используется.
STANDARD_14:NO
STANDARD_GNU_14
Используется стандарт 2014 ISO C++ с расширениями GNU.
Для компилятора C++ значение преобразуется в параметр
-std=gnu++14
.Стандарт 2014 ISO C++ с расширениями GNU не используется.
STANDARD_GNU_14:NO
STANDARD_17
Используются стандарты ISO C17 и 2017 ISO C++.
Для C-компилятора значение преобразуется в параметр
-std=c17
.Для компилятора C++ значение преобразуется в параметр
-std=c++17
.Стандарты ISO C17 и 2017 ISO C++ не используются.
STANDARD_17:NO
STANDARD_GNU_17
Используются стандарты ISO C17 и 2017 ISO C++ с расширениями GNU.
Для C-компилятора значение преобразуется в параметр
-std=gnu17
.Для компилятора C++ значение преобразуется в параметр
-std=gnu++17
.Стандарты ISO C17 и 2017 ISO C++ с расширениями GNU не используются.
STANDARD_GNU_17:NO
STRICT_WARNINGS
Включены предупреждения для обнаружения потенциальных проблем и ошибок в коде на языках C и C++.
Для компиляторов C и C++ значение преобразуется в следующие параметры:
-Wcast-qual
,-Wcast-align
,-Wundef
.Для компилятора C дополнительно используется параметр
-Wmissing-prototypes
.Предупреждения отключены.
STRICT_WARNINGS:YES
Если через параметры команды не заданы флаги компиляции вида
STANDART_*
, то по умолчанию используется параметрSTANDARD_GNU_17:YES
.
При использовании команд initialize_platform(FORCE_STATIC)
, project_static_executable_header_default()
и platform_target_force_static()
могут возникать ошибки компоновки, если статический вариант требуемых библиотек отсутствует (например, не собран или не поставлен в составе KasperskyOS SDK). Но даже при наличии статического варианта требуемых библиотек эти ошибки могут возникать из-за того, что при использовании команд initialize_platform(FORCE_STATIC)
, project_static_executable_header_default()
и platform_target_force_static()
система сборки по умолчанию может выполнять поиск динамического варианта требуемых библиотек, а не статического, как ожидается. Чтобы избежать ошибок, нужно, во-первых, обеспечить наличие статического варианта требуемых библиотек, во-вторых, настроить систему сборки на поиск статических библиотек (для некоторых библиотек этой возможности может не быть) либо явно задавать компоновку со статическими библиотеками.
Примеры настройки системы сборки на поиск статических библиотек:
Пример, в котором явно задана компоновка со статической библиотекой:
Подробнее об использовании динамических библиотек см. "Использование динамических библиотек".
Эти команды используются в файлах CmakeLists.txt
для программы Einit и прикладных программ.
Библиотека nk
Этот раздел содержит описание команд и макросов библиотеки CMake
-библиотеки для работы с компилятором NK.
generate_edl_file()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>toolchain/share/cmake/Modules/platform/nk2.cmake
.
Команда генерирует EDL-файл с описанием класса процессов.
Параметры:
NAME
– имя создаваемого EDL-файла. Обязательный параметр.PREFIX
– в этом параметре необходимо указать имя класса процессов, исключив из него имя EDL-файла. Например, если имя класса процессов, для которого создается EDL-файл, определено какkl.core.NameServer
, то в параметреPREFIX
необходимо передать значениеkl.core
.EDL_COMPONENTS
– имя компонента и его экземпляра, которые будут включены в EDL-файл. Например:EDL_COMPONENTS "env: kl.Env"
. Для включения нескольких компонентов нужно использовать несколько параметровEDL_COMPONENTS
.SECURITY
– квалифицированное имя метода интерфейса безопасности, который будет включен в EDL-файл.OUTPUT_DIR
– директория, где будет создан EDL-файл. По умолчанию${CMAKE_CURRENT_BINARY_DIR}
.
В результате работы команды переменная EDL_FILE
экспортируется и содержит путь до сгенерированного EDL-файла.
Пример вызова:
Пример использования команды см. в статье "Файлы CMakeLists.txt для сборки прикладных программ".
В началоnk_build_idl_files()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>toolchain/share/cmake/Modules/platform/nk2.cmake
.
Команда создает CMake
-цель для генерации .idl.h
-файлов для одного или нескольких заданных IDL-файлов при помощи компилятора NK.
Параметры:
NAME
– имяCMake
-цели для сборки.idl.h
-файлов. Если цель еще не создана, то она будет создана с помощьюadd_library()
с указанным именем. Обязательный параметр.NOINSTALL
– если указана эта опция, то файлы будут только сгенерированы в рабочей директории, но не будут установлены в глобальные директории:${CMAKE_BINARY_DIR}/_headers_ ${CMAKE_BINARY_DIR}/_headers_/${PROJECT_NAME}
.NK_MODULE
– в этом параметре необходимо указать имя пакета, исключив из него имя IDL-файла. Например, если в IDL-описании имя пакета задано какkl.core.NameServer
, то в параметреNK_MODULE
необходимо передать значениеkl.core
.WORKING_DIRECTORY
– рабочая директория для вызова компилятора NK, по умолчанию:${CMAKE_CURRENT_BINARY_DIR}
.DEPENDS
– дополнительные цели сборки, от которых зависит IDL-файл.Для добавления нескольких целей нужно использовать несколько параметров
DEPENDS
.IDL
– путь к IDL-файлу, для которого генерируется idl.h-файл. Обязательный параметр.Для добавления нескольких IDL-файлов нужно использовать несколько параметров
IDL
.Если один IDL-файл импортирует другой IDL-файл, то генерацию idl.h-файлов нужно производить в порядке, необходимом для соблюдения зависимостей (сначала самые вложенные).
NK_FLAGS
– дополнительные флаги для NK компилятора.
Пример вызова:
Пример использования команды см. в статье "Файлы CMakeLists.txt для сборки прикладных программ".
В началоnk_build_cdl_files()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>toolchain/share/cmake/Modules/platform/nk2.cmake
.
Команда создает CMake
-цель для генерации .cdl.h
-файлов для одного или нескольких заданных CDL-файлов при помощи компилятора NK.
Параметры:
NAME
– имяCMake
-цели для сборки.cdl.h
-файлов. Если цель еще не создана, то она будет создана с помощьюadd_library()
с указанным именем. Обязательный параметр.NOINSTALL
– если указана эта опция, то файлы будут только сгенерированы в рабочей директории, но не установлены в глобальные директории:${CMAKE_BINARY_DIR}/_headers_ ${CMAKE_BINARY_DIR}/_headers_/${PROJECT_NAME}
.IDL_TARGET
– цель сборки.idl.h
-файлов для IDL-файлов, содержащих описания служб, предоставляемых компонентами, описанными в CDL-файлах.NK_MODULE
– в этом параметре необходимо указать имя компонента, исключив из него имя CDL-файла. Например, если в CDL-описании имя компонента задано какkl.core.NameServer
, то в параметреNK_MODULE
необходимо передать значениеkl.core
.WORKING_DIRECTORY
– рабочая директория для вызова компилятора NK, по умолчанию:${CMAKE_CURRENT_BINARY_DIR}
.DEPENDS
– дополнительные цели сборки, от которых зависит CDL-файл.Для добавления нескольких целей нужно использовать несколько параметров
DEPENDS
.CDL
– путь к CDL-файлу, для которого генерируется.cdl.h
-файл. Обязательный параметр.Для добавления нескольких CDL-файлов нужно использовать несколько параметров
CDL
.NK_FLAGS
– дополнительные флаги для NK компилятора.
Пример вызова:
Пример использования команды см. в статье "Файлы CMakeLists.txt для сборки прикладных программ".
В началоnk_build_edl_files()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>toolchain/share/cmake/Modules/platform/nk2.cmake
.
Команда создает CMake
-цель для генерации .edl.h
-файла для одного заданного EDL-файла при помощи компилятора NK.
Параметры:
NAME
– имяCMake
-цели сборки.edl.h
-файла. Если цель еще не создана, то она будет создана с помощьюadd_library()
с указанным именем. Обязательный параметр.NOINSTALL
– если указана эта опция, то файлы будут только сгенерированы в рабочей директории, но не установлены в глобальные директории:${CMAKE_BINARY_DIR}/_headers_ ${CMAKE_BINARY_DIR}/_headers_/${PROJECT_NAME}
.CDL_TARGET
– цель сборки.cdl.h
-файлов для CDL-файлов, содержащих описания компонентов EDL-файла, для которого выполняется сборка.IDL_TARGET
– цель сборки .idl.h-файлов для IDL-файлов, содержащих описания интерфейсов EDL-файла, для которого выполняется сборка.NK_MODULE
– в этом параметре необходимо указать имя класса процессов, исключив из него имя EDL-файла. Например, если в EDL-описании имя класса процессов задано какkl.core.NameServer
, то в параметреNK_MODULE
необходимо передать значениеkl.core
.WORKING_DIRECTORY
– рабочая директория для вызова компилятора NK, по умолчанию:${CMAKE_CURRENT_BINARY_DIR}
.DEPENDS
– дополнительные цели сборки, от которых зависит EDL-файл.Для добавления нескольких целей нужно использовать несколько параметров
DEPENDS
.EDL
– путь к EDL файлу, для которого генерируется edl.h-файл. Обязательный параметр.NK_FLAGS
– дополнительные флаги для NK компилятора.
Примеры вызова:
Пример использования команды см. в статье "Файлы CMakeLists.txt для сборки прикладных программ".
В началоГенерация транспортного кода для разработки на языке C++
Для генерации транспортных прокси-объектов и стабов с помощью генератора nkppmeta
при сборке решения используются CMake
-команды add_nk_idl(), add_nk_cdl() и add_nk_edl().
add_nk_idl()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>/toolchain/share/cmake/Modules/platform/nk2.cmake
.
Команда создает CMake
-цель для генерации заголовочного файла *.idl.cpp.h
для заданного IDL-файла при помощи компилятора nkppmeta
. Также команда создает библиотеку, содержащую транспортный код для заданного интерфейса. Для компоновки с этой библиотекой необходимо использовать команду bind_nk_targets()
.
Генерируемые заголовочные файлы содержат представление на языке C++ для интерфейса и типов данных, описанных в IDL-файле, а также методы, необходимые для использования прокси-объектов и стабов.
Параметры:
NAME
– имяCMake
-цели. Обязательный параметр.IDL_FILE
– путь к IDL-файлу. Обязательный параметр.NK_MODULE
– в этом параметре необходимо указать имя пакета, исключив из него имя IDL-файла. Например, если в IDL-описании имя пакета задано какkl.core.NameServer
, то в параметреNK_MODULE
необходимо передать значениеkl.core
.LANG
– в этом параметре необходимо указать значениеCXX
.
Пример вызова:
add_nk_cdl()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>/toolchain/share/cmake/Modules/platform/nk2.cmake
.
Команда создает CMake
-цель для генерации файла *.cdl.cpp.h
для заданного CDL-файла при помощи компилятора nkppmeta
. Команда также создает библиотеку, содержащую транспортный код для заданного компонента. Для компоновки с этой библиотекой необходимо использовать команду bind_nk_targets()
.
Файл *.cdl.cpp.h
содержит дерево вложенных компонентов и служб, предоставляемых компонентом, описанным в CDL-файле.
Параметры:
NAME
– имяCMake
-цели. Обязательный параметр.CDL_FILE
– путь к CDL-файлу. Обязательный параметр.NK_MODULE
– в этом параметре необходимо указать имя компонента, исключив из него имя CDL-файла. Например, если в CDL-описании имя компонента задано какkl.core.NameServer
, то в параметреNK_MODULE
необходимо передать значениеkl.core
.LANG
– в этом параметре необходимо указать значениеCXX
.
Пример вызова:
add_nk_edl()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>/toolchain/share/cmake/Modules/platform/nk2.cmake
.
Команда создает CMake
-цель для генерации файла *.edl.cpp.h
для заданного EDL-файла при помощи компилятора nkppmeta
. Также команда создает библиотеку, содержащую транспортный код для серверной или клиентской программы. Для компоновки с этой библиотекой необходимо использовать команду bind_nk_targets()
.
Файл *.edl.cpp.h
содержит дерево вложенных компонентов и служб, предоставляемых классом процессов, описанным в EDL-файле.
Параметры:
NAME
– имяCMake
-цели. Обязательный параметр.EDL_FILE
– путь к EDL-файлу. Обязательный параметр.NK_MODULE
– в этом параметре необходимо указать имя класса процессов, исключив из него имя EDL-файла. Например, если в EDL-описании имя класса процессов задано какkl.core.NameServer
, то в параметреNK_MODULE
необходимо передать значениеkl.core
.LANG
– в этом параметре необходимо указать значениеCXX
.
Пример вызова:
Библиотека image
Этот раздел содержит описание команд и макросов CMake
-библиотеки image
, входящей в состав KasperskyOS Community Edition и содержащей скрипты сборки образа решения.
build_kos_qemu_image()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>toolchain/share/cmake/Modules/platform/image.cmake
.
Команда создает CMake
-цель сборки образа решения для QEMU.
Параметры:
NAME
– имяCMake
-цели для сборки образа решения. Обязательный параметр.PERFCNT_KERNEL
– использовать ядро со счетчиками производительности, если оно доступно в составе KasperskyOS Community Edition.EINIT_ENTITY
– имя исполняемого файла, из которого будет запускаться программаEinit
.EXTRA_XDL_DIR
– дополнительные директории для включения при сборке программыEinit
.CONNECTIONS_CFG
– путь до файлаinit.yaml
или шаблона init.yaml.in.SECURITY_PSL
– путь до файлаsecurity.psl
или шаблона security.psl.in.KLOG_ENTITY
– цель сборки системной программыKlog
, отвечающей за аудит безопасности. Если цель не указана – аудит не выполняется.QEMU_FLAGS
– дополнительные флаги для запуска QEMU.IMAGE_BINARY_DIR_BIN
– директория для финального образа и других артефактов, по умолчанию совпадает сCMAKE_CURRENT_BINARY_DIR
.NO_AUTO_BLOB_CONTAINER
– не включать в образ решения программуBlobContainer
, необходимую для работы с динамическими библиотеками в разделяемой памяти. Подробнее см. "Включение системной программы BlobContainer в решение на базе KasperskyOS".PACK_DEPS
,PACK_DEPS_COPY_ONLY
,PACK_DEPS_LIBS_PATH
,PACK_DEPS_COPY_TARGET
– параметры, задающие способ добавления динамических библиотек в образ решения.IMAGE_FILES
– исполняемые файлы прикладных и системных программ (кроме программыEinit
) и любые другие файлы для добавления в образ ROMFS.Для добавления нескольких программ или файлов можно использовать несколько параметров
IMAGE_FILES
.<пути до файлов>
– свободные параметры, тоже чтоIMAGE_FILES
.
Пример вызова:
Пример использования команды см. в статье "Файлы CMakeLists.txt для сборки программы Einit".
В началоbuild_kos_hw_image()
Команда объявлена в файле /opt/KasperskyOS-Community-Edition-<version>toolchain/share/cmake/Modules/platform/image.cmake
.
Команда создает CMake
-цель сборки образа решения для аппаратной платформы.
Параметры:
NAME
– имяCMake
-цели для сборки образа решения. Обязательный параметр.PERFCNT_KERNEL
– использовать ядро со счетчиками производительности, если оно доступно в составе KasperskyOS Community Edition.EINIT_ENTITY
– имя исполняемого файла, из которого будет запускаться программаEinit
.EXTRA_XDL_DIR
– дополнительные директории для включения при сборке программыEinit
.CONNECTIONS_CFG
– путь до файла init.yaml или шаблона init.yaml.in.SECURITY_PSL
– путь до файла security.psl или шаблона security.psl.in.KLOG_ENTITY
– цель сборки системной программыKlog
, отвечающей за аудит безопасности. Если цель не указана – аудит не выполняется.IMAGE_BINARY_DIR_BIN
– директория для финального образа и других артефактов, по умолчаниюCMAKE_CURRENT_BINARY_DIR
.NO_AUTO_BLOB_CONTAINER
– не включать в образ решения программуBlobContainer
, необходимую для работы с динамическими библиотеками в разделяемой памяти. Подробнее см. "Включение системной программы BlobContainer в решение на базе KasperskyOS".PACK_DEPS
,PACK_DEPS_COPY_ONLY
,PACK_DEPS_LIBS_PATH
,PACK_DEPS_COPY_TARGET
– параметры, задающие способ добавления динамических библиотек в образ решения.IMAGE_FILES
– исполняемые файлы прикладных и системных программ (кроме программыEinit
) и любые другие файлы для добавления в образ ROMFS.Для добавления нескольких программ или файлов можно использовать несколько параметров
IMAGE_FILES
.<пути до файлов>
– свободные параметры, тоже чтоIMAGE_FILES
.
Пример вызова:
Пример использования команды см. в статье "Файлы CMakeLists.txt для сборки программы Einit".
В началоСборка без использования CMake
Этот раздел содержит описание скриптов, утилит, компиляторов и шаблонов сборки, поставляемых в KasperskyOS Community Edition.
Эти инструменты можно использовать:
- в других системах сборки;
- для выполнения отдельных шагов сборки;
- для изучения особенностей сборки и написания собственной системы сборки.
Общая схема сборки образа решения приведена в статье "Общая схема сборки".
Инструменты для сборки решения
Этот раздел содержит описание скриптов, утилит, компиляторов и шаблонов сборки, поставляемых в KasperskyOS Community Edition.
Утилиты и скрипты сборки
В состав KasperskyOS Community Edition входят следующие утилиты и скрипты сборки:
- nk-gen-c
Компилятор NK (
nk-gen-c
) генерирует транспортный код на основе IDL-, CDL- и EDL-описаний. Транспортный код нужен для формирования, отправки, приема и обработки IPC-сообщений. - nk-psl-gen-c
Компилятор
nk-psl-gen-c
генерирует исходный код модуля безопасности Kaspersky Security Module на языке C на основе описания политики безопасности решения и IDL-, CDL-, EDL-описаний. Также компиляторnk-psl-gen-c
позволяет генерировать исходный код тестов политики безопасности решения на языке C на основе тестов политики безопасности решения на языке PAL. - einit
Утилита
einit
позволяет автоматизировать создание кода инициализирующей программыEinit
. Эта программа первой запускается при загрузке KasperskyOS и запускает остальные программы, а также создает IPC-каналы между ними. - makekss
Скрипт
makekss
создает модуль безопасности Kaspersky Security Module. - makeimg
Скрипт
makeimg
создает финальный загружаемый образ решения на базе KasperskyOS со всеми запускаемыми программами и модулем Kaspersky Security Module.
nk-gen-c
Компилятор NK (nk-gen-c
) генерирует транспортный код на основе IDL-, CDL-, EDL-описаний.
Компилятор nk-gen-c
принимает IDL-, CDL- или EDL-файл и создает следующие файлы:
- Файл
*.*dl.h
, содержащий транспортный код. - Файл
*.*dl.nk.d
, в котором перечислены зависимости созданного файла*.*dl.h
от IDL- и CDL-файлов. Файл*.*dl.nk.d
создается для системы сборки.
Синтаксис shell-команды для запуска компилятора nk-gen-c
:
Базовые параметры:
FILE
Путь к IDL-, CDL- или EDL-файлу, для которого необходимо сгенерировать транспортный код.
-I
<PATH
>Через эти параметры задаются пути к директориям, которые содержат вспомогательные файлы, необходимые для генерации транспортного кода. (Вспомогательные файлы располагаются в директории
sysroot-*-kos/include
из состава KasperskyOS SDK.) Также через эти параметры можно задать пути к директориям, содержащим IDL-, CDL-файлы, на которые ссылается файл, заданный через параметрFILE
.-o
<PATH
>Путь к существующей директории, в которую будут помещены созданные файлы. Если этот параметр не указан, созданные файлы будут помещены в текущую директорию.
-h
|--help
Выводит текст справки.
--version
Выводит версию компилятора
nk-gen-c
.--extended-errors
Это параметр обеспечивает возможность использовать интерфейсные методы с одним или несколькими error-параметрами произвольных IDL-типов. (Клиент работает с error-параметрами как с выходными параметрами.)
Если не указывать параметр
--extended-errors
, можно использовать интерфейсные методы только с одним error-параметромstatus
IDL-типаUInt16
, значение которого передается клиенту через код возврата интерфейсного метода. Такой способ является устаревшим и перестанет поддерживаться в будущем, поэтому рекомендуется всегда указывать параметр--extended-errors
.
Выборочная генерация транспортного кода
Чтобы уменьшить объем генерируемого транспортного кода, можно использовать флаги выборочной генерации транспортного кода. Например, для программ, реализующих службы, можно использовать флаг --server
, а для программ, использующих службы, можно использовать флаг --client
.
Если ни один из флагов выборочной генерации транспортного кода не указан, компилятор nk-gen-c
генерирует для заданного IDL-, CDL- или EDL-файла транспортный код со всеми возможными методами и типами.
Флаги выборочной генерации транспортного кода для IDL-файла:
--types
Транспортный код включает типы, соответствующие IDL-типам из заданного IDL-файла, а также импортируемым в этот файл IDL-типам, которые используются в IDL-типах заданного IDL-файла. При этом типы, соответствующие импортируемым IDL-константам и псевдонимам импортируемых IDL-типов, не включаются в файл
*.idl.h
. Чтобы использовать типы, соответствующие импортируемым IDL-константам и псевдонимам импортируемых IDL-типов, нужно отдельно сгенерировать транспортный код для IDL-файлов, из которых осуществляется импорт.--interface
Транспортный код соответствует флагу
--types
, а также включает типы структур фиксированной части IPC-запросов и IPC-ответов для интерфейсных методов, сигнатуры которых указаны в заданном IDL-файле. Кроме того, транспортный код содержит константы с размерами арен IPC-сообщений.--client
Транспортный код соответствует флагу
--interface
, а также включает тип прокси-объекта, метод инициализации прокси-объекта и интерфейсные методы, указанные в заданном IDL-файле.--server
Транспортный код соответствует флагу
--interface
, а также включает типы и диспетчер (dispatch-метод), используемые для обработки IPC-запросов, соответствующих интерфейсным методам, указанным в заданном IDL-файле.
Флаги выборочной генерации транспортного кода для CDL- или EDL-файла:
--types
Транспортный код включает типы, соответствующие IDL-типам, которые используются в параметрах методов служб, предоставляемых компонентом (для заданного CDL-файла) или классом процессов (для заданного EDL-файла).
--endpoints
Транспортный код соответствует флагу
--types
, а также включает типы структур фиксированной части IPC-запросов и IPC-ответов для методов служб, предоставляемых компонентом (для заданного CDL-файла) или классом процессов (для заданного EDL-файла). Кроме того, транспортный код содержит константы с размерами арен IPC-сообщений.--client
Транспортный код соответствует флагу
--types
, а также включает типы структур фиксированной части IPC-запросов и IPC-ответов для методов служб, предоставляемых компонентом (для заданного CDL-файла) или классом процессов (для заданного EDL-файла). Кроме того, транспортный код содержит константы с размерами арен IPC-сообщений, а также типы прокси-объектов, методы инициализации прокси-объектов и методы служб, предоставляемых компонентом (для заданного CDL-файла) или классом процессов (для заданного EDL-файла).--server
Транспортный код соответствует флагу
--types
, а также включает типы и диспетчеры (dispatch-методы), используемые для обработки IPC-запросов, соответствующих службам, предоставляемым компонентом (для заданного CDL-файла) или классом процессов (для заданного EDL-файла). Кроме того, транспортный код содержит константы с размерами арен IPC-сообщений, а также типы стабов, методы инициализации стабов и типы структур фиксированной части IPC-запросов и IPC-ответов для методов служб, предоставляемых компонентом (для заданного CDL-файла) или классом процессов (для заданного EDL-файла).
Вывод диагностических данных об отправке и приеме IPC-сообщений
Транспортный код может формировать диагностические данные об отправке и приеме IPC-сообщений и выводить эти данные через стандартный вывод ошибок. Чтобы генерировать транспортный код с такими возможностями, нужно использовать следующие параметры:
--trace-client-ipc
{headers
|dump
}Код вывода диагностических данных исполняется непосредственно перед выполнением системного вызова
Call()
и сразу после его выполнения. Если указано значениеheaders
, диагностические данные включают идентификатор метода службы (MID), идентификатор службы (RIID), размер фиксированной части IPC-сообщения в байтах, содержимое дескриптора арены IPC-сообщения, размер арены IPC-сообщения в байтах и размер использованной части арены IPC-сообщения в байтах. Если указано значениеdump
, диагностические данные дополнительно включают содержимое фиксированной части и арены IPC-сообщения в шестнадцатеричном представлении.При использовании этого параметра нужно указать флаг выборочной генерации транспортного кода
--client
либо не указывать флаги выборочной генерации транспортного кода.--trace-server-ipc
{headers
|dump
}Код вывода диагностических данных исполняется непосредственно перед вызовом функции, реализующей интерфейсный метод, и сразу после выполнения этой функции, то есть при вызове диспетчера (dispatch-метода) в промежутке между выполнением системных вызовов
Recv()
иReply()
. Если указано значениеheaders
, диагностические данные включают идентификатор метода службы (MID), идентификатор службы (RIID), размер фиксированной части IPC-сообщения в байтах, содержимое дескриптора арены IPC-сообщения, размер арены IPC-сообщения в байтах и размер использованной части арены IPC-сообщения в байтах. Если указано значениеdump
, диагностические данные дополнительно включают содержимое фиксированной части и арены IPC-сообщения в шестнадцатеричном представлении.При использовании этого параметра нужно указать флаг выборочной генерации транспортного кода
--server
либо не указывать флаги выборочной генерации транспортного кода.--ipc-trace-method-filter
<METHOD
>[,METHOD
]...Вывод диагностических данных выполняется, если только вызваны заданные интерфейсные методы. В качестве значения
METHOD
можно использовать имя интерфейсного метода либо конструкцию <имя пакета
>:
<имя интерфейсного метода
>. Имя пакета и имя интерфейсного метода указаны в IDL-файле.Если этот параметр не указан, вывод диагностических данных выполняется при вызове любого интерфейсного метода.
Параметр можно указать многократно. Например, можно указать все требуемые интерфейсные методы в одном параметре или каждый требуемый интерфейсные метод в отдельном параметре.
nk-psl-gen-c
Компилятор nk-psl-gen-c
генерирует исходный код модуля безопасности Kaspersky Security Module на языке C на основе описания политики безопасности решения и IDL-, CDL-, EDL-описаний. Этот код используется скриптом makekss.
Компилятор nk-psl-gen-c
также позволяет генерировать исходный код тестов политики безопасности решения на языке C на основе тестов политики безопасности решения на языке PAL.
Синтаксис shell-команды для запуска компилятора nk-psl-gen-c
:
Параметры:
INPUT
Путь к верхнеуровневому файлу описания политики безопасности решения. Как правило, это файл
security.psl
.- {
-I
|--include-dir
}DIR
>Через эти параметры задаются пути к директориям с IDL-, CDL-, EDL-файлам, относящимися к решению, и пути к директориям, которые содержат вспомогательные файлы из состава KasperskyOS SDK (
common
,sysroot-*-kos/include
,toolchain/include
). - {
-o
|--output
}FILE
>Путь к файлу, в который будет сохранен исходный код модуля безопасности Kaspersky Security Module и опционально исходный код тестов политики безопасности решения. Путь должен включать существующие директории.
--out-tests
<FILE
>Путь к файлу, в который будет сохранен исходный код тестов политики безопасности решения.
- {
-t
|--tests
}ARG
>Задает, нужно ли генерировать исходный код тестов политики безопасности решения.
ARG
может принимать следующие значения:skip
– исходный код тестов не генерируется. Это значение используется по умолчанию, если параметр-t, --tests
<ARG
> не указан.generate
– исходный код тестов генерируется. Если исходный код тестов генерируется, то рекомендуется использовать параметр--out-tests
<FILE
>, иначе исходный код тестов будет сохранен в одном файле с исходным кодом модуля безопасности Kaspersky Security Module, что может привести к ошибкам при сборке.
- {
-a
|--audit
}FILE
>Путь к файлу, в который будет сохранен исходный код декодера аудита на языке C.
-h
|--help
Выводит текст справки.
--version
Выводит версию компилятора
nk-psl-gen-c
.
einit
Утилита einit
позволяет автоматизировать создание кода инициализирующей программы Einit.
Утилита einit
принимает описание инициализации решения (по умолчанию файл init.yaml
), а также EDL-, CDL- и IDL-описания, и создает файл с исходным кодом инициализирующей программы Einit
. Программу Einit
затем необходимо собрать с помощью кросс-компилятора языка C, поставляемого в KasperskyOS Community Edition.
Синтаксис использования утилиты einit
:
Параметры:
FILE
Путь к файлу
init.yaml
.-I PATH
Путь к директории, содержащей вспомогательные файлы (включая EDL-, CDL- и IDL-описания), необходимые для генерации инициализирующей программы. По умолчанию эти файлы располагаются в директории
/opt/KasperskyOS-Community-Edition-<version>/sysroot-aarch64-kos/include
.-o, --out-file PATH
Путь к создаваемому .c файлу с кодом инициализирующей программы.
-h, --help
Отображает текст справки.
makekss
Скрипт makekss
создает модуль безопасности Kaspersky Security Module.
Скрипт вызывает компилятор nk-psl-gen-c для генерации исходного кода модуля безопасности и затем компилирует полученный код, вызывая компилятор C, поставляемый в KasperskyOS Community Edition.
Скрипт создает модуль безопасности из описания политики безопасности решения.
Синтаксис использования скрипта makekss
:
Параметры:
FILE
Путь к верхнеуровневому файлу описания политики безопасности решения.
--target=ARCH
Архитектура процессора, для которой производится сборка.
--module=-lPATH
Путь к библиотеке
ksm_kss
. Этот ключ передается компилятору C для компоновки с этой библиотекой.--with-nk=PATH
Путь к компилятору
nk-psl-gen-c
, который будет использоваться для генерации исходного кода модуля безопасности. По умолчанию компилятор расположен в/opt/KasperskyOS-Community-Edition-<version>/toolchain/bin/nk-psl-gen-c
.--with-nktype="TYPE"
Указывает на тип компилятора NK, который будет использоваться. Для использования компилятора
nk-psl-gen-c
, необходимо указать типpsl
.--with-nkflags="FLAGS"
Параметры, с которыми вызывается компилятор
nk-psl-gen-c
.Компилятору
nk-psl-gen-c
потребуется доступ ко всем EDL- CDL- и IDL-описаниям. Для того, чтобы компиляторnk-psl-gen-c
мог найти эти описания, нужно передать пути к расположению этих описаний в параметре--with-nkflags
, используя параметр-I
компилятораnk-psl-gen-c
.--output=PATH
Путь к создаваемому файлу модуля безопасности.
--with-cc=PATH
Путь к компилятору C, который будет использоваться для сборки модуля безопасности. По умолчанию используется компилятор, поставляемый в KasperskyOS Community Edition.
--with-cflags=FLAGS
Параметры, с которыми вызывается компилятор C.
-h, --help
Отображает текст справки.
makeimg
Скрипт makeimg
создает финальный загружаемый образ решения на базе KasperskyOS со всеми исполняемыми файлами программ и модулем Kaspersky Security Module.
Скрипт принимает список файлов, включая исполняемые файлы всех программ, которые нужно добавить в ROMFS загружаемого образа, и создает следующие файлы:
- образ решения;
- образ решения без таблиц символов (
.stripped
); - образ решения с отладочными таблицами символов (
.dbg.syms
).
Синтаксис использования скрипта makeimg:
Параметры:
FILES
Список путей к файлам, включая исполняемые файлы всех программ, которые нужно добавить в ROMFS.
Модуль безопасности (
ksm.module
) нужно указывать явно, иначе он не будет включен в образ решения. ПрограммуEinit
указывать не нужно, так как она будет включена в образ решения автоматически.--target=ARCH
Архитектура, для которой производится сборка.
--sys-root=PATH
Путь к корневой директории sysroot. По умолчанию эта директория расположена в
/opt/KasperskyOS-Community-Edition-<version>/sysroot-aarch64-kos/
.--with-toolchain=PATH
Путь к набору вспомогательных утилит, необходимых для сборки решения. По умолчанию эти утилиты расположены в
/opt/KasperskyOS-Community-Edition-<version>/toolchain/
.--ldscript=PATH
Путь к скрипту компоновщика, необходимому для сборки решения. По умолчанию этот скрипт расположен в
/opt/KasperskyOS-Community-Edition-<version>/libexec/aarch64-kos/
.--img-src=PATH
Путь к заранее скомпилированному ядру KasperskyOS. По умолчанию ядро расположено в
/opt/KasperskyOS-Community-Edition-<version>/libexec/aarch64-kos/
.--img-dst=PATH
Путь к создаваемому файлу образа.
--with-init=PATH
Путь к исполняемому файлу инициализирующей программы
Einit
.--with-extra-asflags=FLAGS
Дополнительные флаги для ассемблера AS.
--with-extra-ldflags=FLAGS
Дополнительные флаги для компоновщика LD.
-h, --help
Отображает текст справки.
Кросс-компиляторы
В тулчейн из состава KasperskyOS SDK входит один или несколько компиляторов GCC. В директории toolchain/bin
находятся следующие файлы:
- исполняемые файлы компиляторов (например,
x86_64-pc-kos-gcc
,arm-kos-g++
); - исполняемые файлы компоновщиков (например,
x86_64-pc-kos-ld
,arm-kos-ld
); - исполняемые файлы ассемблеров (например,
x86_64-pc-kos-as
,arm-kos-as
);
В GCC, кроме стандартных макросов, определен дополнительный макрос __KOS__=1
. Использование этого макроса упрощает портирование программного кода на KasperskyOS, а также разработку платформонезависимых программ.
Чтобы просмотреть список стандартных макросов GCC, выполните следующую команду:
Особенности работы компоновщика
При выполнении сборки исполняемого файла программы компоновщик по умолчанию связывает следующие библиотеки в указанном порядке:
- libc – стандартная библиотека языка C.
- libm – библиотека, реализующая математические функции стандартной библиотеки языка C.
- libvfs_stubs – библиотека, содержащая заглушки функций ввода/вывода (например,
open
,socket
,read
,write
). - libkos – библиотека для доступа к службам ядра KasperskyOS.
- libenv – библиотека подсистемы настройки окружения программ (переменных окружения, аргументов функции
main
и пользовательских конфигураций). - libsrvtransport-u – библиотека поддержки IPC между процессами и ядром.
Пример сборки без использования CMake
Ниже приведен пример скрипта для сборки простейшего примера. Этот пример содержит единственную прикладную программу Hello
, которая не предоставляет службы.
Приведенный скрипт предназначен только для демонстрации используемых команд сборки.
build.sh