GPU_PTX IRWIW+membar.cta+ctrl-p0:p1:p2:p3-xsys "Rf-w-sl2l2 Mcta-d-Rsl2-Wsl2 Ws-w-sl2l2 Rf-w-sl2l2 Ctrl-d-sl2-Wsl2 Ws-w-sl2l2" {} P0 | P1 | P2 | P3 ; mov.s32 r0, 2 | ld.cg.s32 r0, [r1] | mov.s32 r0, 2 | ld.cg.s32 r0, [r1] ; st.cg.s32 [r1], r0 | membar.cta | st.cg.s32 [r1], r0 | and.b32 r2, r0 2147483648 ; | mov.s32 r2, 1 | | setp.eq.b32 p0, r2, 0 ; | st.cg.s32 [r3], r2 | | @p0 bra LC00 ; | | | mov.s64 r4, 3494 ; | | | LC00: ; | | | mov.s32 r3, 1 ; | | | st.cg.s32 [r4], r3 ; exists (0::x=2 /\ 1::y=2 /\ 1:r0=2 /\ 3:r0=2) (device (kernel (cta (warp P0) (warp P1) (warp P2) (warp P3)))) x:local; y:local Generated assembler //START _litmus_P3 ld.cg.s32 sr03, [sr13] ; and.b32 sr23, sr03, 2147483648 ; setp.eq.b32 sp03, sr23, 0 ; @sp03 bra LC00 ; mov.s64 sr43, 3494 ; LC00: mov.s32 sr33, 1 ; st.cg.s32 [sr43], sr33 ; //START _litmus_P2 mov.s32 sr02, 2 ; st.cg.s32 [sr12], sr02 ; //START _litmus_P1 ld.cg.s32 sr01, [sr11] ; membar.cta ; mov.s32 sr21, 1 ; st.cg.s32 [sr31], sr21 ; //START _litmus_P0 mov.s32 sr00, 2 ; st.cg.s32 [sr10], sr00 ; Binary '/tmp/dir88d467.tmp/IRWIW+membar.cta+ctrl-p0:p1:p2:p3-xsys-0.exe' successfully loaded Specification clusters: 4 Specification: [[(620, 3, 'R4'), (619, 2, 'R12')], [(662, 2, 'R10')], [(718, 3, 'R4'), (717, 2, 'R12')], [(768, 2, 'R10')]] Cluster 0: OK Cluster 1: OK Cluster 2: OK Cluster 3: OK !!SUCCESS!! Test IRWIW+membar.cta+ctrl-p0:p1:p2:p3-xsys Allowed Histogram (27 states) 7391 :>1:r0=0; 3:r0=0; 0::x=1; 1::y=1; 6881 :>1:r0=1; 3:r0=0; 0::x=1; 1::y=1; 10254 :>1:r0=2; 3:r0=0; 0::x=1; 1::y=1; 5179 :>1:r0=0; 3:r0=1; 0::x=1; 1::y=1; 2540 :>1:r0=2; 3:r0=1; 0::x=1; 1::y=1; 9332 :>1:r0=0; 3:r0=2; 0::x=1; 1::y=1; 2802 :>1:r0=1; 3:r0=2; 0::x=1; 1::y=1; 12736 :>1:r0=2; 3:r0=2; 0::x=1; 1::y=1; 5126 :>1:r0=0; 3:r0=0; 0::x=2; 1::y=1; 4924 :>1:r0=1; 3:r0=0; 0::x=2; 1::y=1; 3886 :>1:r0=2; 3:r0=0; 0::x=2; 1::y=1; 324 :>1:r0=0; 3:r0=1; 0::x=2; 1::y=1; 3713 :>1:r0=0; 3:r0=2; 0::x=2; 1::y=1; 1168 :>1:r0=1; 3:r0=2; 0::x=2; 1::y=1; 882 :>1:r0=2; 3:r0=2; 0::x=2; 1::y=1; 4831 :>1:r0=0; 3:r0=0; 0::x=1; 1::y=2; 743 :>1:r0=1; 3:r0=0; 0::x=1; 1::y=2; 3795 :>1:r0=2; 3:r0=0; 0::x=1; 1::y=2; 2850 :>1:r0=0; 3:r0=1; 0::x=1; 1::y=2; 894 :>1:r0=2; 3:r0=1; 0::x=1; 1::y=2; 2811 :>1:r0=0; 3:r0=2; 0::x=1; 1::y=2; 759 :>1:r0=2; 3:r0=2; 0::x=1; 1::y=2; 3749 :>1:r0=0; 3:r0=0; 0::x=2; 1::y=2; 1324 :>1:r0=1; 3:r0=0; 0::x=2; 1::y=2; 242 :>1:r0=2; 3:r0=0; 0::x=2; 1::y=2; 646 :>1:r0=0; 3:r0=1; 0::x=2; 1::y=2; 218 :>1:r0=0; 3:r0=2; 0::x=2; 1::y=2; No Witnesses Positive: 0, Negative: 100000 Condition exists (0::x=2 /\ 1::y=2 /\ 1:r0=2 /\ 3:r0=2) is NOT validated Observation IRWIW+membar.cta+ctrl-p0:p1:p2:p3-xsys Never 0 100000 Time IRWIW+membar.cta+ctrl-p0:p1:p2:p3-xsys 27.98 -- device info -- Name: GeForce GTX 660 Major revision number: 3 Minor revision number: 0 Total global memory: 2147155968 Total shared memory per block: 49152 Number of multiprocessors: 5 Machine: csu8975 Revision 967, version 5.01 GPU_PTX experimental backend Command line: ./litmus -gpu -ccopts -arch=sm_30 -gpu-max-ctas 8 -gpu-min-ctas 4 tests-sm30/IRWIW+membar.cta+ctrl-p0:p1:p2:p3-xsys-0.litmus Parameters #ifndef SIZE_OF_TEST #define SIZE_OF_TEST 100000 #endif #ifndef NUMBER_OF_RUN #define NUMBER_OF_RUN 1 #endif /* cc options: -arch=sm_30 */ /* barrier: user */ /* speedcheck: no */ /* gpu_general_bc: true */ /* gpu_mem_stress: true */ /* gpu-rand-threads: true */ /* gpu_cuda: true */ /* gpu_gen_addr: true */ /* gpu_cvt_global_to_gen: true */ /* gpu_cvt_shared_to_gen: true */ /* gpu_max_ctas: 8 */ /* gpu_min_ctas: 4 */ /* gpu_max_threads: 512 */ /* gpu_min_threads: 128 */