atomic_toggle()

Безопасно переключить биты в переменной

Прототип:

#include <atomic.h>
void atomic_toggle( volatile unsigned *loc,
unsigned bits );

Аргументы:

loc
Указатель на переменную в которой требуется переключить биты.
bits
Биты, которые требуется переключить.

Библиотека:

libc

Описание:

Функция atomic_toggle() представляет собой потокобезопасный способ выполнения операции (*loc) ^= bits.

Функции atomic_*() гарантировано выполняются без вытеснения другим потоком. При модификации переменной совместно используемой в потоке и прерываниях, необходимо либо запрещать прерывания, либо использовать функции atomic_*().

Функции atomic_*() полезны для модификации переменной используемой в нескольких потоках (которые не обязательно принадлежат одному процессу) без необходимости в использовании мьютекса.


Caution: Производите атомарные операции только с объектами находящимися в памяти с нормальным мапированием. На определённых процессорах (например некоторые PPC) атомарные операции будут вызывать сбои, если объект находится в памяти без кэширования.

Примеры:

Безопасное переключение битов 0xdeadbeef в переменной flags:

#include <atomic.h>
...
volatile unsigned flags;
...
atomic_toggle( &flags, 0xdeadbeef );

Классификация:

ЗОСРВ «Нейтрино»

Безопасность использования
Точка остановки потока
Нет
Обработчик прерываний
Да
Обработчик сигналов
Да
В потоке
Да

Тематические ссылки:

atomic_add(), atomic_add_value(), atomic_clr(), atomic_clr_value(), atomic_set(), atomic_set_value(), atomic_sub(), atomic_sub_value(), atomic_toggle_value()




Предыдущий раздел: Описание API системной библиотеки