+2019-11-22 Andrew Burgess <andrew.burgess@embecosm.com>
+
+ * as.c (flag_dwarf_cie_version): Change initial value to -1, and
+ update comment.
+ * config/tc-riscv.c (riscv_after_parse_args): Set
+ flag_dwarf_cie_version if it has not already been set.
+ * dwarf2dbg.c (dwarf2_init): Initialise flag_dwarf_cie_version if
+ needed.
+ * testsuite/gas/riscv/default-cie-version.d: New file.
+ * testsuite/gas/riscv/default-cie-version.s: New file.
+
2019-11-22 Andrew Burgess <andrew.burgess@embecosm.com>
* dw2gencfi.c (output_cie): Error on return column overflow.
/* Enable verbose mode. */
int verbose = 0;
-/* Which version of DWARF CIE to produce. The default could be overridden
- by a target during its initialisation, or by the --gdwarf-cie-version
- command line flag. */
-int flag_dwarf_cie_version = 1;
+/* Which version of DWARF CIE to produce. This default value of -1
+ indicates that this value has not been set yet, a default value is
+ provided in dwarf2_init. A different value can also be supplied by the
+ command line flag --gdwarf-cie-version, or by a target in
+ MD_AFTER_PARSE_ARGS. */
+int flag_dwarf_cie_version = -1;
#if defined OBJ_ELF || defined OBJ_MAYBE_ELF
int flag_use_elf_stt_common = DEFAULT_GENERATE_ELF_STT_COMMON;
/* Insert float_abi into the EF_RISCV_FLOAT_ABI field of elf_flags. */
elf_flags |= float_abi * (EF_RISCV_FLOAT_ABI & ~(EF_RISCV_FLOAT_ABI << 1));
+
+ /* If the CIE to be produced has not been overridden on the command line,
+ then produce version 3 by default. This allows us to use the full
+ range of registers in a .cfi_return_column directive. */
+ if (flag_dwarf_cie_version == -1)
+ flag_dwarf_cie_version = 3;
}
long
dwarf2_init (void)
{
last_seg_ptr = &all_segs;
+
+ /* Select the default CIE version to produce here. The global
+ starts with a value of -1 and will be modified to a valid value
+ either by the user providing a command line option, or some
+ targets will select their own default in md_after_parse_args. If
+ we get here and the global still contains -1 then it is up to us
+ to pick a sane default. The default we choose is 1, this is the
+ CIE version gas has produced for a long time, and there seems no
+ reason to change it yet. */
+ if (flag_dwarf_cie_version == -1)
+ flag_dwarf_cie_version = 1;
}
--- /dev/null
+#objdump: --dwarf=frames
+#as:
+#...
+.*: file format elf.*-.*riscv
+
+Contents of the .* section:
+
+00000000 0+[0-9a-f]+ 0+000 CIE
+ Version: 3
+ Augmentation: .*
+ Code alignment factor: .*
+ Data alignment factor: .*
+ Return address column: .*
+ Augmentation data: .*
+#...
\ No newline at end of file
--- /dev/null
+ .cfi_startproc
+ .cfi_endproc
+2019-11-27 Andrew Burgess <andrew.burgess@embecosm.com>
+
+ * testsuite/ld-elf/eh5.d: Accept version 3 DWARF CIE.
+
2019-11-26 Martin Liska <mliska@suse.cz>
* scripttempl/arclinux.sc: Add .text.sorted.* which is sorted
Contents of the .eh_frame section:
0+0000 0+001[04] 0+0000 CIE
- Version: 1
+ Version: [13]
Augmentation: "zR"
Code alignment factor: .*
Data alignment factor: .*
DW_CFA_nop
0+00(2c|30) 0+0014 0+0000 CIE
- Version: 1
+ Version: [13]
Augmentation: "zPR"
Code alignment factor: .*
Data alignment factor: .*
DW_CFA_nop
0+007[48] 0+001[8c] 0+0000 CIE
- Version: 1
+ Version: [13]
Augmentation: "zPLR"
Code alignment factor: .*
Data alignment factor: .*
DW_CFA_nop
0+00b[08] 0+001[04] 0+0000 CIE
- Version: 1
+ Version: [13]
Augmentation: "zR"
Code alignment factor: .*
Data alignment factor: .*
DW_CFA_nop
#...
0+00[de]8 0+0014 0+0000 CIE
- Version: 1
+ Version: [13]
Augmentation: "zPR"
Code alignment factor: .*
Data alignment factor: .*
DW_CFA_nop
#...
0+01(1c|30) 0+001[8c] 0+0000 CIE
- Version: 1
+ Version: [13]
Augmentation: "zPLR"
Code alignment factor: .*
Data alignment factor: .*