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

Executions for behaviour:
"0:R1=3 ; 0:R2=1 ; 3:R0=0 ; 3:R2=0"

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

Executions for behaviour:
"0:R1=3 ; 0:R2=1 ; 3:R0=0 ; 3:R2=1"

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

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

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

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

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

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

Executions for behaviour:
"0:R1=3 ; 0:R2=1 ; 3:R0=0 ; 3:R2=3"

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

Executions for behaviour:
"0:R1=3 ; 0:R2=1 ; 3:R0=1 ; 3:R2=3"

ARM DETOUR0152
"DetourW DetourR PodRW Rfe DpAddrdR Fre"
Cycle=Rfe DpAddrdR Fre DetourW DetourR PodRW
Prefetch=0:x=F,0:y=W,1:y=F,1:x=T
Com=Rf Fr
Orig=DetourW DetourR PodRW Rfe DpAddrdR Fre
{
%x0=x; %y0=y;
%x1=x;
%x2=x;
%y3=y; %x3=x;
}
P0 | P1 | P2 | P3 ;
MOV R0,#1 | MOV R0,#2 | MOV R0,#3 | LDR R0,[%y3] ;
STR R0,[%x0] | STR R0,[%x1] | STR R0,[%x2] | EOR R1,R0,R0 ;
LDR R1,[%x0] | | | LDR R2,[R1,%x3] ;
LDR R2,[%x0] | | | ;
MOV R3,#1 | | | ;
STR R3,[%y0] | | | ;
Observed
0:R1=2; 0:R2=1; 3:R0=0; 3:R2=0;
and 0:R1=3; 0:R2=1; 3:R0=0; 3:R2=0;
and 0:R1=2; 0:R2=1; 3:R0=0; 3:R2=1;
and 0:R1=3; 0:R2=1; 3:R0=0; 3:R2=1;
and 0:R1=2; 0:R2=1; 3:R0=1; 3:R2=1;
and 0:R1=2; 0:R2=1; 3:R0=0; 3:R2=2;
and 0:R1=3; 0:R2=1; 3:R0=0; 3:R2=2;
and 0:R1=2; 0:R2=1; 3:R0=1; 3:R2=2;
and 0:R1=3; 0:R2=1; 3:R0=1; 3:R2=2;
and 0:R1=2; 0:R2=1; 3:R0=0; 3:R2=3;
and 0:R1=3; 0:R2=1; 3:R0=0; 3:R2=3;
and 0:R1=2; 0:R2=1; 3:R0=1; 3:R2=3;
and 0:R1=3; 0:R2=1; 3:R0=1; 3:R2=3;