Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(135)

Side by Side Diff: tests_lit/llvm2ice_tests/nacl-other-intrinsics.ll

Issue 1745393002: Subzero. ARM32. Reverts cl 1687553002. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « tests_lit/llvm2ice_tests/nacl-mem-intrinsics.ll ('k') | tests_lit/llvm2ice_tests/nonsfi.ll » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 ; This tests the NaCl intrinsics not related to atomic operations. 1 ; This tests the NaCl intrinsics not related to atomic operations.
2 2
3 ; RUN: %if --need=target_X8632 --command %p2i --filetype=obj --disassemble \ 3 ; RUN: %if --need=target_X8632 --command %p2i --filetype=obj --disassemble \
4 ; RUN: --target x8632 --sandbox -i %s --args -O2 \ 4 ; RUN: --target x8632 --sandbox -i %s --args -O2 \
5 ; RUN: -allow-externally-defined-symbols \ 5 ; RUN: -allow-externally-defined-symbols \
6 ; RUN: | %if --need=target_X8632 --command FileCheck %s 6 ; RUN: | %if --need=target_X8632 --command FileCheck %s
7 ; RUN: %if --need=target_X8632 --command %p2i --filetype=obj --disassemble \ 7 ; RUN: %if --need=target_X8632 --command %p2i --filetype=obj --disassemble \
8 ; RUN: --target x8632 --sandbox -i %s --args -Om1 \ 8 ; RUN: --target x8632 --sandbox -i %s --args -Om1 \
9 ; RUN: -allow-externally-defined-symbols \ 9 ; RUN: -allow-externally-defined-symbols \
10 ; RUN: | %if --need=target_X8632 --command FileCheck %s 10 ; RUN: | %if --need=target_X8632 --command FileCheck %s
(...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after
122 NonZero: 122 NonZero:
123 ret i32 1 123 ret i32 1
124 } 124 }
125 ; CHECK-LABEL: test_setjmplongjmp 125 ; CHECK-LABEL: test_setjmplongjmp
126 ; CHECK: call {{.*}} R_{{.*}} setjmp 126 ; CHECK: call {{.*}} R_{{.*}} setjmp
127 ; CHECK: call {{.*}} R_{{.*}} longjmp 127 ; CHECK: call {{.*}} R_{{.*}} longjmp
128 ; CHECKO2REM-LABEL: test_setjmplongjmp 128 ; CHECKO2REM-LABEL: test_setjmplongjmp
129 ; CHECKO2REM: call {{.*}} R_{{.*}} setjmp 129 ; CHECKO2REM: call {{.*}} R_{{.*}} setjmp
130 ; CHECKO2REM: call {{.*}} R_{{.*}} longjmp 130 ; CHECKO2REM: call {{.*}} R_{{.*}} longjmp
131 ; ARM32-LABEL: test_setjmplongjmp 131 ; ARM32-LABEL: test_setjmplongjmp
132 ; ARM32: movw [[CALL:r[0-9]]], {{.+}} setjmp 132 ; ARM32: bl {{.*}} setjmp
133 ; ARM32: movt [[CALL]] 133 ; ARM32: bl {{.*}} longjmp
134 ; ARM32: blx [[CALL]]
135 ; ARM32: movw [[CALL:r[0-9]]], {{.+}} longjmp
136 ; ARM32: movt [[CALL]]
137 ; ARM32: blx [[CALL]]
138 134
139 define internal i32 @test_setjmp_unused(i32 %iptr_env, i32 %i_other) { 135 define internal i32 @test_setjmp_unused(i32 %iptr_env, i32 %i_other) {
140 entry: 136 entry:
141 %env = inttoptr i32 %iptr_env to i8* 137 %env = inttoptr i32 %iptr_env to i8*
142 %i = call i32 @llvm.nacl.setjmp(i8* %env) 138 %i = call i32 @llvm.nacl.setjmp(i8* %env)
143 ret i32 %i_other 139 ret i32 %i_other
144 } 140 }
145 ; Don't consider setjmp side-effect free, so it's not eliminated if 141 ; Don't consider setjmp side-effect free, so it's not eliminated if
146 ; result unused. 142 ; result unused.
147 ; CHECKO2REM-LABEL: test_setjmp_unused 143 ; CHECKO2REM-LABEL: test_setjmp_unused
(...skipping 320 matching lines...) Expand 10 before | Expand all | Expand 10 after
468 ; ARM32: mov {{.*}}, #0 464 ; ARM32: mov {{.*}}, #0
469 465
470 define internal i32 @test_popcount_32(i32 %x) { 466 define internal i32 @test_popcount_32(i32 %x) {
471 entry: 467 entry:
472 %r = call i32 @llvm.ctpop.i32(i32 %x) 468 %r = call i32 @llvm.ctpop.i32(i32 %x)
473 ret i32 %r 469 ret i32 %r
474 } 470 }
475 ; CHECK-LABEL: test_popcount_32 471 ; CHECK-LABEL: test_popcount_32
476 ; CHECK: call {{.*}} R_{{.*}} __popcountsi2 472 ; CHECK: call {{.*}} R_{{.*}} __popcountsi2
477 ; ARM32-LABEL: test_popcount_32 473 ; ARM32-LABEL: test_popcount_32
478 ; ARM32: movw [[CALL:r[0-9]]], {{.+}} __popcountsi2 474 ; ARM32: bl {{.*}} __popcountsi2
479 ; ARM32: movt [[CALL]]
480 ; ARM32: blx [[CALL]]
481 475
482 define internal i64 @test_popcount_64(i64 %x) { 476 define internal i64 @test_popcount_64(i64 %x) {
483 entry: 477 entry:
484 %r = call i64 @llvm.ctpop.i64(i64 %x) 478 %r = call i64 @llvm.ctpop.i64(i64 %x)
485 ret i64 %r 479 ret i64 %r
486 } 480 }
487 ; CHECK-LABEL: test_popcount_64 481 ; CHECK-LABEL: test_popcount_64
488 ; CHECK: call {{.*}} R_{{.*}} __popcountdi2 482 ; CHECK: call {{.*}} R_{{.*}} __popcountdi2
489 ; __popcountdi2 only returns a 32-bit result, so clear the upper bits of 483 ; __popcountdi2 only returns a 32-bit result, so clear the upper bits of
490 ; the return value just in case. 484 ; the return value just in case.
491 ; CHECK: mov {{.*}},0x0 485 ; CHECK: mov {{.*}},0x0
492 ; ARM32-LABEL: test_popcount_64 486 ; ARM32-LABEL: test_popcount_64
493 ; ARM32: movw [[CALL:r[0-9]]], {{.+}} __popcountdi2 487 ; ARM32: bl {{.*}} __popcountdi2
494 ; ARM32: movt [[CALL]]
495 ; ARM32: blx [[CALL]]
496 ; ARM32: mov {{.*}}, #0 488 ; ARM32: mov {{.*}}, #0
497 489
498 define internal i32 @test_popcount_64_ret_i32(i64 %x) { 490 define internal i32 @test_popcount_64_ret_i32(i64 %x) {
499 entry: 491 entry:
500 %r_i64 = call i64 @llvm.ctpop.i64(i64 %x) 492 %r_i64 = call i64 @llvm.ctpop.i64(i64 %x)
501 %r = trunc i64 %r_i64 to i32 493 %r = trunc i64 %r_i64 to i32
502 ret i32 %r 494 ret i32 %r
503 } 495 }
504 ; If there is a trunc, then the mov {{.*}}, 0 is dead and gets optimized out. 496 ; If there is a trunc, then the mov {{.*}}, 0 is dead and gets optimized out.
505 ; CHECKO2REM-LABEL: test_popcount_64_ret_i32 497 ; CHECKO2REM-LABEL: test_popcount_64_ret_i32
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
555 ; CHECK: lea {{.*}},[esp+0x10] 547 ; CHECK: lea {{.*}},[esp+0x10]
556 ; CHECK: lea {{.*}},[esp+0x10] 548 ; CHECK: lea {{.*}},[esp+0x10]
557 ; CHECK: call 549 ; CHECK: call
558 ; CHECK: mov esp,{{.*}} 550 ; CHECK: mov esp,{{.*}}
559 ; CHECK: mov esp,ebp 551 ; CHECK: mov esp,ebp
560 ; ARM32-LABEL: test_stacksave_multiple 552 ; ARM32-LABEL: test_stacksave_multiple
561 ; ARM32: mov {{.*}}, sp 553 ; ARM32: mov {{.*}}, sp
562 ; ARM32: mov {{.*}}, sp 554 ; ARM32: mov {{.*}}, sp
563 ; ARM32: mov {{.*}}, sp 555 ; ARM32: mov {{.*}}, sp
564 ; ARM32: mov sp, {{.*}} 556 ; ARM32: mov sp, {{.*}}
OLDNEW
« no previous file with comments | « tests_lit/llvm2ice_tests/nacl-mem-intrinsics.ll ('k') | tests_lit/llvm2ice_tests/nonsfi.ll » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698