2018-05-17 18:52:18 +08:00
|
|
|
//===-- AssemblerTest.cpp ---------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2018-05-17 18:52:18 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "../Common/AssemblerUtils.h"
|
|
|
|
#include "ARMInstrInfo.h"
|
|
|
|
|
2018-10-23 01:10:47 +08:00
|
|
|
namespace llvm {
|
2018-05-17 18:52:18 +08:00
|
|
|
namespace exegesis {
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
using llvm::MCInstBuilder;
|
|
|
|
|
|
|
|
class ARMMachineFunctionGeneratorTest
|
|
|
|
: public MachineFunctionGeneratorBaseTest {
|
|
|
|
protected:
|
|
|
|
ARMMachineFunctionGeneratorTest()
|
|
|
|
: MachineFunctionGeneratorBaseTest("armv7-none-linux-gnueabi", "") {}
|
|
|
|
|
|
|
|
static void SetUpTestCase() {
|
|
|
|
LLVMInitializeARMTargetInfo();
|
|
|
|
LLVMInitializeARMTargetMC();
|
|
|
|
LLVMInitializeARMTarget();
|
|
|
|
LLVMInitializeARMAsmPrinter();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-05-17 20:41:56 +08:00
|
|
|
TEST_F(ARMMachineFunctionGeneratorTest, DISABLED_JitFunction) {
|
2018-09-20 20:22:18 +08:00
|
|
|
Check({}, llvm::MCInst(), 0x1e, 0xff, 0x2f, 0xe1);
|
2018-05-17 18:52:18 +08:00
|
|
|
}
|
|
|
|
|
2018-05-17 20:41:56 +08:00
|
|
|
TEST_F(ARMMachineFunctionGeneratorTest, DISABLED_JitFunctionADDrr) {
|
2018-09-20 20:22:18 +08:00
|
|
|
Check({{llvm::ARM::R0, llvm::APInt()}},
|
2018-08-01 22:41:45 +08:00
|
|
|
MCInstBuilder(llvm::ARM::ADDrr)
|
2018-05-17 18:52:18 +08:00
|
|
|
.addReg(llvm::ARM::R0)
|
|
|
|
.addReg(llvm::ARM::R0)
|
|
|
|
.addReg(llvm::ARM::R0)
|
|
|
|
.addImm(llvm::ARMCC::AL)
|
|
|
|
.addReg(0)
|
|
|
|
.addReg(0),
|
|
|
|
0x00, 0x00, 0x80, 0xe0, 0x1e, 0xff, 0x2f, 0xe1);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
} // namespace exegesis
|
2018-10-23 01:10:47 +08:00
|
|
|
} // namespace llvm
|