mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
e8b3966318
Currently, it prints the backward branch offset as unsigned value like below: 7: 7d 34 0b 00 00 00 00 00 if r4 s>= r3 goto 11 <LBB0_3> 8: b7 00 00 00 00 00 00 00 r0 = 0 LBB0_2: 9: 07 00 00 00 01 00 00 00 r0 += 1 ...... 17: bf 31 00 00 00 00 00 00 r1 = r3 18: 6d 32 f6 ff 00 00 00 00 if r2 s> r3 goto 65526 <LBB0_3+0x7FFB0> The correct print insn 18 should be: 18: 6d 32 f6 ff 00 00 00 00 if r2 s> r3 goto -10 <LBB0_2> To provide better clarity and be consistent with kernel verifier output, the insn 7 output is changed to the following with "+" added to non-negative branch offset: 7: 7d 34 0b 00 00 00 00 00 if r4 s>= r3 goto +11 <LBB0_3> Signed-off-by: Yonghong Song <yhs@fb.com> Acked-by: Alexei Starovoitov <ast@kernel.org> llvm-svn: 318442
40 lines
1.1 KiB
LLVM
40 lines
1.1 KiB
LLVM
; RUN: llc -march=bpfel -filetype=obj -o - %s | llvm-objdump -d - | FileCheck %s
|
|
|
|
; Source Code:
|
|
; int test(int a, int b) {
|
|
; int s = 0;
|
|
; while (a < b) { s++; a += s; b -= s; }
|
|
; return s;
|
|
; }
|
|
|
|
define i32 @test(i32, i32) local_unnamed_addr #0 {
|
|
; CHECK-LABEL: test:
|
|
%3 = icmp slt i32 %0, %1
|
|
br i1 %3, label %4, label %13
|
|
|
|
; <label>:4: ; preds = %2
|
|
br label %5
|
|
; CHECK: if r4 s>= r3 goto +11 <LBB0_3>
|
|
; CHECK: r0 = 0
|
|
; CHECK-LABEL: LBB0_2:
|
|
|
|
; <label>:5: ; preds = %4, %5
|
|
%6 = phi i32 [ %9, %5 ], [ 0, %4 ]
|
|
%7 = phi i32 [ %11, %5 ], [ %1, %4 ]
|
|
%8 = phi i32 [ %10, %5 ], [ %0, %4 ]
|
|
%9 = add nuw nsw i32 %6, 1
|
|
%10 = add nsw i32 %9, %8
|
|
%11 = sub nsw i32 %7, %9
|
|
%12 = icmp slt i32 %10, %11
|
|
br i1 %12, label %5, label %13
|
|
; CHECK: r1 = r3
|
|
; CHECK: if r2 s> r3 goto -10 <LBB0_2>
|
|
|
|
; <label>:13: ; preds = %5, %2
|
|
%14 = phi i32 [ 0, %2 ], [ %9, %5 ]
|
|
ret i32 %14
|
|
; CHECK-LABEL: LBB0_3:
|
|
; CHECK: exit
|
|
}
|
|
attributes #0 = { norecurse nounwind readnone }
|