diff options
| author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2019-05-22 16:28:41 +0000 | 
|---|---|---|
| committer | Matt Arsenault <Matthew.Arsenault@amd.com> | 2019-05-22 16:28:41 +0000 | 
| commit | ca64ef20434c0cb6912e795c85567d5b00ad9b0d (patch) | |
| tree | 253c385f1311dfc20b539ed68633b3c3959fad04 /llvm/lib/CodeGen | |
| parent | c2187c20a461c19ff50dc358b932c44f2ef5d6c6 (diff) | |
| download | bcm5719-llvm-ca64ef20434c0cb6912e795c85567d5b00ad9b0d.tar.gz bcm5719-llvm-ca64ef20434c0cb6912e795c85567d5b00ad9b0d.zip | |
MC: Allow getMaxInstLength to depend on the subtarget
Keep it optional in cases this is ever needed in some global
context. Currently it's only used for getting an upper bound inline
asm code size.
For AMDGPU, gfx10 increases the maximum instruction size to
20-bytes. This avoids penalizing older subtargets when estimating code
size, and making some annoying branch relaxation test adjustments.
llvm-svn: 361405
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/TargetInstrInfo.cpp | 8 | 
1 files changed, 5 insertions, 3 deletions
| diff --git a/llvm/lib/CodeGen/TargetInstrInfo.cpp b/llvm/lib/CodeGen/TargetInstrInfo.cpp index d397c3334b8..ab13d3482c1 100644 --- a/llvm/lib/CodeGen/TargetInstrInfo.cpp +++ b/llvm/lib/CodeGen/TargetInstrInfo.cpp @@ -85,11 +85,13 @@ static bool isAsmComment(const char *Str, const MCAsmInfo &MAI) {  /// simple--i.e. not a logical or arithmetic expression--size values without  /// the optional fill value. This is primarily used for creating arbitrary  /// sized inline asm blocks for testing purposes. -unsigned TargetInstrInfo::getInlineAsmLength(const char *Str, -                                             const MCAsmInfo &MAI) const { +unsigned TargetInstrInfo::getInlineAsmLength( +  const char *Str, +  const MCAsmInfo &MAI, const TargetSubtargetInfo *STI) const {    // Count the number of instructions in the asm.    bool AtInsnStart = true;    unsigned Length = 0; +  const unsigned MaxInstLength = MAI.getMaxInstLength(STI);    for (; *Str; ++Str) {      if (*Str == '\n' || strncmp(Str, MAI.getSeparatorString(),                                  strlen(MAI.getSeparatorString())) == 0) { @@ -101,7 +103,7 @@ unsigned TargetInstrInfo::getInlineAsmLength(const char *Str,      }      if (AtInsnStart && !std::isspace(static_cast<unsigned char>(*Str))) { -      unsigned AddLength = MAI.getMaxInstLength(); +      unsigned AddLength = MaxInstLength;        if (strncmp(Str, ".space", 6) == 0) {          char *EStr;          int SpaceSize; | 

