# Copyright 2016-2023 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see .
# Test accessing "non-variable" variables, i.e., variables which are
# optimized to a constant DWARF location expression and/or
# partially/fully optimized out.
load_lib dwarf.exp
if {![dwarf2_support]} { return 0 }
standard_testfile main.c -dw.S
# Make some DWARF for the test.
set asm_file [standard_output_file $srcfile2]
Dwarf::assemble $asm_file {
global srcfile
cu {} {
compile_unit {
{DW_AT_name $srcfile}
} {
declare_labels int_type_label char_type_label \
struct_s_label struct_t_label array_a9_label \
char_ptr_label implicit_a_label stack_b_label
int_type_label: base_type {
{name "int"}
{encoding @DW_ATE_signed}
{byte_size 4 DW_FORM_sdata}
}
char_type_label: base_type {
{name "char"}
{encoding @DW_ATE_unsigned}
{byte_size 1 DW_FORM_sdata}
}
char_ptr_label: pointer_type {
{type :$char_type_label}
}
struct_s_label: structure_type {
{name s}
{byte_size 4 DW_FORM_sdata}
} {
member {
{name a}
{type :$int_type_label}
{data_member_location 0 DW_FORM_udata}
{bit_size 8 DW_FORM_udata}
}
member {
{name b}
{type :$int_type_label}
{data_bit_offset 8 DW_FORM_udata}
{bit_size 24 DW_FORM_udata}
}
}
struct_t_label: structure_type {
{name t}
{byte_size 4 DW_FORM_sdata}
} {
member {
{name a}
{type :$int_type_label}
{data_member_location 0 DW_FORM_udata}
{bit_size 9 DW_FORM_udata}
}
member {
{name b}
{type :$int_type_label}
{data_bit_offset 9 DW_FORM_udata}
{bit_size 23 DW_FORM_udata}
}
}
array_a9_label: array_type {
{type :$char_type_label}
} {
subrange_type {
{type :$int_type_label}
{upper_bound 8 DW_FORM_udata}
}
}
DW_TAG_subprogram {
{MACRO_AT_func {main}}
{DW_AT_external 1 flag}
} {
# Simple variable without location.
DW_TAG_variable {
{name undef_int}
{type :$int_type_label}
}
# Struct variable without location.
DW_TAG_variable {
{name undef_s}
{type :$struct_s_label}
}
# Composite location: byte-aligned pieces.
DW_TAG_variable {
{name def_s}
{type :$struct_s_label}
{location {
const1u 0
stack_value
bit_piece 8 0
const1s -1
stack_value
bit_piece 24 0
} SPECIAL_expr}
}
# Composite location: non-byte-aligned pieces.
DW_TAG_variable {
{name def_t}
{type :$struct_t_label}
{location {
const2s -184
stack_value
bit_piece 9 0
const4u 1752286
stack_value
bit_piece 23 0
} SPECIAL_expr}
}
# Composite location with some empty pieces.
DW_TAG_variable {
{name part_def_a}
{type :$array_a9_label}
{location {
piece 3
const4u 0xf1927314
stack_value
piece 4
piece 2
} SPECIAL_expr}
}
# Implicit location: immediate value.
DW_TAG_variable {
{name def_implicit_s}
{type :$struct_s_label}
{location {
implicit_value 0x12 0x34 0x56 0x78
} SPECIAL_expr}
}
# Implicit location: immediate value for whole array, with
# excess bytes.
implicit_a_label: DW_TAG_variable {
{name def_implicit_a}
{type :$array_a9_label}
{location {
implicit_value 0x1 0x12 0x23 0x34 0x45 \
0x56 0x67 0x78 0x89 0x9a 0xab
} SPECIAL_expr}
}
# Implicit pointer into immediate value.
DW_TAG_variable {
{name implicit_a_ptr}
{type :$char_ptr_label}
{location {
implicit_pointer $implicit_a_label 5
} SPECIAL_expr}
}
# Stack-value location.
stack_b_label: DW_TAG_variable {
{name def_stack_b}
{type :$struct_t_label}
{location {
const4u 0x1a2b3c4d
stack_value
} SPECIAL_expr}
}
# Implicit pointer into stack value.
DW_TAG_variable {
{name implicit_b_ptr}
{type :$char_ptr_label}
{location {
implicit_pointer $stack_b_label 1
} SPECIAL_expr}
}
}
}
}
}
if { [prepare_for_testing "failed to prepare" ${testfile} \
[list $srcfile $asm_file] {nodebug}] } {
return -1
}
if ![runto_main] {
return -1
}
# Determine byte order.
set endian [get_endianness]
# Byte-aligned objects with simple location descriptions.
switch $endian { big {set val 0x345678} little {set val 0x785634} }
gdb_test "print/x def_implicit_s" " = \\{a = 0x12, b = $val\\}"
gdb_test "print/x def_implicit_s.b" " = $val"
gdb_test "print/x def_implicit_a" \
" = \\{0x1, 0x12, 0x23, 0x34, 0x45, 0x56, 0x67, 0x78, 0x89\\}"
gdb_test "print/x def_implicit_a\[5\]" " = 0x56"
gdb_test "print/x *(char (*)\[5\]) implicit_a_ptr" \
" = \\{0x56, 0x67, 0x78, 0x89, 0x9a\\}"
switch $endian {
big {set val "a = 52, b = 2833485"}
little {set val "a = 77, b = 857502"}
}
gdb_test "print def_stack_b" " = \\{$val\\}"
switch $endian {big {set val 0x2b} little {set val 0x3c}}
gdb_test "print/x *implicit_b_ptr" " = $val"
# Byte-aligned fields, pieced together from DWARF stack values.
gdb_test "print def_s" " = \\{a = 0, b = -1\\}"
switch $endian { big {set val 0x92} little {set val 0x73} }
gdb_test "print/x part_def_a\[4\]" " = $val"
gdb_test "print/x part_def_a\[8\]" " = "
# Non-byte-aligned fields, pieced together from DWARF stack values.
gdb_test "print def_t" " = \\{a = -184, b = 1752286\\}"
# Simple variable without location.
gdb_test "print undef_int" " = "
# Member of a structure without location.
gdb_test "print undef_s.a" " = "