Критическая область
это участок кода, который должен быть до конца выполнен трактом ядра, вошедшим в него, прежде чем в него сможет войти другой тракт ядра.
Чередование трактов ядра усложняет жизнь разработчикам; они должны быть исключительно внимательны при идентификации критических областей в обработчиках исключений, обработчиках прерываний, функциях отложенного выполнения и потоках ядра. Когда критическая область локализована, она должна быть соответствующим образом защищена, чтоб в любой момент времени внутри ее находилось не более одного управляющего тракта ядра.
Предположим, например, что двум разным обработчикам прерываний необходимо обратиться к одной структуре, содержащей несколько взаимосвязанных переменных, скажем, буфер и целое, показывающее его длину. Все операторы, затрагивающие эту структуру, должны быть помещены в одну критическую область. Если в системе только один процессор, критическая область может быть защищена отключением прерываний на время обращения к совместно используемой структуре, поскольку вложенность управляющих трактов ядра может иметь место только при включенных прерываниях.
С другой стороны, если к структуре обращаются только служебные процедуры системных вызовов, а в системе один процессор, то критическую область можно защитить простым отключением вытеснения в ядре на время обращения к совместно используемой структуре.
Читатель уже догадался, что в многопроцессорных системах ситуация гораздо сложнее. Несколько процессоров могут одновременно выполнять код ядра, и разработчики не могут надеяться, что к структуре можно без опаски обращаться только потому, что вытеснение в ядре отключено, а к структуре никогда не обращается обработчик прерываний или softirq-функция.
В следующих разделах мы увидим, что ядро предлагает разработчикам широкий набор разнообразных приемов синхронизации. Разработчикам остается лишь решать каждую проблему синхронизации наиболее подходящими способами.
Предыдущая страница | 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 | Следующая страница