diff options
author | Tom de Vries <tdevries@suse.de> | 2020-12-04 13:36:48 +0100 |
---|---|---|
committer | Tom de Vries <tdevries@suse.de> | 2020-12-04 13:36:48 +0100 |
commit | b6a6aa07c5bd53d19c33db1f7c9645fc99b66e1b (patch) | |
tree | d92091f20cd5b55c941143e3e355f9b8fff93612 /gdb/i386-tdep.c | |
parent | a8d136756b9882f90311af7205a00c0d97fea64d (diff) | |
download | gdb-b6a6aa07c5bd53d19c33db1f7c9645fc99b66e1b.zip gdb-b6a6aa07c5bd53d19c33db1f7c9645fc99b66e1b.tar.gz gdb-b6a6aa07c5bd53d19c33db1f7c9645fc99b66e1b.tar.bz2 |
[gdb/tdep] Handle static field in i386_16_byte_align_p
When running test-case on gdb.cp/many-args.exp with target board unix/-m32, I
run into:
...
(gdb) p check_val (ref_val, ref_val, ... , ref_val, ref_val)^M
$1 = false^M
(gdb) FAIL: gdb.cp/many-args.exp: check passing many structures
...
The test source contains struct ss:
...
typedef int v4si __attribute__ ((vector_size (16)));
struct ss
{
static v4si static_field;
unsigned char aa;
};
...
and i386_16_byte_align_p returns true for this type.
Fix this by skipping static fields in i386_16_byte_align_p.
Tested on x86_64-linux.
gdb/ChangeLog:
2020-12-04 Tom de Vries <tdevries@suse.de>
PR tdep/27007
* i386-tdep.c (i386_16_byte_align_p): Skip static fields.
Diffstat (limited to 'gdb/i386-tdep.c')
-rw-r--r-- | gdb/i386-tdep.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/gdb/i386-tdep.c b/gdb/i386-tdep.c index 00de4e1..ad02ad6 100644 --- a/gdb/i386-tdep.c +++ b/gdb/i386-tdep.c @@ -2644,6 +2644,8 @@ i386_16_byte_align_p (struct type *type) int i; for (i = 0; i < type->num_fields (); i++) { + if (field_is_static (&type->field (i))) + continue; if (i386_16_byte_align_p (type->field (i).type ())) return 1; } |