Attached, please find a patch fixing this issue.
2011-10-14 Balaji V. Iyer <[email protected]>
* varasm.c (default_elf_asm_named_section): Removed ATTRIBUTE_UNUSED
tag
before decl.
Thanks,
Balaji V. Iyer.
-----Original Message-----
From: Ian Lance Taylor [mailto:[email protected]]
Sent: Friday, October 14, 2011 4:29 PM
To: Iyer, Balaji V
Cc: '[email protected]'
Subject: Re: Question about default_elf_asm_named_section function
"Iyer, Balaji V" <[email protected]> writes:
> Can I submit a patch for it? Or is it a small thing that patch is not
> necessary?
I will preapprove such a patch for anybody with commit access.
Ian
> -----Original Message-----
> From: Ian Lance Taylor [mailto:[email protected]]
> Sent: Friday, October 14, 2011 12:38 AM
> To: Iyer, Balaji V
> Cc: '[email protected]'
> Subject: Re: Question about default_elf_asm_named_section function
>
> "Iyer, Balaji V" <[email protected]> writes:
>
>> This email is in reference to the "default_elf_asm_named_section"
>> function in the varasm.c file.
>>
>> This function is defined like this:
>>
>> void
>> default_elf_asm_named_section (const char *name, unsigned int flags,
>> tree decl ATTRIBUTE_UNUSED)
>>
>>
>> But, inside the function, there is this if-statement:
>>
>>
>> if (HAVE_COMDAT_GROUP && (flags & SECTION_LINKONCE))
>> {
>> if (TREE_CODE (decl) == IDENTIFIER_NODE)
>> fprintf (asm_out_file, ",%s,comdat", IDENTIFIER_POINTER (decl));
>> else
>> fprintf (asm_out_file, ",%s,comdat",
>> IDENTIFIER_POINTER (DECL_COMDAT_GROUP (decl)));
>> }
>>
>>
>> The decl is set with "ATTRIBUTE_UNUSED" but the if-statement is using
>> "decl." Should we remove the attribute unused tag near the "tree decl" or is
>> the if-statement a deadcode that should never be ?
>
>
> ATTRIBUTE_UNUSED does not mean "this parameter is never used." It means
> "this parameter may not be used." The difference is due to #ifdefs--if a
> parameter is only used in code that is something #ifdef'ed out, then the
> parameter should be marked as ATTRIBUTE_UNUSED.
>
> In this case the parameter is always used, so we might as well remove the
> ATTRIBUTE_UNUSED.
>
> Ian
diff --git a/gcc/varasm.c b/gcc/varasm.c
index e83bebb..94c865c 100644
--- a/gcc/varasm.c
+++ b/gcc/varasm.c
@@ -6142,7 +6142,7 @@ default_no_named_section (const char *name
ATTRIBUTE_UNUSED,
void
default_elf_asm_named_section (const char *name, unsigned int flags,
- tree decl ATTRIBUTE_UNUSED)
+ tree decl)
{
char flagchars[10], *f = flagchars;