| ; RUN: llc -O3 < %s | FileCheck %s |
| ; |
| ; Check ADRP instr is not hoisted to entry basic block |
| ; which may throw exception. |
| ; |
| ; CHECK: adrp |
| ; CHECK: adrp |
| ; CHECK: adrp |
| |
| target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128" |
| target triple = "aarch64-arm-none-eabi" |
| |
| @var = hidden local_unnamed_addr global i32 0, align 4 |
| @_ZTIi = external dso_local constant ptr |
| declare dso_local void @_Z2fnv() local_unnamed_addr #1 |
| declare dso_local i32 @__gxx_personality_v0(...) |
| declare i32 @llvm.eh.typeid.for(ptr) #2 |
| declare dso_local ptr @__cxa_begin_catch(ptr) local_unnamed_addr |
| declare dso_local void @__cxa_end_catch() local_unnamed_addr |
| |
| define hidden i32 @_Z7examplev() personality ptr @__gxx_personality_v0 { |
| entry: |
| invoke void @_Z2fnv() to label %try.cont unwind label %lpad |
| |
| lpad: ; preds = %entry |
| %0 = landingpad { ptr, i32 } |
| catch ptr @_ZTIi |
| catch ptr null |
| %1 = extractvalue { ptr, i32 } %0, 0 |
| %2 = extractvalue { ptr, i32 } %0, 1 |
| %3 = tail call i32 @llvm.eh.typeid.for(ptr @_ZTIi) |
| %matches = icmp eq i32 %2, %3 |
| %4 = tail call ptr @__cxa_begin_catch(ptr %1) |
| %5 = load i32, ptr @var, align 4 |
| br i1 %matches, label %catch1, label %catch |
| |
| catch1: ; preds = %lpad |
| %or3 = or i32 %5, 4 |
| store i32 %or3, ptr @var, align 4 |
| tail call void @__cxa_end_catch() |
| br label %try.cont |
| |
| try.cont: ; preds = %entry, %catch1, %catch |
| %6 = load i32, ptr @var, align 4 |
| ret i32 %6 |
| |
| catch: ; preds = %lpad |
| %or = or i32 %5, 8 |
| store i32 %or, ptr @var, align 4 |
| tail call void @__cxa_end_catch() |
| br label %try.cont |
| } |