mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Fix relocations with renamed symbols.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117575 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -644,13 +644,14 @@ void ELFObjectWriterImpl::RecordRelocation(const MCAssembler &Asm, | ||||
|   int Index = 0; | ||||
|   int64_t Value = Target.getConstant(); | ||||
|   const MCSymbol *Symbol = 0; | ||||
|   const MCSymbol *Renamed = 0; | ||||
|  | ||||
|   bool IsPCRel = isFixupKindX86PCRel(Fixup.getKind()); | ||||
|   if (!Target.isAbsolute()) { | ||||
|     Symbol = &AliasedSymbol(Target.getSymA()->getSymbol()); | ||||
|     const MCSymbol *Renamed = Renames.lookup(Symbol); | ||||
|     if (Renamed) | ||||
|       Symbol = Renamed; | ||||
|     Renamed = Renames.lookup(Symbol); | ||||
|     if (!Renamed) | ||||
|       Renamed = Symbol; | ||||
|     MCSymbolData &SD = Asm.getSymbolData(*Symbol); | ||||
|     MCFragment *F = SD.getFragment(); | ||||
|  | ||||
| @@ -685,7 +686,7 @@ void ELFObjectWriterImpl::RecordRelocation(const MCAssembler &Asm, | ||||
|       // Offset of the symbol in the section | ||||
|       Value += Layout.getSymbolAddress(&SD) - Layout.getSectionAddress(FSD); | ||||
|     } else { | ||||
|       UsedInReloc.insert(Symbol); | ||||
|       UsedInReloc.insert(Renamed); | ||||
|       Index = -1; | ||||
|     } | ||||
|     Addend = Value; | ||||
| @@ -833,7 +834,7 @@ void ELFObjectWriterImpl::RecordRelocation(const MCAssembler &Asm, | ||||
|  | ||||
|   ERE.Index = Index; | ||||
|   ERE.Type = Type; | ||||
|   ERE.Symbol = Symbol; | ||||
|   ERE.Symbol = Renamed; | ||||
|  | ||||
|   ERE.r_offset = Layout.getFragmentOffset(Fragment) + Fixup.getOffset(); | ||||
|  | ||||
|   | ||||
							
								
								
									
										46
									
								
								test/MC/ELF/rename.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								test/MC/ELF/rename.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| // RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | elf-dump  | FileCheck %s | ||||
|  | ||||
| // When doing a rename, all the checks for where the relocation should go | ||||
| // should be performed with the original symbol. Only if we decide to relocate | ||||
| // with the symbol we should then use the renamed one. | ||||
|  | ||||
| // This is a regression test for a bug where we used bar5@@@zed when deciding | ||||
| // if we should relocate with the symbol or with the section and we would then | ||||
| // not produce a relocation with .text. | ||||
|  | ||||
| defined1: | ||||
| defined3: | ||||
|         .symver defined3, bar5@@@zed | ||||
|         .long defined3 | ||||
|  | ||||
|         .global defined1 | ||||
|  | ||||
| // Section 1 is .text | ||||
| // CHECK:      # Section 0x00000001 | ||||
| // CHECK-NEXT: (('sh_name', 0x00000001) # '.text' | ||||
| // CHECK-NEXT:  ('sh_type', 0x00000001) | ||||
| // CHECK-NEXT:  ('sh_flags', 0x00000006) | ||||
| // CHECK-NEXT:  ('sh_addr', 0x00000000) | ||||
| // CHECK-NEXT:  ('sh_offset', 0x00000040) | ||||
| // CHECK-NEXT:  ('sh_size', 0x00000004) | ||||
| // CHECK-NEXT:  ('sh_link', 0x00000000) | ||||
| // CHECK-NEXT:  ('sh_info', 0x00000000) | ||||
| // CHECK-NEXT:  ('sh_addralign', 0x00000004) | ||||
| // CHECK-NEXT:  ('sh_entsize', 0x00000000) | ||||
|  | ||||
| // Symbol 2 is section 1 | ||||
| // CHECK:      # Symbol 0x00000002 | ||||
| // CHECK-NEXT: (('st_name', 0x00000000) # '' | ||||
| // CHECK-NEXT:  ('st_bind', 0x00000000) | ||||
| // CHECK-NEXT:  ('st_type', 0x00000003) | ||||
| // CHECK-NEXT:  ('st_other', 0x00000000) | ||||
| // CHECK-NEXT:  ('st_shndx', 0x00000001) | ||||
| // CHECK-NEXT:  ('st_value', 0x00000000) | ||||
| // CHECK-NEXT:  ('st_size', 0x00000000) | ||||
|  | ||||
| // The relocation uses symbol 2 | ||||
| // CHECK:      # Relocation 0x00000000 | ||||
| // CHECK-NEXT: (('r_offset', 0x00000000) | ||||
| // CHECK-NEXT:  ('r_sym', 0x00000002) | ||||
| // CHECK-NEXT:  ('r_type', 0x0000000a) | ||||
| // CHECK-NEXT:  ('r_addend', 0x00000000) | ||||
		Reference in New Issue
	
	Block a user