aboutsummaryrefslogtreecommitdiffstats
path: root/riscV/TargetPrinter.ml
diff options
context:
space:
mode:
authorBernhard Schommer <bschommer@users.noreply.github.com>2019-05-10 14:46:05 +0200
committerXavier Leroy <xavierleroy@users.noreply.github.com>2019-05-10 14:46:05 +0200
commit1eaf745c5e4e32784a8e919b1a82d4d725036214 (patch)
tree475f1f146d9fc8937b6b7e5e866141dc7a9c2ab2 /riscV/TargetPrinter.ml
parent1e821bc1f1fb7a6b73ff1468b8b34f61b78cf304 (diff)
downloadcompcert-kvx-1eaf745c5e4e32784a8e919b1a82d4d725036214.tar.gz
compcert-kvx-1eaf745c5e4e32784a8e919b1a82d4d725036214.zip
Added options -fcommon and -fno-common (#164)
The option -fcommon controls whether uninitialized global variables are placed in the COMMON section. If the option is given in the negated form, -fno-common, variables are not placed in the COMMON section. They are placed in the same sections as gcc does. If the variables are not placed in the COMMON section merging of tentative definitions is inhibited and multiple definitions lead to a linker error, as it does for gcc.
Diffstat (limited to 'riscV/TargetPrinter.ml')
-rw-r--r--riscV/TargetPrinter.ml4
1 files changed, 2 insertions, 2 deletions
diff --git a/riscV/TargetPrinter.ml b/riscV/TargetPrinter.ml
index 19704bad..92df7a76 100644
--- a/riscV/TargetPrinter.ml
+++ b/riscV/TargetPrinter.ml
@@ -108,9 +108,9 @@ module Target : TARGET =
let name_of_section = function
| Section_text -> ".text"
| Section_data i | Section_small_data i ->
- if i then ".data" else "COMM"
+ if i then ".data" else common_section ()
| Section_const i | Section_small_const i ->
- if i then ".section .rodata" else "COMM"
+ if i || (not !Clflags.option_fcommon) then ".section .rodata" else "COMM"
| Section_string -> ".section .rodata"
| Section_literal -> ".section .rodata"
| Section_jumptable -> ".section .rodata"