diff options
Diffstat (limited to 'lib/CodeGen/CGExpr.cpp')
| -rw-r--r-- | lib/CodeGen/CGExpr.cpp | 17 | 
1 files changed, 15 insertions, 2 deletions
| diff --git a/lib/CodeGen/CGExpr.cpp b/lib/CodeGen/CGExpr.cpp index 98740e8f9aab..90eeddf5cc0b 100644 --- a/lib/CodeGen/CGExpr.cpp +++ b/lib/CodeGen/CGExpr.cpp @@ -3076,6 +3076,17 @@ void CodeGenFunction::EmitCfiCheckFail() {    CGM.addUsedGlobal(F);  } +void CodeGenFunction::EmitUnreachable(SourceLocation Loc) { +  if (SanOpts.has(SanitizerKind::Unreachable)) { +    SanitizerScope SanScope(this); +    EmitCheck(std::make_pair(static_cast<llvm::Value *>(Builder.getFalse()), +                             SanitizerKind::Unreachable), +              SanitizerHandler::BuiltinUnreachable, +              EmitCheckSourceLocation(Loc), None); +  } +  Builder.CreateUnreachable(); +} +  void CodeGenFunction::EmitTrapCheck(llvm::Value *Checked) {    llvm::BasicBlock *Cont = createBasicBlock("cont"); @@ -3790,8 +3801,10 @@ LValue CodeGenFunction::EmitLValueForField(LValue base,        FieldTBAAInfo.Offset +=            Layout.getFieldOffset(field->getFieldIndex()) / CharWidth; -    // Update the final access type. +    // Update the final access type and size.      FieldTBAAInfo.AccessType = CGM.getTBAATypeInfo(FieldType); +    FieldTBAAInfo.Size = +        getContext().getTypeSizeInChars(FieldType).getQuantity();    }    Address addr = base.getAddress(); @@ -4616,7 +4629,7 @@ RValue CodeGenFunction::EmitCall(QualType CalleeType, const CGCallee &OrigCallee      Callee.setFunctionPointer(CalleePtr);    } -  return EmitCall(FnInfo, Callee, ReturnValue, Args); +  return EmitCall(FnInfo, Callee, ReturnValue, Args, nullptr, E->getExprLoc());  }  LValue CodeGenFunction:: | 
