diff options
| author | Mon P Wang <wangmp@apple.com> | 2010-04-02 18:04:30 +0000 | 
|---|---|---|
| committer | Mon P Wang <wangmp@apple.com> | 2010-04-02 18:04:30 +0000 | 
| commit | 4b82a8876434e76921f15f4b395440179515b7b5 (patch) | |
| tree | 4448cfe3e8b6a8c30234950cb8d35adfa0442ee4 /clang/lib/CodeGen | |
| parent | a972ab8564c8c7ad1afaa0f32e25c15db42493a7 (diff) | |
| download | bcm5719-llvm-4b82a8876434e76921f15f4b395440179515b7b5.tar.gz bcm5719-llvm-4b82a8876434e76921f15f4b395440179515b7b5.zip  | |
Reapply patch for adding support for address spaces and added a isVolatile field to memcpy, memmove, and memset. 
llvm-svn: 100193
Diffstat (limited to 'clang/lib/CodeGen')
| -rw-r--r-- | clang/lib/CodeGen/CGBuiltin.cpp | 46 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CGDecl.cpp | 14 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CGExprAgg.cpp | 23 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CodeGenFunction.cpp | 6 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CodeGenModule.cpp | 30 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CodeGenModule.h | 14 | 
6 files changed, 89 insertions, 44 deletions
diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp index a9b0b645a4a..38c40ed489d 100644 --- a/clang/lib/CodeGen/CGBuiltin.cpp +++ b/clang/lib/CodeGen/CGBuiltin.cpp @@ -338,38 +338,50 @@ RValue CodeGenFunction::EmitBuiltinExpr(const FunctionDecl *FD,    case Builtin::BIbzero:    case Builtin::BI__builtin_bzero: {      Value *Address = EmitScalarExpr(E->getArg(0)); -    Builder.CreateCall4(CGM.getMemSetFn(), Address, -                        llvm::ConstantInt::get(llvm::Type::getInt8Ty(VMContext), 0), -                        EmitScalarExpr(E->getArg(1)), -                        llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1)); +    Value *SizeVal = EmitScalarExpr(E->getArg(1)); +    Builder.CreateCall5(CGM.getMemSetFn(Address->getType(), SizeVal->getType()), +                   Address, +                   llvm::ConstantInt::get(llvm::Type::getInt8Ty(VMContext), 0), +                   SizeVal, +                   llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1), +                   llvm::ConstantInt::get(llvm::Type::getInt1Ty(VMContext), 0));      return RValue::get(Address);    }    case Builtin::BImemcpy:    case Builtin::BI__builtin_memcpy: {      Value *Address = EmitScalarExpr(E->getArg(0)); -    Builder.CreateCall4(CGM.getMemCpyFn(), Address, -                        EmitScalarExpr(E->getArg(1)), -                        EmitScalarExpr(E->getArg(2)), -                        llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1)); +    Value *SrcAddr = EmitScalarExpr(E->getArg(1)); +    Value *SizeVal = EmitScalarExpr(E->getArg(2)); +    Builder.CreateCall5(CGM.getMemCpyFn(Address->getType(), SrcAddr->getType(), +                                        SizeVal->getType()), +                  Address, SrcAddr, SizeVal,  +                  llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1), +                  llvm::ConstantInt::get(llvm::Type::getInt1Ty(VMContext), 0));      return RValue::get(Address);    }    case Builtin::BImemmove:    case Builtin::BI__builtin_memmove: {      Value *Address = EmitScalarExpr(E->getArg(0)); -    Builder.CreateCall4(CGM.getMemMoveFn(), Address, -                        EmitScalarExpr(E->getArg(1)), -                        EmitScalarExpr(E->getArg(2)), -                        llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1)); +    Value *SrcAddr = EmitScalarExpr(E->getArg(1)); +    Value *SizeVal = EmitScalarExpr(E->getArg(2)); +    Builder.CreateCall5(CGM.getMemMoveFn(Address->getType(), SrcAddr->getType(), +                                         SizeVal->getType()), +                  Address, SrcAddr, SizeVal,  +                  llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1), +                  llvm::ConstantInt::get(llvm::Type::getInt1Ty(VMContext), 0));      return RValue::get(Address);    }    case Builtin::BImemset:    case Builtin::BI__builtin_memset: {      Value *Address = EmitScalarExpr(E->getArg(0)); -    Builder.CreateCall4(CGM.getMemSetFn(), Address, -                        Builder.CreateTrunc(EmitScalarExpr(E->getArg(1)), -                                            llvm::Type::getInt8Ty(VMContext)), -                        EmitScalarExpr(E->getArg(2)), -                        llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1)); +    Value *SizeVal = EmitScalarExpr(E->getArg(2)); +    Builder.CreateCall5(CGM.getMemSetFn(Address->getType(), SizeVal->getType()), +                  Address, +                  Builder.CreateTrunc(EmitScalarExpr(E->getArg(1)), +                                      llvm::Type::getInt8Ty(VMContext)), +                  SizeVal, +                  llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), 1), +                  llvm::ConstantInt::get(llvm::Type::getInt1Ty(VMContext), 0));      return RValue::get(Address);    }    case Builtin::BI__builtin_dwarf_cfa: { diff --git a/clang/lib/CodeGen/CGDecl.cpp b/clang/lib/CodeGen/CGDecl.cpp index 4eb95af8ff6..07d219f1fbf 100644 --- a/clang/lib/CodeGen/CGDecl.cpp +++ b/clang/lib/CodeGen/CGDecl.cpp @@ -564,11 +564,15 @@ void CodeGenFunction::EmitLocalBlockVarDecl(const VarDecl &D) {        if (Loc->getType() != BP)          Loc = Builder.CreateBitCast(Loc, BP, "tmp"); +      llvm::Value *NotVolatile = +        llvm::ConstantInt::get(llvm::Type::getInt1Ty(VMContext), 0); +        // If the initializer is all zeros, codegen with memset.        if (isa<llvm::ConstantAggregateZero>(Init)) {          llvm::Value *Zero = -        llvm::ConstantInt::get(llvm::Type::getInt8Ty(VMContext), 0); -        Builder.CreateCall4(CGM.getMemSetFn(), Loc, Zero, SizeVal, AlignVal); +          llvm::ConstantInt::get(llvm::Type::getInt8Ty(VMContext), 0); +        Builder.CreateCall5(CGM.getMemSetFn(Loc->getType(), SizeVal->getType()), +                            Loc, Zero, SizeVal, AlignVal, NotVolatile);        } else {          // Otherwise, create a temporary global with the initializer then           // memcpy from the global to the alloca. @@ -582,8 +586,10 @@ void CodeGenFunction::EmitLocalBlockVarDecl(const VarDecl &D) {          llvm::Value *SrcPtr = GV;          if (SrcPtr->getType() != BP)            SrcPtr = Builder.CreateBitCast(SrcPtr, BP, "tmp"); -         -        Builder.CreateCall4(CGM.getMemCpyFn(), Loc, SrcPtr, SizeVal, AlignVal); + +        Builder.CreateCall5(CGM.getMemCpyFn(Loc->getType(), SrcPtr->getType(), +                                            SizeVal->getType()), +                            Loc, SrcPtr, SizeVal, AlignVal, NotVolatile);        }      } else if (Ty->isReferenceType()) {        RValue RV = EmitReferenceBindingToExpr(Init, /*IsInitializer=*/true); diff --git a/clang/lib/CodeGen/CGExprAgg.cpp b/clang/lib/CodeGen/CGExprAgg.cpp index e2e2cd05041..4d5160f39b0 100644 --- a/clang/lib/CodeGen/CGExprAgg.cpp +++ b/clang/lib/CodeGen/CGExprAgg.cpp @@ -771,12 +771,27 @@ void CodeGenFunction::EmitAggregateCopy(llvm::Value *DestPtr,    //   a = b;    // }    // -  // we need to use a differnt call here.  We use isVolatile to indicate when +  // we need to use a different call here.  We use isVolatile to indicate when    // either the source or the destination is volatile. -  Builder.CreateCall4(CGM.getMemCpyFn(), +  const llvm::Type *I1Ty = llvm::Type::getInt1Ty(VMContext); +  const llvm::Type *I8Ty = llvm::Type::getInt8Ty(VMContext); +  const llvm::Type *I32Ty = llvm::Type::getInt32Ty(VMContext); + +  const llvm::PointerType *DPT = cast<llvm::PointerType>(DestPtr->getType()); +  const llvm::Type *DBP = llvm::PointerType::get(I8Ty, DPT->getAddressSpace()); +  if (DestPtr->getType() != DBP) +    DestPtr = Builder.CreateBitCast(DestPtr, DBP, "tmp"); + +  const llvm::PointerType *SPT = cast<llvm::PointerType>(SrcPtr->getType()); +  const llvm::Type *SBP = llvm::PointerType::get(I8Ty, SPT->getAddressSpace()); +  if (SrcPtr->getType() != SBP) +    SrcPtr = Builder.CreateBitCast(SrcPtr, SBP, "tmp"); + +  Builder.CreateCall5(CGM.getMemCpyFn(DestPtr->getType(), SrcPtr->getType(), +                                      IntPtr),                        DestPtr, SrcPtr,                        // TypeInfo.first describes size in bits.                        llvm::ConstantInt::get(IntPtr, TypeInfo.first/8), -                      llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), -                                             TypeInfo.second/8)); +                      llvm::ConstantInt::get(I32Ty,  TypeInfo.second/8), +                      llvm::ConstantInt::get(I1Ty,  isVolatile));  } diff --git a/clang/lib/CodeGen/CodeGenFunction.cpp b/clang/lib/CodeGen/CodeGenFunction.cpp index b863aff2361..f38d8a132f0 100644 --- a/clang/lib/CodeGen/CodeGenFunction.cpp +++ b/clang/lib/CodeGen/CodeGenFunction.cpp @@ -495,12 +495,14 @@ void CodeGenFunction::EmitMemSetToZero(llvm::Value *DestPtr, QualType Ty) {    const llvm::Type *IntPtr = llvm::IntegerType::get(VMContext,                                                      LLVMPointerWidth); -  Builder.CreateCall4(CGM.getMemSetFn(), DestPtr, +  Builder.CreateCall5(CGM.getMemSetFn(BP, IntPtr), DestPtr,                   llvm::Constant::getNullValue(llvm::Type::getInt8Ty(VMContext)),                        // TypeInfo.first describes size in bits.                        llvm::ConstantInt::get(IntPtr, TypeInfo.first/8),                        llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), -                                             TypeInfo.second/8)); +                                             TypeInfo.second/8), +                      llvm::ConstantInt::get(llvm::Type::getInt1Ty(VMContext), +                                             0));  }  llvm::BlockAddress *CodeGenFunction::GetAddrOfLabel(const LabelStmt *L) { diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index 3c872c8560d..a2ad31e85a8 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -47,8 +47,7 @@ CodeGenModule::CodeGenModule(ASTContext &C, const CodeGenOptions &CGO,      Features(C.getLangOptions()), CodeGenOpts(CGO), TheModule(M),      TheTargetData(TD), TheTargetCodeGenInfo(0), Diags(diags),      Types(C, M, TD, getTargetCodeGenInfo().getABIInfo()), -    MangleCtx(C), VTables(*this), Runtime(0), -    MemCpyFn(0), MemMoveFn(0), MemSetFn(0), CFConstantStringClassRef(0), +    MangleCtx(C), VTables(*this), Runtime(0), CFConstantStringClassRef(0),      VMContext(M.getContext()) {    if (!Features.ObjC1) @@ -1414,22 +1413,25 @@ llvm::Function *CodeGenModule::getIntrinsic(unsigned IID,const llvm::Type **Tys,                                           (llvm::Intrinsic::ID)IID, Tys, NumTys);  } -llvm::Function *CodeGenModule::getMemCpyFn() { -  if (MemCpyFn) return MemCpyFn; -  const llvm::Type *IntPtr = TheTargetData.getIntPtrType(VMContext); -  return MemCpyFn = getIntrinsic(llvm::Intrinsic::memcpy, &IntPtr, 1); + +llvm::Function *CodeGenModule::getMemCpyFn(const llvm::Type *DestType, +                                           const llvm::Type *SrcType, +                                           const llvm::Type *SizeType) { +  const llvm::Type *ArgTypes[3] = {DestType, SrcType, SizeType }; +  return getIntrinsic(llvm::Intrinsic::memcpy, ArgTypes, 3);  } -llvm::Function *CodeGenModule::getMemMoveFn() { -  if (MemMoveFn) return MemMoveFn; -  const llvm::Type *IntPtr = TheTargetData.getIntPtrType(VMContext); -  return MemMoveFn = getIntrinsic(llvm::Intrinsic::memmove, &IntPtr, 1); +llvm::Function *CodeGenModule::getMemMoveFn(const llvm::Type *DestType, +                                            const llvm::Type *SrcType, +                                            const llvm::Type *SizeType) { +  const llvm::Type *ArgTypes[3] = {DestType, SrcType, SizeType }; +  return getIntrinsic(llvm::Intrinsic::memmove, ArgTypes, 3);  } -llvm::Function *CodeGenModule::getMemSetFn() { -  if (MemSetFn) return MemSetFn; -  const llvm::Type *IntPtr = TheTargetData.getIntPtrType(VMContext); -  return MemSetFn = getIntrinsic(llvm::Intrinsic::memset, &IntPtr, 1); +llvm::Function *CodeGenModule::getMemSetFn(const llvm::Type *DestType, +                                           const llvm::Type *SizeType) { +  const llvm::Type *ArgTypes[2] = { DestType, SizeType }; +  return getIntrinsic(llvm::Intrinsic::memset, ArgTypes, 2);  }  static llvm::StringMapEntry<llvm::Constant*> & diff --git a/clang/lib/CodeGen/CodeGenModule.h b/clang/lib/CodeGen/CodeGenModule.h index 3c57c0b8cbf..74aa4d8a5b2 100644 --- a/clang/lib/CodeGen/CodeGenModule.h +++ b/clang/lib/CodeGen/CodeGenModule.h @@ -290,9 +290,17 @@ public:    llvm::Value *getBuiltinLibFunction(const FunctionDecl *FD,                                       unsigned BuiltinID); -  llvm::Function *getMemCpyFn(); -  llvm::Function *getMemMoveFn(); -  llvm::Function *getMemSetFn(); +  llvm::Function *getMemCpyFn(const llvm::Type *DestType, +                              const llvm::Type *SrcType, +                              const llvm::Type *SizeType); + +  llvm::Function *getMemMoveFn(const llvm::Type *DestType, +                               const llvm::Type *SrcType, +                               const llvm::Type *SizeType); + +  llvm::Function *getMemSetFn(const llvm::Type *DestType, +                              const llvm::Type *SizeType); +    llvm::Function *getIntrinsic(unsigned IID, const llvm::Type **Tys = 0,                                 unsigned NumTys = 0);  | 

