This is the mail archive of the
gdb-patches@sources.redhat.com
mailing list for the GDB project.
Re: [RFA] Add parse_dwarf2_calling_convention functionality
- From: Corinna Vinschen <vinschen at redhat dot com>
- To: gdb-patches at sources dot redhat dot com
- Date: Fri, 8 Oct 2004 14:48:26 +0200
- Subject: Re: [RFA] Add parse_dwarf2_calling_convention functionality
- References: <20041007095401.GN6702@cygbert.vinschen.de>
- Reply-to: gdb-patches at sources dot redhat dot com
Hi,
On Oct 7 11:54, Corinna Vinschen wrote:
> the second patch to prepare the calling convention stuff. It just adds
> the parse_dwarf2_calling_convention functionality to gdbarch. The
> below patch contains only the patch to gdbarch.sh (not the auto-generated
> gdbarch.[ch]) and the new default_parse_dwarf2_calling_convention function
> in arch-utils.
Corrected patch below. It seems to be more useful to use the producer
field of the compilation unit instead of an artificial "gcc_compiled"
flag. The producer string is easily scanned and the information given
is more detailed than just a gcc_compiled flag.
The below patch overrides the previous patch and also contains the
necessary change to dwarf2read.c now.
Corinna
* gdbarch.sh (parse_dwarf2_calling_convention): New method.
* gdbarch.h, gdbarch.c: Re-generate.
* arch-utils.c (default_parse_dwarf2_calling_convention): New function.
* arch-utils.h (default_parse_dwarf2_calling_convention): New extern
declaration.
* dwarf2read.c (read_subroutine_type): Evaluate
DW_AT_calling_convention attribute and call
gdbarch_parse_dwarf2_calling_convention appropriately.
Index: gdbarch.sh
===================================================================
RCS file: /cvs/src/src/gdb/gdbarch.sh,v
retrieving revision 1.348
diff -u -p -r1.348 gdbarch.sh
--- gdbarch.sh 2 Sep 2004 17:22:08 -0000 1.348
+++ gdbarch.sh 8 Oct 2004 12:29:12 -0000
@@ -664,6 +664,10 @@ F:=:CORE_ADDR:fetch_pointer_argument:str
# Return the appropriate register set for a core file section with
# name SECT_NAME and size SECT_SIZE.
M::const struct regset *:regset_from_core_section:const char *sect_name, size_t sect_size:sect_name, sect_size
+
+# Evaluate DW_AT_calling_convention value and convert in a calling_convention
+# value in the functions main type.
+m::void:parse_dwarf2_calling_convention:int has_attr, unsigned long attr_val, const char *producer, struct type *func_type:has_attr, attr_val, producer, func_type:0:default_parse_dwarf2_calling_convention::0
EOF
}
Index: arch-utils.c
===================================================================
RCS file: /cvs/src/src/gdb/arch-utils.c,v
retrieving revision 1.122
diff -u -p -r1.122 arch-utils.c
--- arch-utils.c 5 Aug 2004 14:12:38 -0000 1.122
+++ arch-utils.c 8 Oct 2004 12:29:12 -0000
@@ -331,6 +331,15 @@ default_stabs_argument_has_addr (struct
return 0;
}
+void
+default_parse_dwarf2_calling_convention (struct gdbarch *gdbarch,
+ int has_attr, unsigned long attr_val,
+ const char *producer,
+ struct type *func_type)
+{
+ TYPE_CALLING_CONVENTION (func_type) = attr_val;
+}
+
/* Functions to manipulate the endianness of the target. */
Index: arch-utils.h
===================================================================
RCS file: /cvs/src/src/gdb/arch-utils.h,v
retrieving revision 1.75
diff -u -p -r1.75 arch-utils.h
--- arch-utils.h 5 Aug 2004 14:12:38 -0000 1.75
+++ arch-utils.h 8 Oct 2004 12:29:12 -0000
@@ -119,6 +120,13 @@ extern int generic_convert_register_p (i
extern int default_stabs_argument_has_addr (struct gdbarch *gdbarch,
struct type *type);
+/* By default, just use the dwarf2 val for the type's calling_convention. */
+extern void default_parse_dwarf2_calling_convention (struct gdbarch *gdbarch,
+ int has_attr,
+ unsigned long attr_val,
+ const char *producer,
+ struct type *func_type);
+
/* For compatibility with older architectures, returns
(LEGACY_SIM_REGNO_IGNORE) when the register doesn't have a valid
name. */
Index: dwarf2read.c
===================================================================
RCS file: /cvs/src/src/gdb/dwarf2read.c,v
retrieving revision 1.166
diff -u -p -r1.166 dwarf2read.c
--- dwarf2read.c 6 Oct 2004 08:46:21 -0000 1.166
+++ dwarf2read.c 8 Oct 2004 12:45:52 -0000
@@ -4571,6 +4571,13 @@ read_subroutine_type (struct die_info *d
type = die_type (die, cu);
ftype = make_function_type (type, (struct type **) 0);
+ /* Check if a calling convention attribute is given. */
+ attr = dwarf2_attr (die, DW_AT_calling_convention, cu);
+ gdbarch_parse_dwarf2_calling_convention (current_gdbarch, !!attr,
+ attr ? DW_UNSND (attr) : 0,
+ cu->producer,
+ ftype);
+
/* All functions in C++ and Java have prototypes. */
attr = dwarf2_attr (die, DW_AT_prototyped, cu);
if ((attr && (DW_UNSND (attr) != 0))
--
Corinna Vinschen
Cygwin Project Co-Leader
Red Hat, Inc.