Index: llvm/trunk/lib/CodeGen/TargetLoweringObjectFileImpl.cpp =================================================================== --- llvm/trunk/lib/CodeGen/TargetLoweringObjectFileImpl.cpp +++ llvm/trunk/lib/CodeGen/TargetLoweringObjectFileImpl.cpp @@ -96,7 +96,7 @@ TargetLoweringObjectFile::Initialize(Ctx, TgtM); TM = &TgtM; - bool Large = TgtM.getCodeModel() == CodeModel::Large; + CodeModel::Model CM = TgtM.getCodeModel(); switch (TgtM.getTargetTriple().getArch()) { case Triple::arm: @@ -124,18 +124,23 @@ break; case Triple::x86_64: if (isPositionIndependent()) { - PersonalityEncoding = - dwarf::DW_EH_PE_indirect | dwarf::DW_EH_PE_pcrel | - (Large ? dwarf::DW_EH_PE_sdata8 : dwarf::DW_EH_PE_sdata4); + PersonalityEncoding = dwarf::DW_EH_PE_indirect | dwarf::DW_EH_PE_pcrel | + ((CM == CodeModel::Small || CM == CodeModel::Medium) + ? dwarf::DW_EH_PE_sdata4 : dwarf::DW_EH_PE_sdata8); LSDAEncoding = dwarf::DW_EH_PE_pcrel | - (Large ? dwarf::DW_EH_PE_sdata8 : dwarf::DW_EH_PE_sdata4); + (CM == CodeModel::Small + ? dwarf::DW_EH_PE_sdata4 : dwarf::DW_EH_PE_sdata8); TTypeEncoding = dwarf::DW_EH_PE_indirect | dwarf::DW_EH_PE_pcrel | - (Large ? dwarf::DW_EH_PE_sdata8 : dwarf::DW_EH_PE_sdata4); + ((CM == CodeModel::Small || CM == CodeModel::Medium) + ? dwarf::DW_EH_PE_sdata8 : dwarf::DW_EH_PE_sdata4); } else { PersonalityEncoding = - Large ? dwarf::DW_EH_PE_absptr : dwarf::DW_EH_PE_udata4; - LSDAEncoding = Large ? dwarf::DW_EH_PE_absptr : dwarf::DW_EH_PE_udata4; - TTypeEncoding = Large ? dwarf::DW_EH_PE_absptr : dwarf::DW_EH_PE_udata4; + (CM == CodeModel::Small || CM == CodeModel::Medium) + ? dwarf::DW_EH_PE_udata4 : dwarf::DW_EH_PE_absptr; + LSDAEncoding = (CM == CodeModel::Small) + ? dwarf::DW_EH_PE_udata4 : dwarf::DW_EH_PE_absptr; + TTypeEncoding = (CM == CodeModel::Small) + ? dwarf::DW_EH_PE_udata4 : dwarf::DW_EH_PE_absptr; } break; case Triple::hexagon: Index: llvm/trunk/test/CodeGen/X86/code-model-kernel.ll =================================================================== --- llvm/trunk/test/CodeGen/X86/code-model-kernel.ll +++ llvm/trunk/test/CodeGen/X86/code-model-kernel.ll @@ -0,0 +1,79 @@ +; RUN: llc -mtriple=x86_64-pc-linux-gnu -code-model=kernel %s -o - | FileCheck %s +; CHECK-LABEL: main +; CHECK: .cfi_startproc +; CHECK: .cfi_personality 0, __gxx_personality_v0 +; CHECK: .cfi_lsda 0, [[EXCEPTION_LABEL:.L[^ ]*]] +; CHECK: [[EXCEPTION_LABEL]]: +; CHECK: .byte 0 # @TType Encoding = absptr +; CHECK: .quad _ZTIi + +@_ZTIi = external constant i8* + +; Function Attrs: noinline norecurse optnone uwtable +define i32 @main() #0 personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) { + %1 = alloca i32, align 4 + %2 = alloca i8* + %3 = alloca i32 + %4 = alloca i32, align 4 + store i32 0, i32* %1, align 4 + %5 = call i8* @__cxa_allocate_exception(i64 4) #2 + %6 = bitcast i8* %5 to i32* + store i32 20, i32* %6, align 16 + invoke void @__cxa_throw(i8* %5, i8* bitcast (i8** @_ZTIi to i8*), i8* null) #3 + to label %26 unwind label %7 + +;