Executions for behaviour:
"0:R3=5 ; 1:R0=4 ; 1:R2=5 ; 2:R0=1 ; 2:R2=3"

Executions for behaviour:
"0:R3=3 ; 1:R0=1 ; 1:R2=3 ; 2:R0=0 ; 2:R2=5"

ARM MOREDETOUR0290
"DetourWW Wsi Rfi DpDatadW Rfe DpDatadW Wse"
Cycle=Rfi DpDatadW Rfe DpDatadW Wse DetourWW Wsi
Prefetch=0:x=F,0:y=W,1:y=F,1:x=W
Com=Rf Ws
Orig=DetourWW Wsi Rfi DpDatadW Rfe DpDatadW Wse
{
%x0=x; %y0=y;
%x1=x;
%y2=y; %x2=x;
}
P0 | P1 | P2 ;
MOV R0,#2 | LDR R0,[%x1] | LDR R0,[%y2] ;
STR R0,[%x0] | MOV R1,#3 | EOR R1,R0,R0 ;
MOV R1,#4 | STR R1,[%x1] | ADD R1,R1,#1 ;
STR R1,[%x0] | DMB | STR R1,[%x2] ;
MOV R2,#5 | LDR R2,[%x1] | DMB ;
STR R2,[%x0] | | LDR R2,[%x2] ;
LDR R3,[%x0] | | ;
EOR R4,R3,R3 | | ;
ADD R4,R4,#1 | | ;
STR R4,[%y0] | | ;
Observed
0:R3=5; 1:R0=4; 1:R2=5; 2:R0=1; 2:R2=3;
and 0:R3=3; 1:R0=1; 1:R2=3; 2:R0=0; 2:R2=5;