mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-19 03:24:09 +00:00
Allow aliases to be unnamed_addr.
Alias with unnamed_addr were in a strange state. It is stored in GlobalValue, the language reference talks about "unnamed_addr aliases" but the verifier was rejecting them. It seems natural to allow unnamed_addr in aliases: * It is a property of how it is accessed, not of the data itself. * It is perfectly possible to write code that depends on the address of an alias. This patch then makes unname_addr legal for aliases. One side effect is that the syntax changes for a corner case: In globals, unnamed_addr is now printed before the address space. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@210302 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -44,23 +44,6 @@ TEST(VerifierTest, Branch_i1) {
|
||||
EXPECT_TRUE(verifyFunction(*F));
|
||||
}
|
||||
|
||||
TEST(VerifierTest, AliasUnnamedAddr) {
|
||||
LLVMContext &C = getGlobalContext();
|
||||
Module M("M", C);
|
||||
Type *Ty = Type::getInt8Ty(C);
|
||||
Constant *Init = Constant::getNullValue(Ty);
|
||||
GlobalVariable *Aliasee = new GlobalVariable(M, Ty, true,
|
||||
GlobalValue::ExternalLinkage,
|
||||
Init, "foo");
|
||||
auto *GA = GlobalAlias::create(GlobalValue::ExternalLinkage, "bar", Aliasee);
|
||||
GA->setUnnamedAddr(true);
|
||||
std::string Error;
|
||||
raw_string_ostream ErrorOS(Error);
|
||||
EXPECT_TRUE(verifyModule(M, &ErrorOS));
|
||||
EXPECT_TRUE(
|
||||
StringRef(ErrorOS.str()).startswith("Alias cannot have unnamed_addr"));
|
||||
}
|
||||
|
||||
TEST(VerifierTest, InvalidRetAttribute) {
|
||||
LLVMContext &C = getGlobalContext();
|
||||
Module M("M", C);
|
||||
|
Reference in New Issue
Block a user