Misleading names
jacob navia
jacob@jacob.remcomp.fr
Mon Sep 4 06:29:02 GMT 2023
Hi Alain
In the context of an assembler, not a linker, input and output bed are the same: std output.
The only call done to this special function is in bfd_install_relocation:
cont = howto->special_function(abfd,reloc_entry,symbol,
/* XXX - Non-portable! */
((bfd_byte *) data_start
- data_start_offset),
input_section,abfd,error_message);
Stdoutput is passed to both bfd pointers expected.
As far as I see, this is a modification of the relocation, but I could be wrong.
Note that stdoutput can NEVER be NULL, so the test doesn’t do anything here .
What is surely difficult is that this functions are used in the linker context and in the assembler context, what makes making any modification very difficult. It could be better to separate a bit those 2 different functionalities, but I do not know the linker enough to be sure.
Thanks for your input.
Jacob
> Le 4 sept. 2023 à 02:04, Alan Modra <amodra@gmail.com> a écrit :
>
> On Sun, Sep 03, 2023 at 11:59:28PM +0200, jacob navia wrote:
>> Hi
>> The function riscv_elf_ignore_reloc, contrary to its name, does NOT ignore the relocation!
>>
>> /* Special handler for relocations which don't have to be relocated. This
>> * function just simply return bfd_reloc_ok. */
>> static bfd_reloc_status_type riscv_elf_ignore_reloc(bfd * abfd ATTRIBUTE_UNUSED,
>> arelent * reloc_entry,
>> asymbol * symbol ATTRIBUTE_UNUSED,
>> void *data ATTRIBUTE_UNUSED,
>> asection * input_section,
>> bfd * output_bfd,
>> char **error_message ATTRIBUTE_UNUSED)
>> {
>> if (output_bfd != NULL)
>> reloc_entry->address += input_section->output_offset;
>> return bfd_reloc_ok;
>> }
>>
>> Despite its name, and the associated comment, nothing is ignored here and the relocation address is modified.
>>
>> Long, descriptive names are very good WHEN THEY REFLECT THE TRUTH!
>> Otherwise they are completely misleading.
>>
>> Of course this is not a bug.
>
> There is nothing wrong with the name. No relocation of section
> contents is done. The only change made here is for ld -r to keep the
> relocation associated with the same location in the output as it was
> in the input.
>
> That said, I think it would be better for the R_RISCV_SET_ULEB128
> and R_RISCV_SUB_ULEB128 howto to use a special function something like
> ppc64_elf_unhandled_reloc.
>
> --
> Alan Modra
> Australia Development Lab, IBM
More information about the Binutils
mailing list