X86 X003-L "Fre PodWR Fre Rfi PodRR Fre Rfi PodRR" {} P0 | P1 | P2 ; Lock00: | Lock06: | Lock12: ; MOV %atom,$1 | MOV %atom,$1 | MOV %atom,$1 ; XCHG [L_z],%atom | XCHG [L_x],%atom | XCHG [L_y],%atom ; CMP %atom,$0 | CMP %atom,$0 | CMP %atom,$0 ; JE Lock02 | JE Lock08 | JE Lock14 ; Lock01: | Lock07: | Lock13: ; MOV %atom,[L_z] | MOV %atom,[L_x] | MOV %atom,[L_y] ; CMP %atom,$0 | CMP %atom,$0 | CMP %atom,$0 ; JE Lock00 | JE Lock06 | JE Lock12 ; JMP Lock01 | JMP Lock07 | JMP Lock13 ; Lock02: | Lock08: | Lock14: ; MOV [z],$1 | MOV [x],$1 | MOV [y],$1 ; MOV [L_z],$0 | MOV [L_x],$0 | MOV [L_y],$0 ; Lock03: | MOV EAX,[x] | MOV EAX,[y] ; MOV %atom,$1 | Lock09: | Lock15: ; XCHG [L_x],%atom | MOV %atom,$1 | MOV %atom,$1 ; CMP %atom,$0 | XCHG [L_y],%atom | XCHG [L_z],%atom ; JE Lock05 | CMP %atom,$0 | CMP %atom,$0 ; Lock04: | JE Lock11 | JE Lock17 ; MOV %atom,[L_x] | Lock10: | Lock16: ; CMP %atom,$0 | MOV %atom,[L_y] | MOV %atom,[L_z] ; JE Lock03 | CMP %atom,$0 | CMP %atom,$0 ; JMP Lock04 | JE Lock09 | JE Lock15 ; Lock05: | JMP Lock10 | JMP Lock16 ; MOV EAX,[x] | Lock11: | Lock17: ; MOV [L_x],$0 | MOV EBX,[y] | MOV EBX,[z] ; | MOV [L_y],$0 | MOV [L_z],$0 ; forall (1:EAX=1 /\ 2:EAX=1 /\ (0:EAX=1 /\ (1:EBX=1 /\ (2:EBX=1 \/ 2:EBX=0) \/ 1:EBX=0 /\ (2:EBX=1 \/ 2:EBX=0)) \/ 0:EAX=0 /\ (1:EBX=1 /\ (2:EBX=1 \/ 2:EBX=0) \/ 1:EBX=0 /\ 2:EBX=1)))