官术网_书友最值得收藏!

Software

Software-defined mutual exclusion implementations are all based on busy-waiting. An example is Dekker's algorithm, which defines a system in which two processes can synchronize, employing busy-wait to wait for the other process to leave the critical section.

The pseudocode for this algorithm is as follows:

    variables
wants_to_enter : array of 2 booleans
turn : integer

wants_to_enter[0] ← false
wants_to_enter[1] ← false
turn ← 0 // or 1
p0:
wants_to_enter[0] ← true
while wants_to_enter[1] {
if turn ≠ 0 {
wants_to_enter[0] ← false
while turn ≠ 0 {
// busy wait
}
wants_to_enter[0] ← true
}
}
// critical section
...
turn ← 1
wants_to_enter[0] ← false
// remainder section
p1:
wants_to_enter[1] ← true
while wants_to_enter[0] {
if turn ≠ 1 {
wants_to_enter[1] ← false
while turn ≠ 1 {
// busy wait
}
wants_to_enter[1] ← true
}
}
// critical section
...
turn ← 0
wants_to_enter[1] ← false
// remainder section

(Referenced from: )

In this preceding algorithm, processes indicate the intent to enter a critical section, checking whether it's their turn (using the process ID), then setting their intent to enter the section to false after they have entered it. Only once a process has set its intent to enter to true again will it enter the critical section again. If it wishes to enter, but turn does not match its process ID, it'll busy-wait until the condition becomes true.

A major disadvantage of software-based mutual exclusion algorithms is that they only work if out-of-order (OoO) execution of code is disabled. OoO means that the hardware actively reorders incoming instructions in order to optimize their execution, thus changing their order. Since these algorithms require that various steps are executed in order, they no longer work on OoO processors.

主站蜘蛛池模板: 昭觉县| 济南市| 个旧市| 儋州市| 临朐县| 巴里| 新源县| 措美县| 漳州市| 湟源县| 襄城县| 吉林省| 牟定县| 肥城市| 朔州市| 监利县| 南宫市| 临清市| 重庆市| 邳州市| 都昌县| 剑阁县| 泾源县| 万荣县| 枣阳市| 恩施市| 赫章县| 彭阳县| 敦煌市| 长白| 兴宁市| 涟源市| 高台县| 喀喇| 洛隆县| 平凉市| 襄樊市| 拜泉县| 合肥市| 翁牛特旗| 泊头市|