Executions for behaviour:
"0:R1=2 ; 0:R2=1 ; 2:R1=0 ; y=1"

Executions for behaviour:
"0:R1=2 ; 0:R2=1 ; 2:R1=1 ; y=1"

Executions for behaviour:
"0:R1=2 ; 0:R2=1 ; 2:R1=2 ; y=1"

Executions for behaviour:
"0:R1=2 ; 0:R2=1 ; 2:R1=2 ; y=2"

ARM DETOUR0999
"PosWR DetourR DpDatadW Wse DMBdWR Fre"
Cycle=Fre PosWR DetourR DpDatadW Wse DMBdWR
Prefetch=0:x=F,0:y=W,1:y=F,1:x=T
Com=Ws Fr
Orig=PosWR DetourR DpDatadW Wse DMBdWR Fre
{
%x0=x; %y0=y;
%x1=x;
%y2=y; %x2=x;
}
P0 | P1 | P2 ;
MOV R0,#1 | MOV R0,#2 | MOV R0,#2 ;
STR R0,[%x0] | STR R0,[%x1] | STR R0,[%y2] ;
LDR R1,[%x0] | | DMB ;
LDR R2,[%x0] | | LDR R1,[%x2] ;
EOR R3,R2,R2 | | ;
ADD R3,R3,#1 | | ;
STR R3,[%y0] | | ;
Observed
0:R1=2; 0:R2=1; 2:R1=0; y=1;
and 0:R1=2; 0:R2=1; 2:R1=1; y=1;
and 0:R1=2; 0:R2=1; 2:R1=2; y=1;
and 0:R1=2; 0:R2=1; 2:R1=2; y=2;