public inbox for gcc@gcc.gnu.org
 help / color / mirror / Atom feed
* Question about function splitting
@ 2023-10-02 15:59 Hanke Zhang
  2023-10-02 16:34 ` Martin Jambor
  0 siblings, 1 reply; 5+ messages in thread
From: Hanke Zhang @ 2023-10-02 15:59 UTC (permalink / raw)
  To: gcc

Hi, I have some questions about the strategy and behavior of function
splitting in gcc, like the following code:

int glob;
void f() {
  if (glob) {
    printf("short path\n");
    return;
  }
  // do lots of expensive things
  // ...
}

I hope it can be broken down like below, so that the whole function
can perhaps be inlined, which is more efficient.

int glob;
void f() {
  if (glob) {
    printf("short path\n");
    return;
  }
  f_part();
}

void f_part() {
  // do lots of expensive things
  // ...
}


But on the contrary, gcc splits it like these, which not only does not
bring any benefits, but may increase the time consumption, because the
function call itself is a more resource-intensive thing.

int glob;
void f() {
  if (glob) {
    f_part();
    return;
  }
  // do lots of expensive things
  // ...
}

void f_part() {
  printf("short path\n"); // just do this????
}

Are there any options I can offer to gcc to change this behavior? Or
do I need to make some changes in ipa-split.cc?

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2023-10-04 14:22 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-10-02 15:59 Question about function splitting Hanke Zhang
2023-10-02 16:34 ` Martin Jambor
2023-10-02 17:13   ` Hanke Zhang
2023-10-04  8:17     ` Richard Biener
2023-10-04 14:22       ` Hanke Zhang

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).