<html>
<head>
<base href="https://llvm.org/bugs/" />
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW --- - Multiple issues with #pragma bss_seg"
href="https://llvm.org/bugs/show_bug.cgi?id=29062">29062</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>Multiple issues with #pragma bss_seg
</td>
</tr>
<tr>
<th>Product</th>
<td>clang
</td>
</tr>
<tr>
<th>Version</th>
<td>trunk
</td>
</tr>
<tr>
<th>Hardware</th>
<td>PC
</td>
</tr>
<tr>
<th>OS</th>
<td>All
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Severity</th>
<td>normal
</td>
</tr>
<tr>
<th>Priority</th>
<td>P
</td>
</tr>
<tr>
<th>Component</th>
<td>Frontend
</td>
</tr>
<tr>
<th>Assignee</th>
<td>unassignedclangbugs@nondot.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>richard.barton@arm.com
</td>
</tr>
<tr>
<th>CC</th>
<td>llvm-bugs@lists.llvm.org
</td>
</tr>
<tr>
<th>Classification</th>
<td>Unclassified
</td>
</tr></table>
<p>
<div>
<pre>Reproduce all of the below with:
clang -c -fms-extensions test.c
llvm-objdump -t -section-headers test.o
The first bug is that bss_seg does not result in a section of the correct type:
#pragma bss_seg(".bss2")
int a2;
a2 is correctly placed in a section called .bss2, however the resulting .bss2
section is marked DATA and not BSS.
3 .bss2 00000004 0000000000000000 DATA
...
0000000000000000 g .bss2 00000004 a2
Removing the pragma causes the variable to be emitted as a common variable.
The second bug is that bss_seg is ignored for some zi data:
#pragma bss_seg(".bss2")
int b2 = 0;
This results in b2 being created as a zi variable, but in the default .bss
section rather than the special .bss2 section, which is not created at all.
3 .bss 00000004 0000000000000000 BSS
...
0000000000000000 g .bss 00000004 b2
Combining the above two examples shows a2 going in the correct section but with
the wrong attributes, whilst b2 ends up in the wrong section but with the
correct attributes!
The third issue as that when the #pragma does work, it appears to not respect
ordering and apply across the whole file:
int a1;
#pragma bss_seg(".bss2")
int a2;
The #pragma should only apply to subsequent declarations, so a1 should be a
common symbol and a2 should end up in .bss2. Instead both a1 and a2 ending up
in .specialzi.
0000000000000000 g .bss2 00000004 a1
0000000000000004 g .bss2 00000004 a2
If you pop or reset the pragma bss_seg after a2 is declared then both variables
end up as common symbols:
int a1;
#pragma bss_seg(".bss2")
int a2;
#pragma bss_seg()
0000000000000004 g *COM* 00000004 a1
0000000000000004 g *COM* 00000004 a2
It seems that the last pragma bss_seg value wins the day and applies to all zi
data.
Finally, some zi data can be affected by the data_seg pragma:
int b1 = 0;
#pragma data_seg("specialrw")
int b2 = 0;
I would expect that given b1 is zi data, then b2 would end up in the same place
as the pragma should not apply. Instead b2 goes in "specialrw"
3 .bss 00000004 0000000000000000 BSS
4 specialrw 00000004 0000000000000000 DATA
...
0000000000000000 g .bss 00000004 b1
0000000000000000 g specialrw 00000004 b2</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are on the CC list for the bug.</li>
</ul>
</body>
</html>