Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

rustc: Lower link args to @-files on Windows more #47507

Merged
merged 1 commit into from
Jan 22, 2018

Commits on Jan 22, 2018

  1. rustc: Lower link args to @-files on Windows more

    When spawning a linker rustc has historically been known to blow OS limits for
    the command line being too large, notably on Windows. This is especially true of
    incremental compilation where there can be dozens of object files per
    compilation. The compiler currently has logic for detecting a failure to spawn
    and instead passing arguments via a file instead, but this failure detection
    only triggers if a process actually fails to spawn.
    
    Unfortunately on Windows we've got something else to worry about which is
    `cmd.exe`. The compiler may be running a linker through `cmd.exe` where
    `cmd.exe` has a limit of 8192 on the command line vs 32k on `CreateProcess`.
    Moreso rustc actually succeeds in spawning `cmd.exe` today, it's just that after
    it's running `cmd.exe` fails to spawn its child, which rustc doesn't currently
    detect.
    
    Consequently this commit updates the logic for the spawning the linker on
    Windows to instead have a heuristic to see if we need to pass arguments via a
    file. This heuristic is an overly pessimistic and "inaccurate" calculation which
    just calls `len` on a bunch of `OsString` instances (where `len` is not
    precisely the length in u16 elements). This number, when exceeding the 6k
    threshold, will force rustc to always pass arguments through a file.
    
    This strategy should avoid us trying to parse the output on Windows of the
    linker to see if it successfully spawned yet failed to actually sub-spawn the
    linker. We may just be passing arguments through files a little more commonly
    now...
    
    The motivation for this commit was a recent bug in Gecko [1] when beta testing,
    notably when incremental compilation was enabled it blew out the limit on
    `cmd.exe`. This commit will also fix rust-lang#46999 as well though as emscripten uses a
    bat script as well (and we're blowing the limit there).
    
    [1]: https://bugzilla.mozilla.org/show_bug.cgi?id=1430886
    
    Closes rust-lang#46999
    alexcrichton committed Jan 22, 2018
    Configuration menu
    Copy the full SHA
    66366f9 View commit details
    Browse the repository at this point in the history