mirror of
https://github.com/intel/llvm.git
synced 2026-02-02 02:00:03 +08:00
Rename loop unrolling and loop vectorizer metadata to have a common prefix.
[Clang part] These patches rename the loop unrolling and loop vectorizer metadata such that they have a common 'llvm.loop.' prefix. Metadata name changes: llvm.vectorizer.* => llvm.loop.vectorizer.* llvm.loopunroll.* => llvm.loop.unroll.* This was a suggestion from an earlier review (http://reviews.llvm.org/D4090) which added the loop unrolling metadata. Patch by Mark Heffernan. llvm-svn: 211712
This commit is contained in:
@@ -31,7 +31,7 @@ static MDNode *createMetadata(LLVMContext &Ctx, const LoopAttributes &Attrs) {
|
||||
|
||||
// Setting vectorizer.width
|
||||
if (Attrs.VectorizerWidth > 0) {
|
||||
Value *Vals[] = { MDString::get(Ctx, "llvm.vectorizer.width"),
|
||||
Value *Vals[] = { MDString::get(Ctx, "llvm.loop.vectorize.width"),
|
||||
ConstantInt::get(Type::getInt32Ty(Ctx),
|
||||
Attrs.VectorizerWidth) };
|
||||
Args.push_back(MDNode::get(Ctx, Vals));
|
||||
@@ -39,7 +39,7 @@ static MDNode *createMetadata(LLVMContext &Ctx, const LoopAttributes &Attrs) {
|
||||
|
||||
// Setting vectorizer.unroll
|
||||
if (Attrs.VectorizerUnroll > 0) {
|
||||
Value *Vals[] = { MDString::get(Ctx, "llvm.vectorizer.unroll"),
|
||||
Value *Vals[] = { MDString::get(Ctx, "llvm.loop.vectorize.unroll"),
|
||||
ConstantInt::get(Type::getInt32Ty(Ctx),
|
||||
Attrs.VectorizerUnroll) };
|
||||
Args.push_back(MDNode::get(Ctx, Vals));
|
||||
@@ -47,7 +47,7 @@ static MDNode *createMetadata(LLVMContext &Ctx, const LoopAttributes &Attrs) {
|
||||
|
||||
// Setting vectorizer.enable
|
||||
if (Attrs.VectorizerEnable != LoopAttributes::VecUnspecified) {
|
||||
Value *Vals[] = { MDString::get(Ctx, "llvm.vectorizer.enable"),
|
||||
Value *Vals[] = { MDString::get(Ctx, "llvm.loop.vectorize.enable"),
|
||||
ConstantInt::get(Type::getInt1Ty(Ctx),
|
||||
(Attrs.VectorizerEnable ==
|
||||
LoopAttributes::VecEnable)) };
|
||||
|
||||
@@ -37,16 +37,16 @@ struct LoopAttributes {
|
||||
/// \brief Generate llvm.loop.parallel metadata for loads and stores.
|
||||
bool IsParallel;
|
||||
|
||||
/// \brief Values of llvm.vectorizer.enable metadata.
|
||||
/// \brief Values of llvm.loop.vectorize.enable metadata.
|
||||
enum LVEnableState { VecUnspecified, VecEnable, VecDisable };
|
||||
|
||||
/// \brief llvm.vectorizer.enable
|
||||
/// \brief llvm.loop.vectorize.enable
|
||||
LVEnableState VectorizerEnable;
|
||||
|
||||
/// \brief llvm.vectorizer.width
|
||||
/// \brief llvm.loop.vectorize.width
|
||||
unsigned VectorizerWidth;
|
||||
|
||||
/// \brief llvm.vectorizer.unroll
|
||||
/// \brief llvm.loop.vectorize.unroll
|
||||
unsigned VectorizerUnroll;
|
||||
};
|
||||
|
||||
|
||||
@@ -534,7 +534,7 @@ void CodeGenFunction::EmitCondBrHints(llvm::LLVMContext &Context,
|
||||
if (Attrs.empty())
|
||||
return;
|
||||
|
||||
// Add vectorize hints to the metadata on the conditional branch.
|
||||
// Add vectorize and unroll hints to the metadata on the conditional branch.
|
||||
SmallVector<llvm::Value *, 2> Metadata(1);
|
||||
for (const auto *Attr : Attrs) {
|
||||
const LoopHintAttr *LH = dyn_cast<LoopHintAttr>(Attr);
|
||||
@@ -550,17 +550,17 @@ void CodeGenFunction::EmitCondBrHints(llvm::LLVMContext &Context,
|
||||
switch (Option) {
|
||||
case LoopHintAttr::Vectorize:
|
||||
case LoopHintAttr::VectorizeWidth:
|
||||
MetadataName = "llvm.vectorizer.width";
|
||||
MetadataName = "llvm.loop.vectorize.width";
|
||||
break;
|
||||
case LoopHintAttr::Interleave:
|
||||
case LoopHintAttr::InterleaveCount:
|
||||
MetadataName = "llvm.vectorizer.unroll";
|
||||
MetadataName = "llvm.loop.vectorize.unroll";
|
||||
break;
|
||||
case LoopHintAttr::Unroll:
|
||||
MetadataName = "llvm.loopunroll.enable";
|
||||
MetadataName = "llvm.loop.unroll.enable";
|
||||
break;
|
||||
case LoopHintAttr::UnrollCount:
|
||||
MetadataName = "llvm.loopunroll.count";
|
||||
MetadataName = "llvm.loop.unroll.count";
|
||||
break;
|
||||
}
|
||||
|
||||
@@ -572,7 +572,7 @@ void CodeGenFunction::EmitCondBrHints(llvm::LLVMContext &Context,
|
||||
if (ValueInt == 1) {
|
||||
// FIXME: In the future I will modifiy the behavior of the metadata
|
||||
// so we can enable/disable vectorization and interleaving separately.
|
||||
Name = llvm::MDString::get(Context, "llvm.vectorizer.enable");
|
||||
Name = llvm::MDString::get(Context, "llvm.loop.vectorize.enable");
|
||||
Value = Builder.getTrue();
|
||||
break;
|
||||
}
|
||||
|
||||
@@ -109,21 +109,21 @@ void template_test(double *List, int Length) {
|
||||
}
|
||||
|
||||
// CHECK: ![[LOOP_1]] = metadata !{metadata ![[LOOP_1]], metadata ![[UNROLLENABLE_1:.*]], metadata ![[WIDTH_4:.*]], metadata ![[INTERLEAVE_4:.*]], metadata ![[INTENABLE_1:.*]]}
|
||||
// CHECK: ![[UNROLLENABLE_1]] = metadata !{metadata !"llvm.loopunroll.enable", i1 true}
|
||||
// CHECK: ![[WIDTH_4]] = metadata !{metadata !"llvm.vectorizer.width", i32 4}
|
||||
// CHECK: ![[INTERLEAVE_4]] = metadata !{metadata !"llvm.vectorizer.unroll", i32 4}
|
||||
// CHECK: ![[INTENABLE_1]] = metadata !{metadata !"llvm.vectorizer.enable", i1 true}
|
||||
// CHECK: ![[UNROLLENABLE_1]] = metadata !{metadata !"llvm.loop.unroll.enable", i1 true}
|
||||
// CHECK: ![[WIDTH_4]] = metadata !{metadata !"llvm.loop.vectorize.width", i32 4}
|
||||
// CHECK: ![[INTERLEAVE_4]] = metadata !{metadata !"llvm.loop.vectorize.unroll", i32 4}
|
||||
// CHECK: ![[INTENABLE_1]] = metadata !{metadata !"llvm.loop.vectorize.enable", i1 true}
|
||||
// CHECK: ![[LOOP_2]] = metadata !{metadata ![[LOOP_2:.*]], metadata ![[UNROLLENABLE_0:.*]], metadata ![[INTERLEAVE_4:.*]], metadata ![[WIDTH_8:.*]]}
|
||||
// CHECK: ![[UNROLLENABLE_0]] = metadata !{metadata !"llvm.loopunroll.enable", i1 false}
|
||||
// CHECK: ![[WIDTH_8]] = metadata !{metadata !"llvm.vectorizer.width", i32 8}
|
||||
// CHECK: ![[UNROLLENABLE_0]] = metadata !{metadata !"llvm.loop.unroll.enable", i1 false}
|
||||
// CHECK: ![[WIDTH_8]] = metadata !{metadata !"llvm.loop.vectorize.width", i32 8}
|
||||
// CHECK: ![[LOOP_3]] = metadata !{metadata ![[LOOP_3]], metadata ![[UNROLL_8:.*]], metadata ![[INTERLEAVE_4:.*]], metadata ![[ENABLE_1:.*]]}
|
||||
// CHECK: ![[UNROLL_8]] = metadata !{metadata !"llvm.loopunroll.count", i32 8}
|
||||
// CHECK: ![[UNROLL_8]] = metadata !{metadata !"llvm.loop.unroll.count", i32 8}
|
||||
// CHECK: ![[LOOP_4]] = metadata !{metadata ![[LOOP_4]], metadata ![[INTERLEAVE_2:.*]], metadata ![[WIDTH_2:.*]]}
|
||||
// CHECK: ![[INTERLEAVE_2]] = metadata !{metadata !"llvm.vectorizer.unroll", i32 2}
|
||||
// CHECK: ![[WIDTH_2]] = metadata !{metadata !"llvm.vectorizer.width", i32 2}
|
||||
// CHECK: ![[INTERLEAVE_2]] = metadata !{metadata !"llvm.loop.vectorize.unroll", i32 2}
|
||||
// CHECK: ![[WIDTH_2]] = metadata !{metadata !"llvm.loop.vectorize.width", i32 2}
|
||||
// CHECK: ![[LOOP_5]] = metadata !{metadata ![[LOOP_5]], metadata ![[UNROLLENABLE_0:.*]], metadata ![[WIDTH_1:.*]]}
|
||||
// CHECK: ![[WIDTH_1]] = metadata !{metadata !"llvm.vectorizer.width", i32 1}
|
||||
// CHECK: ![[WIDTH_1]] = metadata !{metadata !"llvm.loop.vectorize.width", i32 1}
|
||||
// CHECK: ![[LOOP_6]] = metadata !{metadata ![[LOOP_6]], metadata ![[UNROLL_8:.*]], metadata ![[INTERLEAVE_2:.*]], metadata ![[WIDTH_2:.*]]}
|
||||
// CHECK: ![[LOOP_7]] = metadata !{metadata ![[LOOP_7]], metadata ![[UNROLL_8:.*]], metadata ![[INTERLEAVE_8:.*]], metadata ![[WIDTH_8:.*]]}
|
||||
// CHECK: ![[INTERLEAVE_8]] = metadata !{metadata !"llvm.vectorizer.unroll", i32 8}
|
||||
// CHECK: ![[INTERLEAVE_8]] = metadata !{metadata !"llvm.loop.vectorize.unroll", i32 8}
|
||||
// CHECK: ![[LOOP_8]] = metadata !{metadata ![[LOOP_8]], metadata ![[UNROLL_8:.*]], metadata ![[INTERLEAVE_2:.*]], metadata ![[WIDTH_2:.*]]}
|
||||
|
||||
@@ -40,8 +40,8 @@ void h3(float *c, float *a, float *b, int size)
|
||||
|
||||
// Metadata for h1:
|
||||
// CHECK: [[LOOP_H1_HEADER:![0-9]+]] = metadata !{metadata [[LOOP_H1_HEADER]], metadata [[LOOP_WIDTH_16:![0-9]+]], metadata [[LOOP_VEC_ENABLE:![0-9]+]]}
|
||||
// CHECK: [[LOOP_WIDTH_16]] = metadata !{metadata !"llvm.vectorizer.width", i32 16}
|
||||
// CHECK: [[LOOP_VEC_ENABLE]] = metadata !{metadata !"llvm.vectorizer.enable", i1 true}
|
||||
// CHECK: [[LOOP_WIDTH_16]] = metadata !{metadata !"llvm.loop.vectorize.width", i32 16}
|
||||
// CHECK: [[LOOP_VEC_ENABLE]] = metadata !{metadata !"llvm.loop.vectorize.enable", i1 true}
|
||||
//
|
||||
// Metadata for h2:
|
||||
// CHECK: [[LOOP_H2_HEADER]] = metadata !{metadata [[LOOP_H2_HEADER]], metadata [[LOOP_VEC_ENABLE]]}
|
||||
@@ -49,4 +49,3 @@ void h3(float *c, float *a, float *b, int size)
|
||||
// Metadata for h3:
|
||||
// CHECK: [[LOOP_H3_HEADER:![0-9]+]] = metadata !{metadata [[LOOP_H3_HEADER]], metadata [[LOOP_VEC_ENABLE]]}
|
||||
//
|
||||
|
||||
|
||||
Reference in New Issue
Block a user