[llvm] 07edd78 - [TableGen] Reduce the number of map lookups in TypeSetByHwMode::getOrCreate. NFCI
Craig Topper via llvm-commits
llvm-commits at lists.llvm.org
Thu Apr 15 12:33:16 PDT 2021
Author: Craig Topper
Date: 2021-04-15T12:32:21-07:00
New Revision: 07edd789939238d309d2ab747fad79337d705909
URL: https://github.com/llvm/llvm-project/commit/07edd789939238d309d2ab747fad79337d705909
DIFF: https://github.com/llvm/llvm-project/commit/07edd789939238d309d2ab747fad79337d705909.diff
LOG: [TableGen] Reduce the number of map lookups in TypeSetByHwMode::getOrCreate. NFCI
hasMode was looking up the map once. Then we'd either call get which
would look up again, or we'd insert into the map which requires
walking the map to find the insertion point.
I believe the hasMode was needed because get has a special case
to look for DefaultMode if the mode being asked for doesn't exist.
We don't want that here so we were using hasMode to make sure we
wouldn't hit that case.
Simplify to a regular operator[] access which will default
construct a SetType if the lookup fails.
Added:
Modified:
llvm/utils/TableGen/CodeGenDAGPatterns.h
Removed:
################################################################################
diff --git a/llvm/utils/TableGen/CodeGenDAGPatterns.h b/llvm/utils/TableGen/CodeGenDAGPatterns.h
index 2e2a9a2b1efc5..d0cf18b7c4c74 100644
--- a/llvm/utils/TableGen/CodeGenDAGPatterns.h
+++ b/llvm/utils/TableGen/CodeGenDAGPatterns.h
@@ -200,9 +200,7 @@ struct TypeSetByHwMode : public InfoByHwMode<MachineValueTypeSet> {
TypeSetByHwMode(ArrayRef<ValueTypeByHwMode> VTList);
SetType &getOrCreate(unsigned Mode) {
- if (hasMode(Mode))
- return get(Mode);
- return Map.insert({Mode,SetType()}).first->second;
+ return Map[Mode];
}
bool isValueTypeByHwMode(bool AllowEmpty) const;
More information about the llvm-commits
mailing list