diff options
Diffstat (limited to 'compiler/utils/assembler_test.h')
| -rw-r--r-- | compiler/utils/assembler_test.h | 86 | 
1 files changed, 82 insertions, 4 deletions
| diff --git a/compiler/utils/assembler_test.h b/compiler/utils/assembler_test.h index 5c4875951b..d265a44092 100644 --- a/compiler/utils/assembler_test.h +++ b/compiler/utils/assembler_test.h @@ -42,7 +42,10 @@ enum class RegisterView {  // private    kUseQuaternaryName,  }; -template<typename Ass, typename Reg, typename FPReg, typename Imm> +// For use in the template as the default type to get a nonvector registers version. +struct NoVectorRegs {}; + +template<typename Ass, typename Reg, typename FPReg, typename Imm, typename VecReg = NoVectorRegs>  class AssemblerTest : public testing::Test {   public:    Ass* GetAssembler() { @@ -146,7 +149,8 @@ class AssemblerTest : public testing::Test {                                                std::string (AssemblerTest::*GetName1)(const Reg1&),                                                std::string (AssemblerTest::*GetName2)(const Reg2&),                                                const std::string& fmt, -                                              int bias = 0) { +                                              int bias = 0, +                                              int multiplier = 1) {      std::string str;      std::vector<int64_t> imms = CreateImmediateValuesBits(abs(imm_bits), (imm_bits > 0)); @@ -154,7 +158,7 @@ class AssemblerTest : public testing::Test {        for (auto reg2 : reg2_registers) {          for (int64_t imm : imms) {            ImmType new_imm = CreateImmediate(imm); -          (assembler_.get()->*f)(*reg1, *reg2, new_imm + bias); +          (assembler_.get()->*f)(*reg1, *reg2, new_imm * multiplier + bias);            std::string base = fmt;            std::string reg1_string = (this->*GetName1)(*reg1); @@ -172,7 +176,7 @@ class AssemblerTest : public testing::Test {            size_t imm_index = base.find(IMM_TOKEN);            if (imm_index != std::string::npos) {              std::ostringstream sreg; -            sreg << imm + bias; +            sreg << imm * multiplier + bias;              std::string imm_string = sreg.str();              base.replace(imm_index, ConstexprStrLen(IMM_TOKEN), imm_string);            } @@ -538,6 +542,69 @@ class AssemblerTest : public testing::Test {      return str;    } +  std::string RepeatVV(void (Ass::*f)(VecReg, VecReg), const std::string& fmt) { +    return RepeatTemplatedRegisters<VecReg, VecReg>(f, +                                                    GetVectorRegisters(), +                                                    GetVectorRegisters(), +                                                    &AssemblerTest::GetVecRegName, +                                                    &AssemblerTest::GetVecRegName, +                                                    fmt); +  } + +  std::string RepeatVVV(void (Ass::*f)(VecReg, VecReg, VecReg), const std::string& fmt) { +    return RepeatTemplatedRegisters<VecReg, VecReg, VecReg>(f, +                                                            GetVectorRegisters(), +                                                            GetVectorRegisters(), +                                                            GetVectorRegisters(), +                                                            &AssemblerTest::GetVecRegName, +                                                            &AssemblerTest::GetVecRegName, +                                                            &AssemblerTest::GetVecRegName, +                                                            fmt); +  } + +  std::string RepeatVR(void (Ass::*f)(VecReg, Reg), const std::string& fmt) { +    return RepeatTemplatedRegisters<VecReg, Reg>( +        f, +        GetVectorRegisters(), +        GetRegisters(), +        &AssemblerTest::GetVecRegName, +        &AssemblerTest::GetRegName<RegisterView::kUsePrimaryName>, +        fmt); +  } + +  template <typename ImmType> +  std::string RepeatVRIb(void (Ass::*f)(VecReg, Reg, ImmType), +                         int imm_bits, +                         const std::string& fmt, +                         int bias = 0, +                         int multiplier = 1) { +    return RepeatTemplatedRegistersImmBits<VecReg, Reg, ImmType>( +        f, +        imm_bits, +        GetVectorRegisters(), +        GetRegisters(), +        &AssemblerTest::GetVecRegName, +        &AssemblerTest::GetRegName<RegisterView::kUsePrimaryName>, +        fmt, +        bias, +        multiplier); +  } + +  template <typename ImmType> +  std::string RepeatVVIb(void (Ass::*f)(VecReg, VecReg, ImmType), +                         int imm_bits, +                         const std::string& fmt, +                         int bias = 0) { +    return RepeatTemplatedRegistersImmBits<VecReg, VecReg, ImmType>(f, +                                                                    imm_bits, +                                                                    GetVectorRegisters(), +                                                                    GetVectorRegisters(), +                                                                    &AssemblerTest::GetVecRegName, +                                                                    &AssemblerTest::GetVecRegName, +                                                                    fmt, +                                                                    bias); +  } +    // This is intended to be run as a test.    bool CheckTools() {      return test_helper_->CheckTools(); @@ -552,6 +619,11 @@ class AssemblerTest : public testing::Test {      UNREACHABLE();    } +  virtual std::vector<VecReg*> GetVectorRegisters() { +    UNIMPLEMENTED(FATAL) << "Architecture does not support vector registers"; +    UNREACHABLE(); +  } +    // Secondary register names are the secondary view on registers, e.g., 32b on 64b systems.    virtual std::string GetSecondaryRegisterName(const Reg& reg ATTRIBUTE_UNUSED) {      UNIMPLEMENTED(FATAL) << "Architecture does not support secondary registers"; @@ -971,6 +1043,12 @@ class AssemblerTest : public testing::Test {      return sreg.str();    } +  std::string GetVecRegName(const VecReg& reg) { +    std::ostringstream sreg; +    sreg << reg; +    return sreg.str(); +  } +    // If the assembly file needs a header, return it in a sub-class.    virtual const char* GetAssemblyHeader() {      return nullptr; |