mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-25 13:24:46 +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:
@@ -1451,10 +1451,11 @@ void AssemblyWriter::printGlobal(const GlobalVariable *GV) {
|
||||
PrintVisibility(GV->getVisibility(), Out);
|
||||
PrintDLLStorageClass(GV->getDLLStorageClass(), Out);
|
||||
PrintThreadLocalModel(GV->getThreadLocalMode(), Out);
|
||||
if (GV->hasUnnamedAddr())
|
||||
Out << "unnamed_addr ";
|
||||
|
||||
if (unsigned AddressSpace = GV->getType()->getAddressSpace())
|
||||
Out << "addrspace(" << AddressSpace << ") ";
|
||||
if (GV->hasUnnamedAddr()) Out << "unnamed_addr ";
|
||||
if (GV->isExternallyInitialized()) Out << "externally_initialized ";
|
||||
Out << (GV->isConstant() ? "constant " : "global ");
|
||||
TypePrinter.print(GV->getType()->getElementType(), Out);
|
||||
@@ -1489,6 +1490,8 @@ void AssemblyWriter::printAlias(const GlobalAlias *GA) {
|
||||
PrintVisibility(GA->getVisibility(), Out);
|
||||
PrintDLLStorageClass(GA->getDLLStorageClass(), Out);
|
||||
PrintThreadLocalModel(GA->getThreadLocalMode(), Out);
|
||||
if (GA->hasUnnamedAddr())
|
||||
Out << "unnamed_addr ";
|
||||
|
||||
Out << "alias ";
|
||||
|
||||
|
Reference in New Issue
Block a user