Получение и освобождение блокировки на запись
Макрос writeiock реализован аналогично макросам spiniocko и read iock . Например, если поддерживается вытеснение в ядре, и пытается тут же ПОЛуЧИТЬ СПИН-блОКИрОВКу, ВЫЗВаВ фуНКЦИЮ rawwritetrylockO. Если вызванная функция возвращает 0, значит, спин-блокировка уже занята. Макрос включает вытеснение в ядре и запускает цикл ожидания без прекращения выполнения, как показано в описании макроса spiniock в одном из предыдущих разделов.
Приведем КОД функции rawwritetrylock :
int rawwritetrylock(rwlockt lock)
{atomic_t count = (atomic_t )lock->lock; if (atomic_sub_and_test(0x01000000, count)) return 1; atomic_add(0x01000000, count); return 0;}
Функция rawwritetrylock вычитает охоюооооо из значения спин- блокировки чтения/записи, чтобы сбросить флаг разблокировано” (бит 24). Если в результате вычитания получен ноль (нет читающих потоков), блокировка выделяется, и функция возвращает 1. В противном случае функция атомарно прибавляет охоюооооо к значению спин-блокировки, чтобы отменить операцию вычитания.
И в этом случае освобождение спин-блокировки гораздо проще получения, поскольку макрос write uniock должен установить флаг разблокировано” в поле lock с помощью ассемблерной инструкции:lock; addl $0x01000000,rwlp а затем вызвать функцию preempt_enable .
Предыдущая страница | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 | Следующая страница