@@ -491,6 +491,14 @@ class Verifier : public InstVisitor<Verifier>, VerifierSupport {
491
491
// / Whether a metadata node is allowed to be, or contain, a DILocation.
492
492
enum class AreDebugLocsAllowed { No, Yes };
493
493
494
+ // / Metadata that should be treated as a range, with slightly different
495
+ // / requirements.
496
+ enum class RangeLikeMetadataKind {
497
+ Range, // MD_range
498
+ AbsoluteSymbol, // MD_absolute_symbol
499
+ NoaliasAddrspace // MD_noalias_addrspace
500
+ };
501
+
494
502
// Verification methods...
495
503
void visitGlobalValue (const GlobalValue &GV);
496
504
void visitGlobalVariable (const GlobalVariable &GV);
@@ -514,8 +522,8 @@ class Verifier : public InstVisitor<Verifier>, VerifierSupport {
514
522
void visitModuleFlagCGProfileEntry (const MDOperand &MDO);
515
523
void visitFunction (const Function &F);
516
524
void visitBasicBlock (BasicBlock &BB);
517
- void verifyRangeMetadata (const Value &V, const MDNode *Range, Type *Ty,
518
- bool IsAbsoluteSymbol, bool IsAddrSpaceRange );
525
+ void verifyRangeLikeMetadata (const Value &V, const MDNode *Range, Type *Ty,
526
+ RangeLikeMetadataKind Kind );
519
527
void visitRangeMetadata (Instruction &I, MDNode *Range, Type *Ty);
520
528
void visitNoaliasAddrspaceMetadata (Instruction &I, MDNode *Range, Type *Ty);
521
529
void visitDereferenceableMetadata (Instruction &I, MDNode *MD);
@@ -760,8 +768,9 @@ void Verifier::visitGlobalValue(const GlobalValue &GV) {
760
768
// FIXME: Why is getMetadata on GlobalValue protected?
761
769
if (const MDNode *AbsoluteSymbol =
762
770
GO->getMetadata (LLVMContext::MD_absolute_symbol)) {
763
- verifyRangeMetadata (*GO, AbsoluteSymbol, DL.getIntPtrType (GO->getType ()),
764
- true , false );
771
+ verifyRangeLikeMetadata (*GO, AbsoluteSymbol,
772
+ DL.getIntPtrType (GO->getType ()),
773
+ RangeLikeMetadataKind::AbsoluteSymbol);
765
774
}
766
775
}
767
776
@@ -4130,9 +4139,8 @@ static bool isContiguous(const ConstantRange &A, const ConstantRange &B) {
4130
4139
4131
4140
// / Verify !range and !absolute_symbol metadata. These have the same
4132
4141
// / restrictions, except !absolute_symbol allows the full set.
4133
- void Verifier::verifyRangeMetadata (const Value &I, const MDNode *Range,
4134
- Type *Ty, bool IsAbsoluteSymbol,
4135
- bool IsAddrSpaceRange) {
4142
+ void Verifier::verifyRangeLikeMetadata (const Value &I, const MDNode *Range,
4143
+ Type *Ty, RangeLikeMetadataKind Kind) {
4136
4144
unsigned NumOperands = Range->getNumOperands ();
4137
4145
Check (NumOperands % 2 == 0 , " Unfinished range!" , Range);
4138
4146
unsigned NumRanges = NumOperands / 2 ;
@@ -4150,7 +4158,7 @@ void Verifier::verifyRangeMetadata(const Value &I, const MDNode *Range,
4150
4158
Check (High->getType () == Low->getType (), " Range pair types must match!" ,
4151
4159
&I);
4152
4160
4153
- if (IsAddrSpaceRange ) {
4161
+ if (Kind == RangeLikeMetadataKind::NoaliasAddrspace ) {
4154
4162
Check (High->getType ()->isIntegerTy (32 ),
4155
4163
" noalias.addrspace type must be i32!" , &I);
4156
4164
} else {
@@ -4167,7 +4175,9 @@ void Verifier::verifyRangeMetadata(const Value &I, const MDNode *Range,
4167
4175
" The upper and lower limits cannot be the same value" , &I);
4168
4176
4169
4177
ConstantRange CurRange (LowV, HighV);
4170
- Check (!CurRange.isEmptySet () && (IsAbsoluteSymbol || !CurRange.isFullSet ()),
4178
+ Check (!CurRange.isEmptySet () &&
4179
+ (Kind == RangeLikeMetadataKind::AbsoluteSymbol ||
4180
+ !CurRange.isFullSet ()),
4171
4181
" Range must not be empty!" , Range);
4172
4182
if (i != 0 ) {
4173
4183
Check (CurRange.intersectWith (LastRange).isEmptySet (),
@@ -4195,14 +4205,15 @@ void Verifier::verifyRangeMetadata(const Value &I, const MDNode *Range,
4195
4205
void Verifier::visitRangeMetadata (Instruction &I, MDNode *Range, Type *Ty) {
4196
4206
assert (Range && Range == I.getMetadata (LLVMContext::MD_range) &&
4197
4207
" precondition violation" );
4198
- verifyRangeMetadata (I, Range, Ty, false , false );
4208
+ verifyRangeLikeMetadata (I, Range, Ty, RangeLikeMetadataKind::Range );
4199
4209
}
4200
4210
4201
4211
void Verifier::visitNoaliasAddrspaceMetadata (Instruction &I, MDNode *Range,
4202
4212
Type *Ty) {
4203
4213
assert (Range && Range == I.getMetadata (LLVMContext::MD_noalias_addrspace) &&
4204
4214
" precondition violation" );
4205
- verifyRangeMetadata (I, Range, Ty, false , true );
4215
+ verifyRangeLikeMetadata (I, Range, Ty,
4216
+ RangeLikeMetadataKind::NoaliasAddrspace);
4206
4217
}
4207
4218
4208
4219
void Verifier::checkAtomicMemAccessSize (Type *Ty, const Instruction *I) {
0 commit comments