diff options
Diffstat (limited to 'include/llvm/IR/Value.def')
| -rw-r--r-- | include/llvm/IR/Value.def | 37 | 
1 files changed, 21 insertions, 16 deletions
| diff --git a/include/llvm/IR/Value.def b/include/llvm/IR/Value.def index cebd7f7297ef..e2ddba0aa159 100644 --- a/include/llvm/IR/Value.def +++ b/include/llvm/IR/Value.def @@ -56,16 +56,10 @@  #define HANDLE_CONSTANT_MARKER(MarkerName, ValueName)  #endif -HANDLE_VALUE(Argument) -HANDLE_VALUE(BasicBlock) - -// FIXME: It's awkward that Value.def knows about classes in Analysis. While -// this doesn't introduce a strict link or include dependency, we should remove -// the circular dependency eventually. -HANDLE_MEMORY_VALUE(MemoryUse) -HANDLE_MEMORY_VALUE(MemoryDef) -HANDLE_MEMORY_VALUE(MemoryPhi) +// Having constant first makes the range check for isa<Constant> faster +// and smaller by one operation. +// Constant  HANDLE_GLOBAL_VALUE(Function)  HANDLE_GLOBAL_VALUE(GlobalAlias)  HANDLE_GLOBAL_VALUE(GlobalIFunc) @@ -88,13 +82,6 @@ HANDLE_CONSTANT(ConstantFP)  HANDLE_CONSTANT(ConstantPointerNull)  HANDLE_CONSTANT(ConstantTokenNone) -HANDLE_METADATA_VALUE(MetadataAsValue) -HANDLE_INLINE_ASM_VALUE(InlineAsm) - -HANDLE_INSTRUCTION(Instruction) -// Enum values starting at InstructionVal are used for Instructions; -// don't add new values here! -  HANDLE_CONSTANT_MARKER(ConstantFirstVal, Function)  HANDLE_CONSTANT_MARKER(ConstantLastVal, ConstantTokenNone)  HANDLE_CONSTANT_MARKER(ConstantDataFirstVal, UndefValue) @@ -102,6 +89,24 @@ HANDLE_CONSTANT_MARKER(ConstantDataLastVal, ConstantTokenNone)  HANDLE_CONSTANT_MARKER(ConstantAggregateFirstVal, ConstantArray)  HANDLE_CONSTANT_MARKER(ConstantAggregateLastVal, ConstantVector) +HANDLE_VALUE(Argument) +HANDLE_VALUE(BasicBlock) + + +HANDLE_METADATA_VALUE(MetadataAsValue) +HANDLE_INLINE_ASM_VALUE(InlineAsm) + +// FIXME: It's awkward that Value.def knows about classes in Analysis. While +// this doesn't introduce a strict link or include dependency, we should remove +// the circular dependency eventually. +HANDLE_MEMORY_VALUE(MemoryUse) +HANDLE_MEMORY_VALUE(MemoryDef) +HANDLE_MEMORY_VALUE(MemoryPhi) + +HANDLE_INSTRUCTION(Instruction) +// Enum values starting at InstructionVal are used for Instructions; +// don't add new values here! +  #undef HANDLE_MEMORY_VALUE  #undef HANDLE_GLOBAL_VALUE  #undef HANDLE_CONSTANT | 
