summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/X86/lea-opt-memop-check-2.ll
blob: f3fc95f8be3c2f32b43ca0a12080c9531b86a045 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
; RUN: llc < %s -mtriple=x86_64-pc-linux -mcpu=corei7 -relocation-model=pic | FileCheck %s

; PR27502
; UNREACHABLE: "Invalid address displacement operand"

@buf = internal global [5 x i8*] zeroinitializer

declare i32 @llvm.eh.sjlj.setjmp(i8*) nounwind

define i32 @test() nounwind optsize {
  %r = tail call i32 @llvm.eh.sjlj.setjmp(i8* bitcast ([5 x i8*]* @buf to i8*))
  ret i32 %r
; CHECK-LABEL: test:
; CHECK:	leaq .LBB0_3(%rip), %r[[REG:[a-z]+]]
; CHECK:	movq %r[[REG]], buf+8(%rip)
; CHECK:	#EH_SjLj_Setup .LBB0_3
; CHECK:	xorl %e[[REG]], %e[[REG]]
; CHECK:	jmp .LBB0_2
; CHECK-LABEL: .LBB0_3: # Block address taken
; CHECK-LABEL: .LBB0_2:
}
OpenPOWER on IntegriCloud