Search code examples
c++out-of-memorylinker-errorsc++builder

"[ilink32] Fatal: Out of memory" in C++ Builder


After updating Embarcadero C++ Builder to a new version, our project suddenly fails to build. This happens just with one of our projects. For the most of the team members, identical code builds without errors. On my computer, linking fails every time.

In Build tab:

[ilink32] Fatal: Out of memory

In Output tab:

Build FAILED.
c:\program files (x86)\embarcadero\studio\18.0\Bin\CodeGear.Cpp.Targets(3517,5): error : Fatal: Out of memory

There is no more information.

If I enable Link with Dynamic RTL, the project links without errors. For example, if our Debug target has that setting enabled, the project links in Debug but not in Release.

How can I fix this problem? How do I give more memory for the linker?


Solution

  • Explanation

    On your computer, one of the linker heaps is too small for this project. The project links with Link with Dynamic RTL option, because in that case the linker needs less memory, and the heap just happens to be large enough.

    You can use -GH linker option to increase that heap, but first you have to find out which heap overflows. To do that, enable diagnostic output in the linker.

    Compiling with diagnostic output

    Compiling from the command line:

    call rsvars
    MSBuild /v:diag YourProject.cbproj
    

    Compiling from the IDE:

    • Go to Tools > Options > IDE > Compiling and Running
      • Tools > Options > Environment Options in older versions of C++ Builder
    • Change Verbosity to Diagnostic
    • After building the project, read output from the Output tab of the Messages window

    Increasing heap sizes

    Near the end of the output, you should find sizes of heaps, similar to this:

    The "ILINK32" task is using "ilink32" from "c:\program files (x86)\embarcadero\studio\18.0\bin\ilink32.exe".
    Turbo Incremental Link 6.75 Copyright (c) 1997-2016 Embarcadero Technologies, Inc.
    Overrun on linker heap: tds
    Linker Heaps
    ------------
    system                 0x030d4000  0x08000000
    tds                    0x08710000  0x09400000
    c:\program files (x86)\embarcadero\studio\18.0\Bin\CodeGear.Cpp.Targets(3517,5): error : Fatal: Out of memory
    The command exited with code 2.
    

    In this case, overflow happened in heap tds, so we need to increase its size. The left column gives the number of bytes in use, and the right column gives the number of bytes allocated. The new size should be larger than the value that is currently in the right column.

    In this case, tds size was 0x09400000, so we increase it to 0x0f400000 with the following option: -GHtds=0x0f400000.

    In the IDE, go to Project > Options > C++ Linker. Add -GHtds=0x0f400000 to Advanced > Additional Options.

    If you are using C++ Builder 10.2. or newer, you don't need to use the command line option. You can simply set TDS heap size to 0x0f400000 on the same settings page.

    After saving project options, compile the project again. If the same heap overflows, you need to increase its size even more. If another heap overflows, you need to increase its size as well.

    For example, if code heap overflows now, and you want to increase its size to 0x0a000000, you should change Additional Options to -GHtds=0x0f400000 -GHcode=0x0a000000.

    Possible issues

    If you increase the heap too much, you will get LME288 error instead. That means you have reached the maximum size for some heap. If even the maximum size is not enough for your project, it seems C++ Builder 10.2.3. has doubled the maximum size, so you could migrate to that version, or copy ilink32.exe from 10.2.3. installation to use with an older version of C++ Builder.

    If these settings did not work, and you are using C++ Builder 10.0 or 10.1, try to patch your linker as described here: LME288 Error in C++ Builder. With C++ Builder 10.2 and newer, patching the linker should not be needed.

    More details