mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	This commit extends the interface provided by the AsmParser library by adding a function that allows the user to parse a standalone contant value. This change is useful for MIR serialization, as it will allow the MIR Parser to parse the constant values in a machine constant pool. Reviewers: Duncan P. N. Exon Smith Differential Revision: http://reviews.llvm.org/D10280 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@242579 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			116 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
//===- llvm/unittest/AsmParser/AsmParserTest.cpp - asm parser unittests ---===//
 | 
						|
//
 | 
						|
//                     The LLVM Compiler Infrastructure
 | 
						|
//
 | 
						|
// This file is distributed under the University of Illinois Open Source
 | 
						|
// License. See LICENSE.TXT for details.
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#include "llvm/ADT/StringRef.h"
 | 
						|
#include "llvm/AsmParser/Parser.h"
 | 
						|
#include "llvm/AsmParser/SlotMapping.h"
 | 
						|
#include "llvm/IR/Constants.h"
 | 
						|
#include "llvm/IR/LLVMContext.h"
 | 
						|
#include "llvm/IR/Module.h"
 | 
						|
#include "llvm/Support/SourceMgr.h"
 | 
						|
#include "gtest/gtest.h"
 | 
						|
 | 
						|
using namespace llvm;
 | 
						|
 | 
						|
namespace {
 | 
						|
 | 
						|
TEST(AsmParserTest, NullTerminatedInput) {
 | 
						|
  LLVMContext &Ctx = getGlobalContext();
 | 
						|
  StringRef Source = "; Empty module \n";
 | 
						|
  SMDiagnostic Error;
 | 
						|
  auto Mod = parseAssemblyString(Source, Error, Ctx);
 | 
						|
 | 
						|
  EXPECT_TRUE(Mod != nullptr);
 | 
						|
  EXPECT_TRUE(Error.getMessage().empty());
 | 
						|
}
 | 
						|
 | 
						|
#ifdef GTEST_HAS_DEATH_TEST
 | 
						|
#ifndef NDEBUG
 | 
						|
 | 
						|
TEST(AsmParserTest, NonNullTerminatedInput) {
 | 
						|
  LLVMContext &Ctx = getGlobalContext();
 | 
						|
  StringRef Source = "; Empty module \n\1\2";
 | 
						|
  SMDiagnostic Error;
 | 
						|
  std::unique_ptr<Module> Mod;
 | 
						|
  EXPECT_DEATH(Mod = parseAssemblyString(Source.substr(0, Source.size() - 2),
 | 
						|
                                         Error, Ctx),
 | 
						|
               "Buffer is not null terminated!");
 | 
						|
}
 | 
						|
 | 
						|
#endif
 | 
						|
#endif
 | 
						|
 | 
						|
TEST(AsmParserTest, SlotMappingTest) {
 | 
						|
  LLVMContext &Ctx = getGlobalContext();
 | 
						|
  StringRef Source = "@0 = global i32 0\n !0 = !{}\n !42 = !{i32 42}";
 | 
						|
  SMDiagnostic Error;
 | 
						|
  SlotMapping Mapping;
 | 
						|
  auto Mod = parseAssemblyString(Source, Error, Ctx, &Mapping);
 | 
						|
 | 
						|
  EXPECT_TRUE(Mod != nullptr);
 | 
						|
  EXPECT_TRUE(Error.getMessage().empty());
 | 
						|
 | 
						|
  ASSERT_EQ(Mapping.GlobalValues.size(), 1u);
 | 
						|
  EXPECT_TRUE(isa<GlobalVariable>(Mapping.GlobalValues[0]));
 | 
						|
 | 
						|
  EXPECT_EQ(Mapping.MetadataNodes.size(), 2u);
 | 
						|
  EXPECT_EQ(Mapping.MetadataNodes.count(0), 1u);
 | 
						|
  EXPECT_EQ(Mapping.MetadataNodes.count(42), 1u);
 | 
						|
  EXPECT_EQ(Mapping.MetadataNodes.count(1), 0u);
 | 
						|
}
 | 
						|
 | 
						|
TEST(AsmParserTest, TypeAndConstantValueParsing) {
 | 
						|
  LLVMContext &Ctx = getGlobalContext();
 | 
						|
  SMDiagnostic Error;
 | 
						|
  StringRef Source = "define void @test() {\n  entry:\n  ret void\n}";
 | 
						|
  auto Mod = parseAssemblyString(Source, Error, Ctx);
 | 
						|
  ASSERT_TRUE(Mod != nullptr);
 | 
						|
  auto &M = *Mod;
 | 
						|
 | 
						|
  const Value *V;
 | 
						|
  V = parseConstantValue("double 3.5", Error, M);
 | 
						|
  ASSERT_TRUE(V);
 | 
						|
  EXPECT_TRUE(V->getType()->isDoubleTy());
 | 
						|
  ASSERT_TRUE(isa<ConstantFP>(V));
 | 
						|
  EXPECT_TRUE(cast<ConstantFP>(V)->isExactlyValue(3.5));
 | 
						|
 | 
						|
  V = parseConstantValue("i32 42", Error, M);
 | 
						|
  ASSERT_TRUE(V);
 | 
						|
  EXPECT_TRUE(V->getType()->isIntegerTy());
 | 
						|
  ASSERT_TRUE(isa<ConstantInt>(V));
 | 
						|
  EXPECT_TRUE(cast<ConstantInt>(V)->equalsInt(42));
 | 
						|
 | 
						|
  V = parseConstantValue("<4 x i32> <i32 0, i32 1, i32 2, i32 3>", Error, M);
 | 
						|
  ASSERT_TRUE(V);
 | 
						|
  EXPECT_TRUE(V->getType()->isVectorTy());
 | 
						|
  ASSERT_TRUE(isa<ConstantDataVector>(V));
 | 
						|
 | 
						|
  V = parseConstantValue("i32 add (i32 1, i32 2)", Error, M);
 | 
						|
  ASSERT_TRUE(V);
 | 
						|
  ASSERT_TRUE(isa<ConstantInt>(V));
 | 
						|
 | 
						|
  V = parseConstantValue("i8* blockaddress(@test, %entry)", Error, M);
 | 
						|
  ASSERT_TRUE(V);
 | 
						|
  ASSERT_TRUE(isa<BlockAddress>(V));
 | 
						|
 | 
						|
  EXPECT_FALSE(parseConstantValue("duble 3.25", Error, M));
 | 
						|
  EXPECT_EQ(Error.getMessage(), "expected type");
 | 
						|
 | 
						|
  EXPECT_FALSE(parseConstantValue("i32 3.25", Error, M));
 | 
						|
  EXPECT_EQ(Error.getMessage(), "floating point constant invalid for type");
 | 
						|
 | 
						|
  EXPECT_FALSE(parseConstantValue("i32* @foo", Error, M));
 | 
						|
  EXPECT_EQ(Error.getMessage(), "expected a constant value");
 | 
						|
 | 
						|
  EXPECT_FALSE(parseConstantValue("i32 3, ", Error, M));
 | 
						|
  EXPECT_EQ(Error.getMessage(), "expected end of string");
 | 
						|
}
 | 
						|
 | 
						|
} // end anonymous namespace
 |