forked from Imagelibrary/binutils-gdb
Rewrite GNAT-encoded fixed point types in DWARF reader
gdb currently supports two different styles of fixed-point. The original style, where fixed point types are "GNAT encoded", is handled primarily in the Ada code. The newer style, encoded using DWARF, is handled by the core of gdb. This patch changes gdb to read the GNAT encodings in the DWARF reader as well. This removes some code and unifies the two paths. As a result, GNAT-encoded fixed-point now works a bit better. One possible drawback of this change is that, if someone uses stabs, then fixed-point might now stop working. I consider stabs to be fully obsolete, though, so I don't intend to address this. gdb/ChangeLog 2021-03-02 Tom Tromey <tromey@adacore.com> * ada-lang.c (cast_from_gnat_encoded_fixed_point_type) (cast_to_gnat_encoded_fixed_point_type): Remove. (ada_value_cast, ada_evaluate_subexp): Update. (gnat_encoded_fixed_point_type_info) (ada_is_gnat_encoded_fixed_point_type) (gnat_encoded_fixed_point_delta) (gnat_encoded_fixed_point_scaling_factor): Remove. * ada-lang.h (ada_is_gnat_encoded_fixed_point_type) (gnat_encoded_fixed_point_delta) (gnat_encoded_fixed_point_scaling_factor): Don't declare. * ada-typeprint.c (print_gnat_encoded_fixed_point_type): Remove. (ada_print_type): Update. * ada-valprint.c (ada_value_print_num): Update. * dwarf2/read.c (ada_get_gnat_encoded_number) (ada_get_gnat_encoded_ratio): New functions. (finish_fixed_point_type): Use them. Add parameters. (GNAT_FIXED_POINT_SUFFIX): New define. (gnat_encoded_fixed_point_type_info): New function. (read_base_type): Handle gnat encodings. gdb/testsuite/ChangeLog 2021-03-02 Tom Tromey <tromey@adacore.com> * gdb.ada/fixed_points.exp: Remove most special cases for minimal encodings.
This commit is contained in:
@@ -741,22 +741,10 @@ ada_value_print_num (struct value *val, struct ui_file *stream, int recurse,
|
||||
struct type *type = ada_check_typedef (value_type (val));
|
||||
const gdb_byte *valaddr = value_contents_for_printing (val);
|
||||
|
||||
if (ada_is_gnat_encoded_fixed_point_type (type))
|
||||
{
|
||||
struct value *scale = gnat_encoded_fixed_point_scaling_factor (type);
|
||||
val = value_cast (value_type (scale), val);
|
||||
val = value_binop (val, scale, BINOP_MUL);
|
||||
|
||||
const char *fmt = TYPE_LENGTH (type) < 4 ? "%.11g" : "%.17g";
|
||||
std::string str
|
||||
= target_float_to_string (value_contents (val), value_type (val), fmt);
|
||||
fputs_filtered (str.c_str (), stream);
|
||||
return;
|
||||
}
|
||||
else if (type->code () == TYPE_CODE_RANGE
|
||||
&& (TYPE_TARGET_TYPE (type)->code () == TYPE_CODE_ENUM
|
||||
|| TYPE_TARGET_TYPE (type)->code () == TYPE_CODE_BOOL
|
||||
|| TYPE_TARGET_TYPE (type)->code () == TYPE_CODE_CHAR))
|
||||
if (type->code () == TYPE_CODE_RANGE
|
||||
&& (TYPE_TARGET_TYPE (type)->code () == TYPE_CODE_ENUM
|
||||
|| TYPE_TARGET_TYPE (type)->code () == TYPE_CODE_BOOL
|
||||
|| TYPE_TARGET_TYPE (type)->code () == TYPE_CODE_CHAR))
|
||||
{
|
||||
/* For enum-valued ranges, we want to recurse, because we'll end
|
||||
up printing the constant's name rather than its numeric
|
||||
|
||||
Reference in New Issue
Block a user