mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 18:20:39 +00:00 
			
		
		
		
	TableGen: Use 'enum : uint64_t' for feature flags to fix -Wmicrosoft
clang-cl would warn that this value is not representable in 'int':
  enum { FeatureX = 1ULL << 31 };
All MS enums are 'ints' unless otherwise specified, so we have to use an
explicit type.  The AMDGPU target just hit 32 features, triggering this
warning.
Now that we have C++11 strong enum types, we can also eliminate the
'const uint64_t' codepath from tablegen and just use 'enum : uint64_t'.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@231697 91177308-0d34-0410-b5e6-96231b3b80d8
			
			
This commit is contained in:
		| @@ -14,6 +14,8 @@ | ||||
| #ifndef LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430MCTARGETDESC_H | ||||
| #define LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430MCTARGETDESC_H | ||||
|  | ||||
| #include "llvm/Support/DataTypes.h" | ||||
|  | ||||
| namespace llvm { | ||||
| class Target; | ||||
|  | ||||
|   | ||||
| @@ -14,6 +14,8 @@ | ||||
| #ifndef LLVM_LIB_TARGET_NVPTX_MCTARGETDESC_NVPTXMCTARGETDESC_H | ||||
| #define LLVM_LIB_TARGET_NVPTX_MCTARGETDESC_NVPTXMCTARGETDESC_H | ||||
|  | ||||
| #include <stdint.h> | ||||
|  | ||||
| namespace llvm { | ||||
| class Target; | ||||
|  | ||||
|   | ||||
| @@ -16,6 +16,7 @@ | ||||
| #ifndef LLVM_LIB_TARGET_R600_MCTARGETDESC_AMDGPUMCTARGETDESC_H | ||||
| #define LLVM_LIB_TARGET_R600_MCTARGETDESC_AMDGPUMCTARGETDESC_H | ||||
|  | ||||
| #include "llvm/Support/DataTypes.h" | ||||
| #include "llvm/ADT/StringRef.h" | ||||
|  | ||||
| namespace llvm { | ||||
|   | ||||
| @@ -14,6 +14,8 @@ | ||||
| #ifndef LLVM_LIB_TARGET_XCORE_MCTARGETDESC_XCOREMCTARGETDESC_H | ||||
| #define LLVM_LIB_TARGET_XCORE_MCTARGETDESC_XCOREMCTARGETDESC_H | ||||
|  | ||||
| #include "llvm/Support/DataTypes.h" | ||||
|  | ||||
| namespace llvm { | ||||
| class Target; | ||||
|  | ||||
|   | ||||
| @@ -128,20 +128,8 @@ void SubtargetEmitter::Enumeration(raw_ostream &OS, | ||||
|  | ||||
|   OS << "namespace " << Target << " {\n"; | ||||
|  | ||||
|   // For bit flag enumerations with more than 32 items, emit constants. | ||||
|   // Emit an enum for everything else. | ||||
|   if (isBits && N > 32) { | ||||
|     // For each record | ||||
|     for (unsigned i = 0; i < N; i++) { | ||||
|       // Next record | ||||
|       Record *Def = DefList[i]; | ||||
|  | ||||
|       // Get and emit name and expression (1 << i) | ||||
|       OS << "  const uint64_t " << Def->getName() << " = 1ULL << " << i << ";\n"; | ||||
|     } | ||||
|   } else { | ||||
|     // Open enumeration | ||||
|     OS << "enum {\n"; | ||||
|   // Open enumeration. Use a 64-bit underlying type. | ||||
|   OS << "enum : uint64_t {\n"; | ||||
|  | ||||
|   // For each record | ||||
|   for (unsigned i = 0; i < N;) { | ||||
| @@ -162,7 +150,6 @@ void SubtargetEmitter::Enumeration(raw_ostream &OS, | ||||
|  | ||||
|   // Close enumeration | ||||
|   OS << "};\n"; | ||||
|   } | ||||
|  | ||||
|   OS << "}\n"; | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user