mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
178ddc2360
The exit-on-error flag is necessary to avoid some assertions/unreachables. We can get past them by creating a few dummy nodes. Fixes PR27768, PR27769. Differential Revision: http://reviews.llvm.org/D20726 llvm-svn: 271200
18 lines
724 B
LLVM
18 lines
724 B
LLVM
; RUN: not llc -march=bpf < %s 2> %t1
|
|
; RUN: FileCheck %s < %t1
|
|
; CHECK: only integer returns
|
|
|
|
%struct.S = type { i32, i32, i32 }
|
|
|
|
@s = common global %struct.S zeroinitializer, align 4
|
|
|
|
; Function Attrs: nounwind readonly uwtable
|
|
define { i64, i32 } @bar(i32 %a, i32 %b, i32 %c, i32 %d, i32 %e) #0 {
|
|
entry:
|
|
%retval.sroa.0.0.copyload = load i64, i64* bitcast (%struct.S* @s to i64*), align 4
|
|
%retval.sroa.2.0.copyload = load i32, i32* getelementptr inbounds (%struct.S, %struct.S* @s, i64 0, i32 2), align 4
|
|
%.fca.0.insert = insertvalue { i64, i32 } undef, i64 %retval.sroa.0.0.copyload, 0
|
|
%.fca.1.insert = insertvalue { i64, i32 } %.fca.0.insert, i32 %retval.sroa.2.0.copyload, 1
|
|
ret { i64, i32 } %.fca.1.insert
|
|
}
|