[PATCH] KFAIL variable-length array tests which fail with Clang

Tom de Vries tdevries@suse.de
Fri Nov 20 16:30:02 GMT 2020


On 11/20/20 4:50 PM, Tom Tromey wrote:
>>>>>> "Tom" == Tom de Vries <tdevries@suse.de> writes:
> 
> Tom> +               gdb_byte last = block->data[block->size - 1];
> Tom> +               baton->locexpr.is_reference
> Tom> +                 = !(last == DW_OP_stack_value || last == DW_OP_implicit_value);
> 
> I don't really understand the is_reference stuff

In case a dwarf expression is used for an DW_AT_location attribute, by
default it represents an address, and needs to be dereferenced to get
the value.

> but my first reaction
> is that it must be incorrect somehow.
> 
> Anyway, gdb can't do this sort of check.  It will fail if the expression
> has a different shape, which is completely allowed by the spec.

So, I'm referring to this bit in the dwarf standard (v4):
...
2.6.1.1.3 Implicit Location Descriptions

An implicit location description represents a piece or all of an object
which has no actual location but whose contents are nonetheless either
known or known to be undefined.

The following DWARF operations may be used to specify a value that has
no location in the program but is a known constant or is computed from
other locations and values in the program.

   ...

2.DW_OP_stack_value

The DW_OP_stack_value operation specifies that the object does not exist
in memory but its value is nonetheless known and is at the top of the
DWARF expression stack. In this form of location description, the DWARF
expression represents the actual value of the object, rather than its
location. The DW_OP_stack_value operation terminates the expression.
...

AFAIU, the spec specifically says how to interpret a DW_OP_stack_value
at the end of the dwarf expression which is used a location description,
and the code in the patch follows that reasoning.

So, for my understanding, can you give an example of the problem you're
envisioning?

Thanks,
- Tom


More information about the Gdb-patches mailing list