mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-16 11:30:51 +00:00
5a70dd1d82
Similar to gep (r230786) and load (r230794) changes. Similar migration script can be used to update test cases, which successfully migrated all of LLVM and Polly, but about 4 test cases needed manually changes in Clang. (this script will read the contents of stdin and massage it into stdout - wrap it in the 'apply.sh' script shown in previous commits + xargs to apply it over a large set of test cases) import fileinput import sys import re rep = re.compile(r"(getelementptr(?:\s+inbounds)?\s*\()((<\d*\s+x\s+)?([^@]*?)(|\s*addrspace\(\d+\))\s*\*(?(3)>)\s*)(?=$|%|@|null|undef|blockaddress|getelementptr|addrspacecast|bitcast|inttoptr|zeroinitializer|<|\[\[[a-zA-Z]|\{\{)", re.MULTILINE | re.DOTALL) def conv(match): line = match.group(1) line += match.group(4) line += ", " line += match.group(2) return line line = sys.stdin.read() off = 0 for match in re.finditer(rep, line): sys.stdout.write(line[off:match.start()]) sys.stdout.write(conv(match)) off = match.end() sys.stdout.write(line[off:]) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@232184 91177308-0d34-0410-b5e6-96231b3b80d8
73 lines
2.5 KiB
LLVM
73 lines
2.5 KiB
LLVM
;RUN: llc -march=sparc < %s | FileCheck %s
|
|
;RUN: llc -march=sparcv9 < %s | FileCheck %s --check-prefix=V9
|
|
|
|
|
|
%0 = type { [32 x i32] }
|
|
%struct.jmpbuf_env = type { i32, i32, [1 x %struct.__jmp_buf_tag], i32 }
|
|
%struct.__jmp_buf_tag = type { [3 x i32], i32, %0 }
|
|
|
|
@jenv = common unnamed_addr global %struct.jmpbuf_env* null
|
|
@.cst = private unnamed_addr constant [30 x i8] c"in bar with jmp_buf's id: %d\0A\00", align 64
|
|
|
|
; CHECK-LABEL: foo
|
|
; CHECK-DAG: st {{.+}}, [%i0]
|
|
; CHECK-DAG: st {{.+}}, [%i0+4]
|
|
; CHECK: call _setjmp
|
|
; CHECK: ld [%fp+{{.+}}], %[[R:[gilo][0-7]]]
|
|
; CHECK: st %o0, [%[[R]]+{{.+}}]
|
|
|
|
; V9-LABEL: foo
|
|
; V9-DAG: st {{.+}}, [%i0]
|
|
; V9-DAG: st {{.+}}, [%i0+4]
|
|
; V9: call _setjmp
|
|
; V9: ldx [%fp+{{.+}}], %[[R:[gilo][0-7]]]
|
|
; V9: st %o0, [%[[R]]+{{.+}}]
|
|
|
|
; Function Attrs: nounwind
|
|
define i32 @foo(%struct.jmpbuf_env* byval %inbuf) #0 {
|
|
entry:
|
|
%0 = getelementptr inbounds %struct.jmpbuf_env, %struct.jmpbuf_env* %inbuf, i32 0, i32 0
|
|
store i32 0, i32* %0, align 4, !tbaa !4
|
|
%1 = getelementptr inbounds %struct.jmpbuf_env, %struct.jmpbuf_env* %inbuf, i32 0, i32 1
|
|
store i32 1, i32* %1, align 4, !tbaa !4
|
|
%2 = getelementptr inbounds %struct.jmpbuf_env, %struct.jmpbuf_env* %inbuf, i32 0, i32 2, i32 0
|
|
%3 = call i32 @_setjmp(%struct.__jmp_buf_tag* %2) #2
|
|
%4 = getelementptr inbounds %struct.jmpbuf_env, %struct.jmpbuf_env* %inbuf, i32 0, i32 3
|
|
store i32 %3, i32* %4, align 4, !tbaa !4
|
|
store %struct.jmpbuf_env* %inbuf, %struct.jmpbuf_env** @jenv, align 4, !tbaa !3
|
|
%5 = load i32, i32* %1, align 4, !tbaa !4
|
|
%6 = icmp eq i32 %5, 1
|
|
%7 = icmp eq i32 %3, 0
|
|
%or.cond = and i1 %6, %7
|
|
br i1 %or.cond, label %"4.i", label %bar.exit
|
|
|
|
"4.i": ; preds = %entry
|
|
call void @longjmp(%struct.__jmp_buf_tag* %2, i32 0) #1
|
|
unreachable
|
|
|
|
bar.exit: ; preds = %entry
|
|
%8 = load i32, i32* %0, align 4, !tbaa !4
|
|
%9 = call i32 (i8*, ...)* @printf(i8* noalias getelementptr inbounds ([30 x i8], [30 x i8]* @.cst, i32 0, i32 0), i32 %8) #0
|
|
ret i32 0
|
|
}
|
|
|
|
; Function Attrs: nounwind returns_twice
|
|
declare i32 @_setjmp(%struct.__jmp_buf_tag*) #2
|
|
|
|
; Function Attrs: noreturn nounwind
|
|
declare void @longjmp(%struct.__jmp_buf_tag*, i32) #1
|
|
|
|
; Function Attrs: nounwind
|
|
declare i32 @printf(i8* nocapture, ...) #0
|
|
|
|
|
|
attributes #0 = { nounwind }
|
|
attributes #1 = { noreturn nounwind }
|
|
attributes #2 = { nounwind returns_twice }
|
|
|
|
!0 = !{!"alias set 6: struct.jmpbuf_env*", !1}
|
|
!1 = !{!1}
|
|
!2 = !{!"alias set 3: int", !1}
|
|
!3 = !{!0, !0, i64 0}
|
|
!4 = !{!2, !2, i64 0}
|