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:
Reid Kleckner 2015-03-09 20:23:14 +00:00
parent 5e261ee7b0
commit fe8490c22e
5 changed files with 23 additions and 29 deletions

View File

@ -14,6 +14,8 @@
#ifndef LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430MCTARGETDESC_H #ifndef LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430MCTARGETDESC_H
#define LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430MCTARGETDESC_H #define LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430MCTARGETDESC_H
#include "llvm/Support/DataTypes.h"
namespace llvm { namespace llvm {
class Target; class Target;

View File

@ -14,6 +14,8 @@
#ifndef LLVM_LIB_TARGET_NVPTX_MCTARGETDESC_NVPTXMCTARGETDESC_H #ifndef LLVM_LIB_TARGET_NVPTX_MCTARGETDESC_NVPTXMCTARGETDESC_H
#define LLVM_LIB_TARGET_NVPTX_MCTARGETDESC_NVPTXMCTARGETDESC_H #define LLVM_LIB_TARGET_NVPTX_MCTARGETDESC_NVPTXMCTARGETDESC_H
#include <stdint.h>
namespace llvm { namespace llvm {
class Target; class Target;

View File

@ -16,6 +16,7 @@
#ifndef LLVM_LIB_TARGET_R600_MCTARGETDESC_AMDGPUMCTARGETDESC_H #ifndef LLVM_LIB_TARGET_R600_MCTARGETDESC_AMDGPUMCTARGETDESC_H
#define 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" #include "llvm/ADT/StringRef.h"
namespace llvm { namespace llvm {

View File

@ -14,6 +14,8 @@
#ifndef LLVM_LIB_TARGET_XCORE_MCTARGETDESC_XCOREMCTARGETDESC_H #ifndef LLVM_LIB_TARGET_XCORE_MCTARGETDESC_XCOREMCTARGETDESC_H
#define LLVM_LIB_TARGET_XCORE_MCTARGETDESC_XCOREMCTARGETDESC_H #define LLVM_LIB_TARGET_XCORE_MCTARGETDESC_XCOREMCTARGETDESC_H
#include "llvm/Support/DataTypes.h"
namespace llvm { namespace llvm {
class Target; class Target;

View File

@ -128,42 +128,29 @@ void SubtargetEmitter::Enumeration(raw_ostream &OS,
OS << "namespace " << Target << " {\n"; OS << "namespace " << Target << " {\n";
// For bit flag enumerations with more than 32 items, emit constants. // Open enumeration. Use a 64-bit underlying type.
// Emit an enum for everything else. OS << "enum : uint64_t {\n";
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) // For each record
OS << " const uint64_t " << Def->getName() << " = 1ULL << " << i << ";\n"; for (unsigned i = 0; i < N;) {
} // Next record
} else { Record *Def = DefList[i];
// Open enumeration
OS << "enum {\n";
// For each record // Get and emit name
for (unsigned i = 0; i < N;) { OS << " " << Def->getName();
// Next record
Record *Def = DefList[i];
// Get and emit name // If bit flags then emit expression (1 << i)
OS << " " << Def->getName(); if (isBits) OS << " = " << " 1ULL << " << i;
// If bit flags then emit expression (1 << i) // Depending on 'if more in the list' emit comma
if (isBits) OS << " = " << " 1ULL << " << i; if (++i < N) OS << ",";
// Depending on 'if more in the list' emit comma OS << "\n";
if (++i < N) OS << ",";
OS << "\n";
}
// Close enumeration
OS << "};\n";
} }
// Close enumeration
OS << "};\n";
OS << "}\n"; OS << "}\n";
} }