Skip to content
This repository has been archived by the owner on Nov 17, 2023. It is now read-only.

[1.x] Backport Add cmake flag USE_FATBIN_COMPRESSION, ON by default (#19123) #19158

Merged
merged 3 commits into from
Sep 17, 2020

Conversation

DickJC123
Copy link
Contributor

Description

Backport of PR #19123. Reduces the size of nvcc fatbin output files via compression. Helps libmxnet.so to stay within 2GB limit that causes linker failures.

Checklist

Essentials

  • PR's title starts with a category (e.g. [BUGFIX], [MODEL], [TUTORIAL], [FEATURE], [DOC], etc)
  • Changes are complete (i.e. I finished coding on this PR)
  • All changes have test coverage
  • Code is well-documented

Changes

  • Feature1, tests, (and when applicable, API doc)
  • Feature2, tests, (and when applicable, API doc)

Comments

  • If this change is a backward incompatible change, why must this change be made.
  • Interesting edge cases to note here

@DickJC123 DickJC123 requested a review from szha as a code owner September 15, 2020 23:07
@mxnet-bot
Copy link

Hey @DickJC123 , Thanks for submitting the PR
All tests are already queued to run once. If tests fail, you can trigger one or more tests again with the following commands:

  • To trigger all jobs: @mxnet-bot run ci [all]
  • To trigger specific jobs: @mxnet-bot run ci [job1, job2]

CI supported jobs: [windows-cpu, website, windows-gpu, clang, sanity, centos-cpu, miscellaneous, edge, centos-gpu, unix-gpu, unix-cpu]


Note:
Only following 3 categories can trigger CI :PR Author, MXNet Committer, Jenkins Admin.
All CI tests must pass before the PR can be merged.

@mxnet-bot
Copy link

Unauthorized access detected.
Only following 3 categories can trigger CI :
PR Author, MXNet Committer, Jenkins Admin.

@samskalicky
Copy link
Contributor

It looks like CMAKE_CUDA_FLAGS gets set again later in the windows flow:
https://github.com/apache/incubator-mxnet/blob/4bb3df00ba5c509975363da8ece5cd89dc8f574a/CMakeLists.txt#L725
wont this overwrite the previous fatbin setting?

@DickJC123
Copy link
Contributor Author

I've pushed a fix to this set-vs-string_append, and changed a few minor details with the approach. I'd be surprised if it fixes things since the referenced line is not in the build's code path (I think) due to:

https://github.com/apache/incubator-mxnet/blob/38c9d57f9a14578be4fc739b9d6880b49b00c4fc/CMakeLists.txt#L76

Is it possible to have the 1.x Windows build use the same MSVC compiler as master (which doesn't seem to have the problem with -compress-all or the link OOM error)?

@samskalicky samskalicky merged commit 3d9af6e into apache:v1.x Sep 17, 2020
DickJC123 added a commit to DickJC123/mxnet that referenced this pull request Sep 18, 2020
…pache#19123) (apache#19158)

* [1.x] Backport Add cmake flag USE_FATBIN_COMPRESSION, ON by default (apache#19123)

* Trigger CI

* Appending to existing CMAKE_CUDA_FLAGS in all cases
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants