public inbox for binutils@sourceware.org
 help / color / mirror / Atom feed
From: Indu Bhagat <indu.bhagat@oracle.com>
To: Jens Remus <jremus@linux.ibm.com>, binutils@sourceware.org
Cc: Andreas Krebbel <krebbel@linux.ibm.com>
Subject: Re: [RFC PATCH 0/1] sframe: Represent FP without RA on stack (bitmap)
Date: Mon, 22 Apr 2024 16:59:39 -0700	[thread overview]
Message-ID: <0996b8e3-9fe3-4381-b34c-df9ef3798d67@oracle.com> (raw)
In-Reply-To: <20240422155905.2497883-1-jremus@linux.ibm.com>

On 4/22/24 08:59, Jens Remus wrote:
> This patch series adds support in SFrame to represent the frame pointer
> (FP) without the return address (RA) being saved on the stack (and/or on
> s390x in another register).
> 
> This is the second of two proposed alternatives:
> 1. The alternative patch series uses a dummy padding offset (invalid
>     offset from CFA value of zero) as RA offset to represent FP without
>     RA on saved on the stack.
> 2. This patch series changes the SFrame FRE count field into
>     a bitmap, to convey which offsets follow the FRE.
> 
> Note that it currently applies on top of my v3 patch series series that
> adds initial support to generate .sframe from CFI directives on s390x,
> although it is independent of that.
> 
> A SFrame FRE currently has a 4-bit field containing the offset count
> that follow the FRE. While this could account for up to 15 offsets (or
> 16, when excluding the mandatory CFA offset from CFA base register), it
> cannot represent which of these offsets actually follow.
> 
> Redefining the 4-bit count field into a 4-bit offset bitmap allows to
> track up to 4 offsets (or 5, when excluding the mandatory CFA offset
> from CFA base register).
> 

This approach, in its current form, immensely confines the future 
adaptability of the format.

My recommendation would be to avoid such changes to format where is 
becomes more restrictive for future needs.  While it is generally 
recommended to not add more registers to track, confining it now to 4 
(or 5) offsets now seems rather limiting.

I have two suggestions to resolve this issue of "FP without RA on 
stack".  I will reply on the other thread.

> The main downside of this approach is that this is potentially a major
> change to the SFrame V2 format, which may require a bump to V3. The
> benefits are that (1) it does not add any dummy padding offsets, which
> would unnecessarily add bloat to the SFrame information, and that (2)
> it does not change any of the external SFrame API.
> Using a lookup table the bitmap can easily be translated into an offset
> count. Similar any logic that checks the presence of an offset can
> easily be implemented using a bit test.
> 
> Note that there is a minor implementation issue with regards to the
> internal API methods (callbacks), due to the change in SFrame format
> changing a method argument from count to bitmap.
> Additionally this initial implementation lacks better naming of the
> tracked register IDs and any update of the SFrame format specification.
> 
> Thanks and regards,
> Jens
> 
> 
> Jens Remus (1):
>    sframe: Represent FP without RA on stack
> 
>   gas/gen-sframe.c   | 66 ++++++++++++++++++++++++++++------------------
>   include/sframe.h   | 13 ++++++---
>   libsframe/sframe.c | 51 +++++++++++++++++++++++++++--------
>   3 files changed, 90 insertions(+), 40 deletions(-)
> 


  parent reply	other threads:[~2024-04-22 23:59 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-04-22 15:59 Jens Remus
2024-04-22 15:59 ` [RFC PATCH 1/1] sframe: Represent FP without RA on stack Jens Remus
2024-04-22 23:59 ` Indu Bhagat [this message]
2024-04-23  9:54   ` [RFC PATCH 0/1] sframe: Represent FP without RA on stack (bitmap) Jens Remus
2024-04-25  7:58     ` Indu Bhagat

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=0996b8e3-9fe3-4381-b34c-df9ef3798d67@oracle.com \
    --to=indu.bhagat@oracle.com \
    --cc=binutils@sourceware.org \
    --cc=jremus@linux.ibm.com \
    --cc=krebbel@linux.ibm.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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).