From 9fc4a7106f2d77bb5d15659c20154cfea0374d7f Mon Sep 17 00:00:00 2001 From: Afonso Bordado Date: Mon, 9 Oct 2023 04:11:00 +0100 Subject: [PATCH] cranelift: Group labels by FuncId instead of Name (#7183) This prevents confusing label locations when there are multiple functions with the same Name. --- cranelift/jit/src/backend.rs | 4 ++-- cranelift/module/src/module.rs | 12 ++++++++---- cranelift/object/src/backend.rs | 16 ++++++---------- 3 files changed, 16 insertions(+), 16 deletions(-) diff --git a/cranelift/jit/src/backend.rs b/cranelift/jit/src/backend.rs index 438c60d49e27..f04b89d84cce 100644 --- a/cranelift/jit/src/backend.rs +++ b/cranelift/jit/src/backend.rs @@ -712,7 +712,7 @@ impl Module for JITModule { .buffer .relocs() .iter() - .map(|reloc| ModuleReloc::from_mach_reloc(reloc, &ctx.func)) + .map(|reloc| ModuleReloc::from_mach_reloc(reloc, &ctx.func, id)) .collect(); self.record_function_for_perf(ptr, size, &decl.linkage_name(id)); @@ -797,7 +797,7 @@ impl Module for JITModule { size, relocs: relocs .iter() - .map(|reloc| ModuleReloc::from_mach_reloc(reloc, func)) + .map(|reloc| ModuleReloc::from_mach_reloc(reloc, func, id)) .collect(), }); diff --git a/cranelift/module/src/module.rs b/cranelift/module/src/module.rs index cae49ef17e97..76661fd86481 100644 --- a/cranelift/module/src/module.rs +++ b/cranelift/module/src/module.rs @@ -11,7 +11,7 @@ use core::fmt::Display; use cranelift_codegen::binemit::{CodeOffset, Reloc}; use cranelift_codegen::entity::{entity_impl, PrimaryMap}; use cranelift_codegen::ir::function::{Function, VersionMarker}; -use cranelift_codegen::ir::{ExternalName, UserFuncName}; +use cranelift_codegen::ir::ExternalName; use cranelift_codegen::settings::SetError; use cranelift_codegen::{ ir, isa, CodegenError, CompileError, Context, FinalizedMachReloc, FinalizedRelocTarget, @@ -36,7 +36,11 @@ pub struct ModuleReloc { impl ModuleReloc { /// Converts a `FinalizedMachReloc` produced from a `Function` into a `ModuleReloc`. - pub fn from_mach_reloc(mach_reloc: &FinalizedMachReloc, func: &Function) -> Self { + pub fn from_mach_reloc( + mach_reloc: &FinalizedMachReloc, + func: &Function, + func_id: FuncId, + ) -> Self { let name = match mach_reloc.target { FinalizedRelocTarget::ExternalName(ExternalName::User(reff)) => { let name = &func.params.user_named_funcs()[reff]; @@ -50,7 +54,7 @@ impl ModuleReloc { ModuleRelocTarget::KnownSymbol(ks) } FinalizedRelocTarget::Func(offset) => { - ModuleRelocTarget::FunctionOffset(func.name.clone(), offset) + ModuleRelocTarget::FunctionOffset(func_id, offset) } }; Self { @@ -430,7 +434,7 @@ pub enum ModuleRelocTarget { /// Symbols known to the linker. KnownSymbol(ir::KnownSymbol), /// A offset inside a function - FunctionOffset(UserFuncName, CodeOffset), + FunctionOffset(FuncId, CodeOffset), } impl ModuleRelocTarget { diff --git a/cranelift/object/src/backend.rs b/cranelift/object/src/backend.rs index d083d84ce12f..435ff39856b8 100644 --- a/cranelift/object/src/backend.rs +++ b/cranelift/object/src/backend.rs @@ -3,7 +3,6 @@ use anyhow::anyhow; use cranelift_codegen::binemit::{Addend, CodeOffset, Reloc}; use cranelift_codegen::entity::SecondaryMap; -use cranelift_codegen::ir::UserFuncName; use cranelift_codegen::isa::{OwnedTargetIsa, TargetIsa}; use cranelift_codegen::{self, ir, FinalizedMachReloc}; use cranelift_control::ControlPlane; @@ -132,7 +131,7 @@ pub struct ObjectModule { libcalls: HashMap, libcall_names: Box String + Send + Sync>, known_symbols: HashMap, - known_labels: HashMap<(UserFuncName, CodeOffset), SymbolId>, + known_labels: HashMap<(FuncId, CodeOffset), SymbolId>, per_function_section: bool, } @@ -372,7 +371,9 @@ impl Module for ObjectModule { if !relocs.is_empty() { let relocs = relocs .iter() - .map(|record| self.process_reloc(&ModuleReloc::from_mach_reloc(&record, func))) + .map(|record| { + self.process_reloc(&ModuleReloc::from_mach_reloc(&record, func, func_id)) + }) .collect(); self.relocs.push(SymbolRelocs { section, @@ -594,15 +595,10 @@ impl ObjectModule { } } - ModuleRelocTarget::FunctionOffset(ref fname, offset) => { - match self.known_labels.entry((fname.clone(), offset)) { + ModuleRelocTarget::FunctionOffset(func_id, offset) => { + match self.known_labels.entry((func_id, offset)) { Entry::Occupied(o) => *o.get(), Entry::Vacant(v) => { - let func_user_name = fname.get_user().unwrap(); - let func_id = FuncId::from_name(&ModuleRelocTarget::user( - func_user_name.namespace, - func_user_name.index, - )); let func_symbol_id = self.functions[func_id].unwrap().0; let func_symbol = self.object.symbol(func_symbol_id);