From: Simon Marchi <simark@simark.ca>
To: Pedro Alves <palves@redhat.com>, gdb-patches@sourceware.org
Subject: Re: [PATCH v2 03/15] Calling ifunc functions when target has no debug info but resolver has
Date: Sun, 01 Apr 2018 04:22:00 -0000 [thread overview]
Message-ID: <805a18bb-d85d-f115-2e27-970ac8e8523c@simark.ca> (raw)
In-Reply-To: <20180325191943.8246-4-palves@redhat.com>
On 2018-03-25 03:19 PM, Pedro Alves wrote:
> In v2:
> - Added testsuite tweak.
>
> After the previous patch, on Fedora 27 (glibc 2.26), if you try
> calling strlen in the inferior, you now get:
>
> (top-gdb) p strlen ("hello")
> '__strlen_avx2' has unknown return type; cast the call to its declared return type
>
> This is correct, because __strlen_avx2 is written in assembly.
>
> We can improve on this though -- if the final ifunc resolved/target
> function has no debug info, but the ifunc _resolver_ does have debug
> info, we can try extracting the final function's type from the type
> that the resolver returns. E.g.,:
>
> typedef size_t (*strlen_t) (const char*);
>
> size_t my_strlen (const char *) { /* some implementation */ }
> strlen_t strlen_resolver (unsigned long hwcap) { return my_strlen; }
>
> extern size_t strlen (const char *s);
> __typeof (strlen) strlen __attribute__ ((ifunc ("strlen_resolver")));
>
> In the strlen example above, the resolver returns strlen_t, which is a
> typedef for pointer to a function that returns size_t. "strlen_t" is
> the type of both the user-visible "strlen", and of the the target
> function that implements it.
>
> This patch teaches GDB to extract that type.
>
> This is done for actual inferior function calls (in infcall.c), and
> for ptype (in eval_call). By the time we get to either of these
> places, we've already lost the original symbol/minsym, and only have
> values and types to work with. Hence the changes to c-exp.y and
> evaluate_var_msym_value, to ensure that we propagate the ifunc
> minsymbol's info.
>
> The change to make ifunc symbols have no/unknown return type exposes a
> latent problem -- gdb.compile/compile-ifunc.exp calls a no-debug-info
> function, but we did not warn about it. The test is fixed by this
> commit too.
As usual, what you did seems to make sense, but I'm a bit lost. I noted
some random comments.
> diff --git a/gdb/blockframe.c b/gdb/blockframe.c
> index 9be8871f756..db02b35742d 100644
> --- a/gdb/blockframe.c
> +++ b/gdb/blockframe.c
> @@ -323,6 +323,40 @@ find_pc_partial_function (CORE_ADDR pc, const char **name, CORE_ADDR *address,
> return find_pc_partial_function_gnu_ifunc (pc, name, address, endaddr, NULL);
> }
>
> +/* See symtab.h. */
> +
> +struct type *
> +find_gnu_ifunc_target_type (CORE_ADDR resolver_funaddr)
> +{
> + /* See if we can figure out the function's return type from the type
> + that the resolver returns. */
> + symbol *sym = find_pc_function (resolver_funaddr);
> + if (sym != NULL
> + && SYMBOL_CLASS (sym) == LOC_BLOCK
> + && BLOCK_START (SYMBOL_BLOCK_VALUE (sym)) == resolver_funaddr)
> + {
This looks a lot like the "find_function_type" function. Maybe it should use it?
> @@ -864,7 +878,11 @@ call_function_by_hand_dummy (struct value *function,
> }
> }
>
> - funaddr = find_function_addr (function, &values_type);
> + struct type *ftype = check_typedef (value_type (function));
> + if (TYPE_CODE (ftype) == TYPE_CODE_PTR)
> + ftype = check_typedef (TYPE_TARGET_TYPE (ftype));
Are these last operations necessary to do here? It seems to me like find_function_addr
will do pretty much the same work and ignore the input value of ftype anyway.
> +
> + funaddr = find_function_addr (function, &values_type, &ftype);
> if (values_type == NULL)
> values_type = default_return_type;
> if (values_type == NULL)
> diff --git a/gdb/infcall.h b/gdb/infcall.h
> index a3861fb1bf3..bea1494b50d 100644
> --- a/gdb/infcall.h
> +++ b/gdb/infcall.h
> @@ -25,8 +25,15 @@
> struct value;
> struct type;
>
> +/* Determine a function's address and its return type from its value.
> + If the function is a GNU ifunc, then return the address of the
> + target function, and set *FUNCTION_TYPE to the target function's
> + type, and *RETVAL_TYPE to the target function's return type..
> + Calls error() if the function is not valid for calling. */
> +
> extern CORE_ADDR find_function_addr (struct value *function,
> - struct type **retval_type);
> + struct type **retval_type,
> + struct type **function_type = NULL);
Isn't the function's return value type always the target type of the function's
type? If so, it seems a bit redundant to have both retval_type and function_type.
The callers easily call TYPE_TARGET_TYPE on *function_type. Or maybe do you see
some situations where we're able to determine the reval_type but not the
function_type, in which case the retval_type would still be relevant?
Simon
next prev parent reply other threads:[~2018-04-01 4:22 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-03-25 19:19 [PATCH v2 00/15] Fixing GNU ifunc support Pedro Alves
2018-03-25 19:19 ` [PATCH v2 07/15] Breakpoints, don't skip prologue of ifunc resolvers with debug info Pedro Alves
2018-03-25 19:19 ` [PATCH v2 15/15] Fix resolving GNU ifunc bp locations when inferior runs resolver Pedro Alves
2018-03-25 19:19 ` [PATCH v2 12/15] For PPC64/ELFv1: Introduce mst_data_gnu_ifunc Pedro Alves
2018-03-25 19:19 ` [PATCH v2 05/15] Fix elf_gnu_ifunc_resolve_by_got buglet Pedro Alves
2018-04-01 4:32 ` Simon Marchi
2018-04-10 21:52 ` Pedro Alves
2018-03-25 19:19 ` [PATCH v2 03/15] Calling ifunc functions when target has no debug info but resolver has Pedro Alves
2018-04-01 4:22 ` Simon Marchi [this message]
2018-04-10 21:48 ` Pedro Alves
2018-04-10 21:54 ` Pedro Alves
2018-03-25 19:19 ` [PATCH v2 11/15] Fix stepping past GNU ifunc resolvers (introduce lookup_msym_prefer) Pedro Alves
2018-06-18 20:26 ` [PATCH] Silence GCC "uninitialized" warning on minsyms.c:lookup_minimal_symbol_by_pc_section Sergio Durigan Junior
2018-06-19 15:22 ` Pedro Alves
2018-06-19 16:55 ` Sergio Durigan Junior
2018-06-19 18:47 ` Tom Tromey
2018-03-25 19:19 ` [PATCH v2 01/15] Fix breakpoints in ifunc after inferior resolved it (@got.plt symbol creation) Pedro Alves
2018-04-01 3:35 ` Simon Marchi
2018-04-10 21:20 ` Pedro Alves
2018-04-14 16:36 ` Simon Marchi
2018-03-25 19:19 ` [PATCH v2 02/15] Fix calling ifunc functions when resolver has debug info and different name Pedro Alves
2018-04-01 3:44 ` Simon Marchi
2018-04-10 21:20 ` Pedro Alves
2018-03-25 19:19 ` [PATCH v2 08/15] Eliminate find_pc_partial_function_gnu_ifunc Pedro Alves
2018-03-25 19:25 ` [PATCH v2 09/15] Factor out minsym_found/find_function_start_sal overload Pedro Alves
2018-03-25 19:25 ` [PATCH v2 04/15] Calling ifunc functions when resolver has debug info, user symbol same name Pedro Alves
2018-03-25 19:28 ` [PATCH v2 14/15] Extend GNU ifunc testcases Pedro Alves
2018-03-25 19:29 ` [PATCH v2 06/15] Fix setting breakpoints on ifunc functions after they're already resolved Pedro Alves
2018-03-25 19:29 ` [PATCH v2 13/15] PPC64: always make synthetic .text symbols for GNU ifunc symbols Pedro Alves
2018-03-25 19:33 ` Pedro Alves
2018-03-26 7:54 ` Alan Modra
2018-03-25 19:29 ` [PATCH v2 10/15] For PPC64: elf_gnu_ifunc_record_cache: handle plt symbols in .text section Pedro Alves
2018-04-26 12:23 ` [PATCH v2 00/15] Fixing GNU ifunc support Pedro Alves
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=805a18bb-d85d-f115-2e27-970ac8e8523c@simark.ca \
--to=simark@simark.ca \
--cc=gdb-patches@sourceware.org \
--cc=palves@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox