blob: 171e0cbf3aab6f4369f5f0c87e20fe51aa02e09d [file]
# Copyright 2017-2026 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 <http://www.gnu.org/licenses/>.
load_lib dwarf.exp
# This test can only be run on targets which support DWARF-2 and use gas.
require dwarf2_support
standard_testfile .c -dw.S
# We need to know the size of integer and address types in order
# to write some of the debugging info we'd like to generate.
#
# For that, we ask GDB by debugging our ada-valprint-error.c program.
# Any program would do, but since we already have ada-valprint-error.c
# specifically for this testcase, might as well use that.
if { [prepare_for_testing ${testfile}.exp ${testfile} ${srcfile}] } {
untested "failed to compile"
return
}
# Make some DWARF for the test.
set asm_file [standard_output_file $srcfile2]
Dwarf::assemble $asm_file {
cu {} {
DW_TAG_compile_unit {
DW_AT_language @DW_LANG_Ada95
DW_AT_name fd.adb
DW_AT_comp_dir /tmp
} {
declare_labels array_elt_label integer_label array_label \
typedef_label ref_type_label
set ptr_size [get_sizeof "void *" 96]
set int_size [get_sizeof "int" 4]
# A structure with no size attribute, to mimic structures
# in Ada that have a dynamic size...
array_elt_label: structure_type {
DW_AT_name fd__Tints_doubledC
DW_AT_artificial 1 DW_FORM_flag_present
}
# ... and a corresponding XVZ variable, supposed to be there
# to provide the actual size. Except that, in this case,
# the variable has no address, to simulate the fact that
# it has been optimized out (which the compiler can do,
# even if it at the expense of debuggability).
DW_TAG_variable {
DW_AT_name fd__Tints_doubledC___XVZ
DW_AT_type :$integer_label
DW_AT_artificial 1 DW_FORM_flag_present
}
integer_label: DW_TAG_base_type {
DW_AT_byte_size $int_size DW_FORM_sdata
DW_AT_encoding @DW_ATE_signed
DW_AT_name integer
}
array_label: DW_TAG_array_type {
DW_AT_name fd__ints_doubled
DW_AT_type :$array_elt_label
} {
DW_TAG_subrange_type {
DW_AT_type :$integer_label
DW_AT_upper_bound 2 DW_FORM_data1
}
}
typedef_label: DW_TAG_typedef {
DW_AT_name fd__ints_doubled
DW_AT_type :$array_label
}
ref_type_label: DW_TAG_reference_type {
DW_AT_byte_size $ptr_size DW_FORM_sdata
DW_AT_type :$typedef_label
}
DW_TAG_variable {
DW_AT_name fd__global
DW_AT_type :$ref_type_label
DW_AT_location {
DW_OP_addr [gdb_target_symbol fd__global]
} SPECIAL_expr
DW_AT_external 1 flag
}
}
}
}
if { [prepare_for_testing ${testfile}.exp ${testfile} \
[list $srcfile $asm_file] {nodebug}] } {
return
}
# Note: This test may fail with certain clang + linker combinations
# Specifically, clang + ld.lld can fail to apply relocations when linking
# nodebug .o with separate DWARF .o, leaving fd__global as NULL instead
# of pointing to buffer. The failure is a linker limitation, not a GDB bug.
#
# Known to fail: clang 20/22 + GNU ld 2.42, clang 22 + ld.lld 22
# Known to pass: GCC + GNU ld, clang 17/19 + GNU ld 2.45.0
set unsupported 0
gdb_test_multiple "print /x fd__global" "check fd__global value" {
-re -wrap "@0x0: 0x0" {
set unsupported 1
}
-re -wrap "" {
pass $gdb_test_name
}
}
if {$unsupported} {
unsupported "linker failed to apply relocation for fd__global"
return
}
gdb_test_no_output "set language ada"
gdb_test "print fd.global" \
" = <error reading variable: unable to read value of fd__Tints_doubledC___XVZ \\(value has been optimized out\\)>"