Mon Dec 28 22:22:40 NFT 2009
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Results for ./src/podrw000.litmus %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
PPC
podrw000
"Wse SyncdWW Rfe PodRW"
{0:r2=y; 0:r4=x; 1:r2=x; 1:r4=y;}
P0 | P1 ;
li r1,2 | lwz r1,0(r2) ;
stw r1,0(r2) | li r3,1 ;
sync | stw r3,0(r4) ;
li r3,1 | ;
stw r3,0(r4) | ;
exists (y=2 /\ 1:r1=1)
Generated assembler
_litmus_P1_0_: lwz 30,0(11)
_litmus_P1_1_: li 31,1
_litmus_P1_2_: stw 31,0(9)
_litmus_P0_0_: li 5,2
_litmus_P0_1_: stw 5,0(11)
_litmus_P0_2_: sync
_litmus_P0_3_: li 4,1
_litmus_P0_4_: stw 4,0(9)
Test podrw000 Allowed
Histogram (3 states)
111938700:>1:r1=1; y=1;
57757158:>1:r1=0; y=1;
150304142:>1:r1=0; y=2;
No
Witnesses
Positive: 0, Negative: 320000000
Condition exists (y=2 /\ 1:r1=1) is NOT validated
Hash=cdbca6b42640c1c580bfff55409bff0a
Cycle=Wse SyncdWW Rfe PodRW
Relax podrw000 No PodRW
Safe=Wse BCSyncdWW
Time podrw000 13.49
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Results for ./src/podrw001.litmus %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
PPC
podrw001
"Wse SyncdWW Rfe PodRW Wse SyncdWW Rfe PodRW"
{0:r2=a; 0:r4=x; 1:r2=x; 1:r4=y; 2:r2=y; 2:r4=z; 3:r2=z; 3:r4=a;}
P0 | P1 | P2 | P3 ;
li r1,2 | lwz r1,0(r2) | li r1,2 | lwz r1,0(r2) ;
stw r1,0(r2) | li r3,1 | stw r1,0(r2) | li r3,1 ;
sync | stw r3,0(r4) | sync | stw r3,0(r4) ;
li r3,1 | | li r3,1 | ;
stw r3,0(r4) | | stw r3,0(r4) | ;
exists (a=2 /\ y=2 /\ 1:r1=1 /\ 3:r1=1)
Generated assembler
_litmus_P3_0_: lwz 30,0(11)
_litmus_P3_1_: li 31,1
_litmus_P3_2_: stw 31,0(9)
_litmus_P2_0_: li 5,2
_litmus_P2_1_: stw 5,0(11)
_litmus_P2_2_: sync
_litmus_P2_3_: li 4,1
_litmus_P2_4_: stw 4,0(9)
_litmus_P1_0_: lwz 30,0(11)
_litmus_P1_1_: li 31,1
_litmus_P1_2_: stw 31,0(9)
_litmus_P0_0_: li 4,2
_litmus_P0_1_: stw 4,0(11)
_litmus_P0_2_: sync
_litmus_P0_3_: li 3,1
_litmus_P0_4_: stw 3,0(9)
Test podrw001 Allowed
Histogram (15 states)
984761:>1:r1=1; 3:r1=1; a=1; y=2;
942814:>1:r1=1; 3:r1=1; a=2; y=1;
1730745:>1:r1=0; 3:r1=1; a=2; y=2;
1735896:>1:r1=1; 3:r1=0; a=2; y=2;
10425822:>1:r1=0; 3:r1=1; a=1; y=2;
10338630:>1:r1=1; 3:r1=0; a=2; y=1;
868631:>1:r1=0; 3:r1=0; a=1; y=1;
13167944:>1:r1=0; 3:r1=1; a=1; y=1;
13288160:>1:r1=1; 3:r1=0; a=1; y=1;
10627670:>1:r1=1; 3:r1=0; a=1; y=2;
10391697:>1:r1=0; 3:r1=1; a=2; y=1;
16142503:>1:r1=0; 3:r1=0; a=2; y=1;
15878600:>1:r1=0; 3:r1=0; a=1; y=2;
33264284:>1:r1=0; 3:r1=0; a=2; y=2;
20211843:>1:r1=1; 3:r1=1; a=1; y=1;
No
Witnesses
Positive: 0, Negative: 160000000
Condition exists (a=2 /\ y=2 /\ 1:r1=1 /\ 3:r1=1) is NOT validated
Hash=1bf24e0898e097d6dee5319da0f77d12
Cycle=Wse SyncdWW Rfe PodRW Wse SyncdWW Rfe PodRW
Relax podrw001 No PodRW
Safe=Wse BCSyncdWW
Time podrw001 21.58
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Results for ./src/podrw002.litmus %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
PPC
podrw002
"Wse SyncdWW Rfe SyncdRW Rfe PodRW"
{0:r2=z; 0:r4=x; 1:r2=x; 1:r4=y; 2:r2=y; 2:r4=z;}
P0 | P1 | P2 ;
li r1,2 | lwz r1,0(r2) | lwz r1,0(r2) ;
stw r1,0(r2) | sync | li r3,1 ;
sync | li r3,1 | stw r3,0(r4) ;
li r3,1 | stw r3,0(r4) | ;
stw r3,0(r4) | | ;
exists (z=2 /\ 1:r1=1 /\ 2:r1=1)
Generated assembler
_litmus_P2_0_: lwz 30,0(11)
_litmus_P2_1_: li 31,1
_litmus_P2_2_: stw 31,0(9)
_litmus_P1_0_: lwz 30,0(11)
_litmus_P1_1_: sync
_litmus_P1_2_: li 31,1
_litmus_P1_3_: stw 31,0(9)
_litmus_P0_0_: li 4,2
_litmus_P0_1_: stw 4,0(11)
_litmus_P0_2_: sync
_litmus_P0_3_: li 3,1
_litmus_P0_4_: stw 3,0(9)
Test podrw002 Allowed
Histogram (7 states)
12684552:>1:r1=1; 2:r1=1; z=1;
18135097:>1:r1=0; 2:r1=1; z=2;
6036548:>1:r1=0; 2:r1=0; z=1;
58562419:>1:r1=0; 2:r1=0; z=2;
49386672:>1:r1=0; 2:r1=1; z=1;
45183500:>1:r1=1; 2:r1=0; z=1;
20011212:>1:r1=1; 2:r1=0; z=2;
No
Witnesses
Positive: 0, Negative: 210000000
Condition exists (z=2 /\ 1:r1=1 /\ 2:r1=1) is NOT validated
Hash=63fda5260d684056b54f65990cd3e6c9
Cycle=Wse SyncdWW Rfe SyncdRW Rfe PodRW
Relax podrw002 No PodRW
Safe=Wse BCSyncdWW BCSyncdRW
Time podrw002 17.70
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Results for ./src/podrw003.litmus %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
PPC
podrw003
"Wse SyncdWW Rfe SyncdRW Rfe SyncdRW Rfe PodRW"
{0:r2=a; 0:r4=x; 1:r2=x; 1:r4=y; 2:r2=y; 2:r4=z; 3:r2=z; 3:r4=a;}
P0 | P1 | P2 | P3 ;
li r1,2 | lwz r1,0(r2) | lwz r1,0(r2) | lwz r1,0(r2) ;
stw r1,0(r2) | sync | sync | li r3,1 ;
sync | li r3,1 | li r3,1 | stw r3,0(r4) ;
li r3,1 | stw r3,0(r4) | stw r3,0(r4) | ;
stw r3,0(r4) | | | ;
exists (a=2 /\ 1:r1=1 /\ 2:r1=1 /\ 3:r1=1)
Generated assembler
_litmus_P3_0_: lwz 30,0(11)
_litmus_P3_1_: li 31,1
_litmus_P3_2_: stw 31,0(9)
_litmus_P2_0_: lwz 30,0(11)
_litmus_P2_1_: sync
_litmus_P2_2_: li 31,1
_litmus_P2_3_: stw 31,0(9)
_litmus_P1_0_: lwz 30,0(11)
_litmus_P1_1_: sync
_litmus_P1_2_: li 31,1
_litmus_P1_3_: stw 31,0(9)
_litmus_P0_0_: li 4,2
_litmus_P0_1_: stw 4,0(11)
_litmus_P0_2_: sync
_litmus_P0_3_: li 3,1
_litmus_P0_4_: stw 3,0(9)
Test podrw003 Allowed
Histogram (15 states)
662894:>1:r1=1; 2:r1=1; 3:r1=1; a=1;
1071141:>1:r1=0; 2:r1=1; 3:r1=1; a=2;
1197924:>1:r1=1; 2:r1=0; 3:r1=1; a=2;
1206833:>1:r1=1; 2:r1=1; 3:r1=0; a=2;
22776687:>1:r1=1; 2:r1=0; 3:r1=1; a=1;
11729860:>1:r1=1; 2:r1=0; 3:r1=0; a=2;
1298421:>1:r1=0; 2:r1=0; 3:r1=0; a=1;
12034267:>1:r1=0; 2:r1=0; 3:r1=1; a=2;
8200433:>1:r1=1; 2:r1=1; 3:r1=0; a=1;
28960047:>1:r1=0; 2:r1=1; 3:r1=0; a=2;
14451971:>1:r1=0; 2:r1=1; 3:r1=0; a=1;
14397236:>1:r1=1; 2:r1=0; 3:r1=0; a=1;
18585881:>1:r1=0; 2:r1=0; 3:r1=0; a=2;
7679506:>1:r1=0; 2:r1=1; 3:r1=1; a=1;
15746899:>1:r1=0; 2:r1=0; 3:r1=1; a=1;
No
Witnesses
Positive: 0, Negative: 160000000
Condition exists (a=2 /\ 1:r1=1 /\ 2:r1=1 /\ 3:r1=1) is NOT validated
Hash=3ecc0c0abdbd62deb73054a63399a7c3
Cycle=Wse SyncdWW Rfe SyncdRW Rfe SyncdRW Rfe PodRW
Relax podrw003 No PodRW
Safe=Wse BCSyncdWW BCSyncdRW
Time podrw003 22.39
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Results for ./src/podrw004.litmus %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
PPC
podrw004
"Wse SyncdWW Rfe SyncdRW Rfe SyncdRW Rfe SyncdRW Rfe PodRW"
{0:r2=b; 0:r4=x; 1:r2=x; 1:r4=y; 2:r2=y; 2:r4=z; 3:r2=z; 3:r4=a; 4:r2=a; 4:r4=b;}
P0 | P1 | P2 | P3 | P4 ;
li r1,2 | lwz r1,0(r2) | lwz r1,0(r2) | lwz r1,0(r2) | lwz r1,0(r2) ;
stw r1,0(r2) | sync | sync | sync | li r3,1 ;
sync | li r3,1 | li r3,1 | li r3,1 | stw r3,0(r4) ;
li r3,1 | stw r3,0(r4) | stw r3,0(r4) | stw r3,0(r4) | ;
stw r3,0(r4) | | | | ;
exists (b=2 /\ 1:r1=1 /\ 2:r1=1 /\ 3:r1=1 /\ 4:r1=1)
Generated assembler
_litmus_P4_0_: lwz 30,0(11)
_litmus_P4_1_: li 31,1
_litmus_P4_2_: stw 31,0(9)
_litmus_P3_0_: lwz 30,0(11)
_litmus_P3_1_: sync
_litmus_P3_2_: li 31,1
_litmus_P3_3_: stw 31,0(9)
_litmus_P2_0_: lwz 30,0(11)
_litmus_P2_1_: sync
_litmus_P2_2_: li 31,1
_litmus_P2_3_: stw 31,0(9)
_litmus_P1_0_: lwz 30,0(11)
_litmus_P1_1_: sync
_litmus_P1_2_: li 31,1
_litmus_P1_3_: stw 31,0(9)
_litmus_P0_0_: li 31,2
_litmus_P0_1_: stw 31,0(11)
_litmus_P0_2_: sync
_litmus_P0_3_: li 3,1
_litmus_P0_4_: stw 3,0(9)
Test podrw004 Allowed
Histogram (31 states)
19146 :>1:r1=1; 2:r1=1; 3:r1=1; 4:r1=1; b=1;
522814:>1:r1=0; 2:r1=1; 3:r1=1; 4:r1=1; b=1;
32194 :>1:r1=0; 2:r1=1; 3:r1=1; 4:r1=1; b=2;
44885 :>1:r1=1; 2:r1=1; 3:r1=1; 4:r1=0; b=2;
36576 :>1:r1=1; 2:r1=0; 3:r1=1; 4:r1=1; b=2;
43239 :>1:r1=1; 2:r1=1; 3:r1=0; 4:r1=1; b=2;
3238708:>1:r1=1; 2:r1=0; 3:r1=1; 4:r1=1; b=1;
3177985:>1:r1=0; 2:r1=0; 3:r1=1; 4:r1=1; b=1;
774712:>1:r1=0; 2:r1=0; 3:r1=1; 4:r1=1; b=2;
880955:>1:r1=1; 2:r1=0; 3:r1=0; 4:r1=1; b=2;
4195940:>1:r1=1; 2:r1=0; 3:r1=0; 4:r1=0; b=2;
897692:>1:r1=1; 2:r1=1; 3:r1=0; 4:r1=0; b=2;
3069543:>1:r1=0; 2:r1=1; 3:r1=1; 4:r1=0; b=1;
4804218:>1:r1=1; 2:r1=0; 3:r1=1; 4:r1=0; b=2;
3380092:>1:r1=1; 2:r1=1; 3:r1=0; 4:r1=1; b=1;
10651088:>1:r1=1; 2:r1=0; 3:r1=0; 4:r1=1; b=1;
10711062:>1:r1=0; 2:r1=1; 3:r1=0; 4:r1=1; b=1;
10332552:>1:r1=1; 2:r1=0; 3:r1=1; 4:r1=0; b=1;
570141:>1:r1=1; 2:r1=1; 3:r1=1; 4:r1=0; b=1;
4277549:>1:r1=0; 2:r1=1; 3:r1=1; 4:r1=0; b=2;
3694293:>1:r1=0; 2:r1=1; 3:r1=0; 4:r1=0; b=1;
3058089:>1:r1=1; 2:r1=1; 3:r1=0; 4:r1=0; b=1;
4327604:>1:r1=0; 2:r1=0; 3:r1=0; 4:r1=1; b=2;
3913172:>1:r1=0; 2:r1=0; 3:r1=1; 4:r1=0; b=1;
3655357:>1:r1=1; 2:r1=0; 3:r1=0; 4:r1=0; b=1;
12973204:>1:r1=0; 2:r1=1; 3:r1=0; 4:r1=0; b=2;
4029096:>1:r1=0; 2:r1=0; 3:r1=0; 4:r1=1; b=1;
12934499:>1:r1=0; 2:r1=0; 3:r1=1; 4:r1=0; b=2;
257191:>1:r1=0; 2:r1=0; 3:r1=0; 4:r1=0; b=1;
4692442:>1:r1=0; 2:r1=0; 3:r1=0; 4:r1=0; b=2;
4803962:>1:r1=0; 2:r1=1; 3:r1=0; 4:r1=1; b=2;
No
Witnesses
Positive: 0, Negative: 120000000
Condition exists (b=2 /\ 1:r1=1 /\ 2:r1=1 /\ 3:r1=1 /\ 4:r1=1) is NOT validated
Hash=0a5d1f6d4d1fe8e45903c66be35a69dd
Cycle=Wse SyncdWW Rfe SyncdRW Rfe SyncdRW Rfe SyncdRW Rfe PodRW
Relax podrw004 No PodRW
Safe=Wse BCSyncdWW BCSyncdRW
Time podrw004 24.31
$Revision: 3163 $
Parameters
#ifndef SIZE_OF_TEST
#define SIZE_OF_TEST 100000
#endif
#ifndef NUMBER_OF_RUN
#define NUMBER_OF_RUN 10
#endif
#ifndef N_EXE
#define N_EXE (64 < N ? 1 : 64 / N)
#endif
/* gcc options: -Wall -std=gnu99 -O -pthread -maix64 */
/* barrier: user */
/* tread start/join: changing */
/* memory: indirect */
/* safer: false */
/* preload: true */
/* para: self */
/* changes: false */
/* speedcheck: false */
/* proc used: 64 */
GCCOPTS="-Wall -std=gnu99 -O -pthread -maix64"
LITMUSOPTS=-r 100
Mon Dec 28 22:24:20 NFT 2009