API определен в заголовочном файле sysroot-*-kos/include/kos/semaphore.h из состава KasperskyOS SDK. Также в составе KasperskyOS SDK поставляется заголовочный файл sysroot-*-kos/include/kos/sync_api.h, который дает возможность транзитивно включить в исходный код программы заголовочный файл semaphore.h и заголовочные файлы для использования других примитивов синхронизации.
API предназначен для синхронизации потоков исполнения на основе семафоров. Семафор – примитив синхронизации, основанный на счетчике, значение которого может быть атомарно изменено. Значение счетчика обычно отражает число доступных разделяемых между потоками исполнения ресурсов. Для исполнения критической секции поток ожидает, пока значение счетчика не станет больше нуля. Если значение счетчика больше нуля, то оно уменьшается на единицу, и поток исполняет критическую секцию. После исполнения критической секции поток исполнения сигнализирует семафор, в результате чего значение счетчика увеличивается.
Сведения о функциях API приведены в таблице ниже.
Использование API
Типовой сценарий использования API включает следующие шаги:
KosSemaphoreInit().KosSemaphoreWait(), KosSemaphoreWaitTimeout() или KosSemaphoreTryWait().KosSemaphoreSignal() или KosSemaphoreSignalN().KosSemaphoreDeinit().Сведения о функциях API
Функции semaphore.h
Функция |
Сведения о функции |
|---|---|
|
Назначение Инициализирует семафор. Параметры
Возвращаемые значения В случае успеха возвращает Если значение в параметре |
|
Назначение Освобождает ресурсы семафора. Параметры
Возвращаемые значения В случае успеха возвращает Если есть потоки исполнения, ожидающие семафор, возвращает |
|
Назначение Сигнализирует семафор с увеличением счетчика на единицу. Параметры
Возвращаемые значения В случае успеха возвращает |
|
Назначение Сигнализирует семафор с увеличением счетчика на заданное число. Параметры
Возвращаемые значения В случае успеха возвращает |
|
Назначение Ожидает семафор не дольше заданного времени. Параметры
Возвращаемые значения В случае успеха возвращает Если время ожидания истекло, возвращает Дополнительные сведения Неблокирующий вызов, если в параметре |
|
Назначение Ожидает семафор сколь угодно долго. Параметры
Возвращаемые значения В случае успеха возвращает |
|
Назначение Ожидает семафор. Если счетчик семафора имеет нулевое значение, не ожидает увеличения счетчика этого семафора, а возвращает управление. Параметры
Возвращаемые значения В случае успеха возвращает Если счетчик семафора имеет нулевое значение, возвращает |