Commit 7728669d by Mark Wielaard Committed by Mark Wielaard

DWARF: Handle expressions containing "-1" in dw2_asm_output_delta_uleb128.

In dwarf2out.c dwarf2out_var_location () we create loclabels that might
contain -1 (for example ".LVL5-1"). Technically those are expressions,
not just plain labels. But they work fine everywhere we use them, except
when calculating an uleb128 delta between two labels.

For example we might create the following DWARF5 location list entry:

        .byte   0x3     # DW_LLE_startx_length (*.LLST0)
        .uleb128 0x6    # Location list range start index (*.LVL5-1)
        .uleb128 .LFE1-.LVL5-1        # Location list length (*.LLST0)
        .uleb128 0x1    # Location expression size
        .byte   0x54    # DW_OP_reg4
        .byte   0       # DW_LLE_end_of_list (*.LLST0)

Note the length is calculated using .uleb128 .LFE1-.LVL5-1. This is
wrong, since both .LVL5 and 1 are substracted from .LFE1, instead of
1 being subtracted from .LVL5 first, before substracting from .LFE1.

This happens because dw2_asm_output_delta_uleb128 expects two plain
labels and simply inserts a minus sign between them. To fix this we
simply look if the second label is actually an expression containing
a minus sign and then add brackets around it. That will emit the
correct .uleb128 expression:

        .uleb128 .LFE1-(.LVL5-1)        # Location list length (*.LLST0)

We cannot simply generate the loclabel containing brackets directly
because we do use them also in contexts that don't take a full
expression (for example we use them with .quad too).

gcc/

	* dwarf2asm.c (dw2_asm_output_delta_uleb128): Add brackets around
	lab2 if it is an expression containing a minus sign.

From-SVN: r260845
parent ab4dad49
2018-05-28 Mark Wielaard <mark@klomp.org>
* dwarf2asm.c (dw2_asm_output_delta_uleb128): Add brackets around lab2
if it is an expression containing a minus sign.
2018-05-27 John David Anglin <danglin@gcc.gnu.org> 2018-05-27 John David Anglin <danglin@gcc.gnu.org>
* config/pa/pa-linux.h (NEED_INDICATE_EXEC_STACK): Define to 0. * config/pa/pa-linux.h (NEED_INDICATE_EXEC_STACK): Define to 0.
......
...@@ -811,7 +811,17 @@ dw2_asm_output_delta_uleb128 (const char *lab1 ATTRIBUTE_UNUSED, ...@@ -811,7 +811,17 @@ dw2_asm_output_delta_uleb128 (const char *lab1 ATTRIBUTE_UNUSED,
fputs ("\t.uleb128 ", asm_out_file); fputs ("\t.uleb128 ", asm_out_file);
assemble_name (asm_out_file, lab1); assemble_name (asm_out_file, lab1);
putc ('-', asm_out_file); putc ('-', asm_out_file);
assemble_name (asm_out_file, lab2); /* dwarf2out.c might give us a label expression (e.g. .LVL548-1)
as second argument. If so, make it a subexpression, to make
sure the substraction is done in the right order. */
if (strchr (lab2, '-') != NULL)
{
putc ('(', asm_out_file);
assemble_name (asm_out_file, lab2);
putc (')', asm_out_file);
}
else
assemble_name (asm_out_file, lab2);
if (flag_debug_asm && comment) if (flag_debug_asm && comment)
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment