Skip to main content
Redhat Developers  Logo
  • AI

    Get started with AI

    • Red Hat AI
      Accelerate the development and deployment of enterprise AI solutions.
    • AI learning hub
      Explore learning materials and tools, organized by task.
    • AI interactive demos
      Click through scenarios with Red Hat AI, including training LLMs and more.
    • AI/ML learning paths
      Expand your OpenShift AI knowledge using these learning resources.
    • AI quickstarts
      Focused AI use cases designed for fast deployment on Red Hat AI platforms.
    • No-cost AI training
      Foundational Red Hat AI training.

    Featured resources

    • OpenShift AI learning
    • Open source AI for developers
    • AI product application development
    • Open source-powered AI/ML for hybrid cloud
    • AI and Node.js cheat sheet

    Red Hat AI Factory with NVIDIA

    • Red Hat AI Factory with NVIDIA is a co-engineered, enterprise-grade AI solution for building, deploying, and managing AI at scale across hybrid cloud environments.
    • Explore the solution
  • Learn

    Self-guided

    • Documentation
      Find answers, get step-by-step guidance, and learn how to use Red Hat products.
    • Learning paths
      Explore curated walkthroughs for common development tasks.
    • Guided learning
      Receive custom learning paths powered by our AI assistant.
    • See all learning

    Hands-on

    • Developer Sandbox
      Spin up Red Hat's products and technologies without setup or configuration.
    • Interactive labs
      Learn by doing in these hands-on, browser-based experiences.
    • Interactive demos
      Click through product features in these guided tours.

    Browse by topic

    • AI/ML
    • Automation
    • Java
    • Kubernetes
    • Linux
    • See all topics

    Training & certifications

    • Courses and exams
    • Certifications
    • Skills assessments
    • Red Hat Academy
    • Learning subscription
    • Explore training
  • Build

    Get started

    • Red Hat build of Podman Desktop
      A downloadable, local development hub to experiment with our products and builds.
    • Developer Sandbox
      Spin up Red Hat's products and technologies without setup or configuration.

    Download products

    • Access product downloads to start building and testing right away.
    • Red Hat Enterprise Linux
    • Red Hat AI
    • Red Hat OpenShift
    • Red Hat Ansible Automation Platform
    • See all products

    Featured

    • Red Hat build of OpenJDK
    • Red Hat JBoss Enterprise Application Platform
    • Red Hat OpenShift Dev Spaces
    • Red Hat Developer Toolset

    References

    • E-books
    • Documentation
    • Cheat sheets
    • Architecture center
  • Community

    Get involved

    • Events
    • Live AI events
    • Red Hat Summit
    • Red Hat Accelerators
    • Community discussions

    Follow along

    • Articles & blogs
    • Developer newsletter
    • Videos
    • Github

    Get help

    • Customer service
    • Customer support
    • Regional contacts
    • Find a partner

    Join the Red Hat Developer program

    • Download Red Hat products and project builds, access support documentation, learning content, and more.
    • Explore the benefits

Red Hat Enterprise Linux 7 GCC Optimizations - partial inlining indepth

October 29, 2014
Jeff Law ktietz2014
Related topics:
Linux
Related products:
Red Hat Enterprise Linux

    In this prior post we mentioned several new optimization improvements in GCC for Red Hat Enterprise Linux 7. It's time to dig a little deeper. In this post we will focus on partial inlining/function outlining which are part of the Inter-Procedural Analysis (IPA) framework.

    gnu logo

    Function inlining is a well known technique to improve application performance by expanding the body of a called function into one or more of its call site(s). Function inlining decreases function call overhead, may improve icache behaviour, expose previously hidden redundancies, etc. However, the increase in total code size may be detrimental and, as a result, heuristics which drive inlining are very sensitive to code growth. Function outlining/partial inlining are variants of function inlining to allow for inlining with less code growth.

    Function outlining partitions a function into hot (often executed) and cold (rarely executed) code. Cold code is put into separate functions that get called as necessary by the main function. The result is the main function becomes smaller and thus may be inlined more aggressively into call sites.

    Partial inlining is closely related to function outlining. Rather than inlining the entire body into a call site, the compiler may choose to inline part of the called function (typically a hot fragment at the start of the function with an early return).

    So as a simple example, consider the following code:

    extern int something_external (void);
    
    int test(int a)
    {
       if (a < 100)  return 1;
    
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
    
       return 0;
    }
    

    There is a clear "early return" in the test() function. Function outlining will gather all the code after the early return test into a distinct function, resulting in something like this:

    int
    test(int a)
    {
       if (a < 100)  return 1;
    
       return test.part.0 ();
    }
    
    int
    test.part.0 ()
    {
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       something_external ();
       return 0;
    }
    

    "test" has now become significantly smaller and may be a candidate for more aggressive inlining. Furthermore, the compiler may choose to only partially inline test() into its call sites by inlining the early exit test at sites where the parameter is a known constant and thus the result of the test is known at compile time.

    With the IPA framework, GCC can automatically analyze and perform these optimizations on an entire compilation unit (a single source file) when optimization is enabled. However, modern software design emphasizes modularity, separate compilation, etc. which limit the usefulness of these techniques.

    Link-time optimization (LTO) is a further enhancement to allow these kinds of optimizations to occur across entire applications or DSOs (dynamic shared objects, or shared libraries). In essence, LTO defers actual compilation until the link phase when the entire application/DSO is fed to the compiler as a single compilation unit. Thus in an LTO-optimized compile/link, the entire program is subject to all the IPA based optimizations, including inlining, outlining and partial inlining.

    Future posts will discuss recursive inlining, function multi-versioning, function specialization and/or other techniques GCC uses to improve the performance of the code it generates.

    Last updated: April 5, 2018

    Recent Posts

    • Every layer counts: Defense in depth for AI agents with Red Hat AI

    • Fun in the RUN instruction: Why container builds with distroless images can surprise you

    • Trusted software factory: Building trust in the agentic AI era

    • Build a zero trust AI pipeline with OpenShift and RHEL CVMs

    • Red Hat Hardened Images: Top 5 benefits for software developers

    Red Hat Developers logo LinkedIn YouTube Twitter Facebook

    Platforms

    • Red Hat AI
    • Red Hat Enterprise Linux
    • Red Hat OpenShift
    • Red Hat Ansible Automation Platform
    • See all products

    Build

    • Developer Sandbox
    • Developer tools
    • Interactive tutorials
    • API catalog

    Quicklinks

    • Learning resources
    • E-books
    • Cheat sheets
    • Blog
    • Events
    • Newsletter

    Communicate

    • About us
    • Contact sales
    • Find a partner
    • Report a website issue
    • Site status dashboard
    • Report a security problem

    RED HAT DEVELOPER

    Build here. Go anywhere.

    We serve the builders. The problem solvers who create careers with code.

    Join us if you’re a developer, software engineer, web designer, front-end designer, UX designer, computer scientist, architect, tester, product manager, project manager or team lead.

    Sign me up

    Red Hat legal and privacy links

    • About Red Hat
    • Jobs
    • Events
    • Locations
    • Contact Red Hat
    • Red Hat Blog
    • Inclusion at Red Hat
    • Cool Stuff Store
    • Red Hat Summit
    © 2026 Red Hat

    Red Hat legal and privacy links

    • Privacy statement
    • Terms of use
    • All policies and guidelines
    • Digital accessibility

    Chat Support

    Please log in with your Red Hat account to access chat support.