Skip to content

Latest commit

 

History

History
322 lines (261 loc) · 11.1 KB

SYNC_UPSTREAM.md

File metadata and controls

322 lines (261 loc) · 11.1 KB

How to synchronize HCC with upstream

This section shows the step to synchronize HCC with upstream projects, such as Clang, LLVM, and LLD. The process is currently carried out manually but it could and should be automated.

Upstream Clang, LLVM, and LLD all sit in different git repositories and they are almost changed daily. Sometimes a change upstream may affect several projects, but it is usually not easy to figure it out from the commit log.

HCC has been configured to use git submodules to track these dependencies, but there are users who prefer using repo tool. This document has been revised to cope with both git submodules and repo.

HCC depends on amd-common LLVM / LLD / Clang, which is a fork maintained by AMD, and may contain patches not yet upstreamed. amd-common LLVM / LLD / Clang is automatically synchronized with upstream LLVM / LLD / Clang every 4 hours, so they are very close to the latest codes upstream.

There are two roles in the HCC merge process. The one who conducts the upstream sync process through getting all the amd-common code, merging it into amd-hcc, and filing the pull requests. And the one who reviews all of your sync pull requests. The HCC merge maintainer will take on the first role, and is required to interact, modify, and satisfy the changes requested by the reviewer before the pull requests can be accepted.

Generally speaking, the process goes like this:

  1. Clone HCC repo manifest
  2. Clone HCC with repo
  3. Initialize git submodules
  4. Add all remotes and forks for submodules
  5. Checkout latest master ROCm-Device-Libs
  6. Merge amd-common LLD commits
  7. Merge amd-common LLVM commits
  8. Merge master COMPILER-RT commits from llvm-mirror
  9. Merge master CLANG-TOOLS-EXTRA commits from llvm-mirror
  10. Merge amd-common Clang commits
  11. Build merged HCC
  12. Full sanity tests on merged HCC (optional)
  13. Quick sanity tests on merged HCC
  14. Push and Create Pull Request for HCC Clang submodule
  15. Push and Create Pull Request for amd-hcc LLD submodule
  16. Push and Create Pull Request for amd-hcc LLVM submodule
  17. Push and Create Pull Request for amd-hcc COMPILER-RT submodule
  18. Update HCC git submodules configuration
  19. Update HCC repo manifest

Detailed step-by-step instructions are in following sections.

Useful github remote repositories (For reference)

git locations of repositories used in the merge process are:

Set own forks for sub-directories

Go to these links and fork onto personal account:

  1. https://github.com/RadeonOpenCompute/hcc
  2. https://github.com/RadeonOpenCompute/hcc-clang-upgrade
  3. https://github.com/RadeonOpenCompute/llvm
  4. https://github.com/RadeonOpenCompute/compiler-rt
  5. https://github.com/RadeonOpenCompute/clang-tools-extra
  6. https://github.com/RadeonOpenCompute/lld Note, you'd won't need to do this for rocdl, since we will use its master branch.

This only needs to be done once.

Step-by-step Merge Process

Assuming that we have created forks for all the repositories above, follow this:

Clone HCC with repo

  • repo init -u https://github.com/RadeonOpenCompute/HCC-Native-GCN-ISA.git
  • repo sync

Clone HCC repo manifest

A manifest directory is created to track working commits for all components.

  • git clone https://github.com/RadeonOpenCompute/HCC-Native-GCN-ISA.git manifest

This directory would be referred as HCC manifest directory hereafter.

Initialize git submodules

From here on, replace aaronenyeshi with your own github id

  • git clone https://github.com/aaronenyeshi/hcc.git hcc_fork
  • cd hcc_fork
  • git checkout clang_tot_upgrade
  • git submodule update --init

There will be an hcc-fork directory inside the repo. It would be referred as HCC directory hereafter.

Add all remotes and forks for submodules

  • change to HCC directory
  • git remote add hcc_fork https://github.com/aaronenyeshi/hcc.git
  • cd ../lld
  • git remote add lld_fork https://github.com/aaronenyeshi/lld.git
  • cd ../compiler
  • git remote add llvm_fork https://github.com/aaronenyeshi/llvm.git
  • cd ../compiler-rt
  • git remote add compiler-rt_fork https://github.com/aaronenyeshi/compiler-rt.git
  • git remote add compiler-rt https://github.com/llvm-mirror/compiler-rt
  • cd ../clang-tools-extra
  • git remote add clang-tools-extra_fork https://github.com/aaronenyeshi/clang-tools-extra.git
  • git remote add clang-tools-extra https://github.com/llvm-mirror/clang-tools-extra
  • cd ../clang
  • git remote add clang_fork https://github.com/aaronenyeshi/hcc-clang-upgrade.git
  • git remote add clang https://github.com/RadeonOpenCompute/clang

Use git remote -v to verify the new remotes are added.

Checkout latest master ROCm-Device-Libs

  • change to HCC directory
  • cd rocdl
  • git fetch --all
  • git checkout origin/master

Merge amd-common LLD commits

From here, replace YYYYMMDD with your date.

  • change to HCC directory
  • cd lld
  • git fetch --all
  • git checkout -b merge_YYYYMMDD origin/amd-hcc
  • git merge origin/amd-common --no-edit
  • Resolve any merge conflicts encountered here

Merge amd-common LLVM commits

  • change to HCC directory
  • cd compiler
  • git fetch --all
  • git checkout -b merge_YYYYMMDD origin/amd-hcc
  • git merge origin/amd-common --no-edit
  • Resolve any merge conflicts encountered here

Merge amd-common COMPILER-RT commits from llvm-mirror

  • change to HCC directory
  • cd compiler-rt
  • git fetch --all
  • git checkout -b merge_YYYYMMDD origin/amd-hcc
  • git merge --no-ff compiler-rt/master --no-edit
  • Resolve any merge conflicts encountered here

Merge amd-common CLANG-TOOLS-EXTRA commits from llvm-mirror

  • change to HCC directory
  • cd clang-tools-extra
  • git fetch --all
  • git checkout -b merge_YYYYMMDD origin/amd-hcc
  • git merge clang-tools-extra/master --no-edit
  • Resolve any merge conflicts encountered here

Merge amd-common Clang commits

  • change to HCC directory
  • cd clang
  • git fetch --all
  • git checkout -b merge_YYYYMMDD origin/clang_tot_upgrade
  • git merge --no-ff clang/amd-common --no-edit
  • Resolve any merge conflicts encountered here

Build merged HCC

  • change to root directory
  • mkdir -p build; cd build
  • cmake -DCMAKE_BUILD_TYPE=Release ../hcc
  • make -j

Fix any compilation failures if there is any. Repeat this step until HCC can be built.

Full sanity tests on merged HCC (optional)

Test all unit tests.

  • change to HCC build directory
  • make test

Resolve any issues encountered here. May see old test failures.

Quick sanity tests on merged HCC

Assume commands below are carried out in HCC build directory. And HCC directory is at ~/hcc.

Test with one C++AMP FP math unit test.

bin/hcc `bin/clamp-config --build --cxxflags --ldflags` -lm \
  ~/hcc/tests/Unit/AmpMath/amp_math_cos.cpp
./a.out ; echo $?

Test with one grid_launch unit test with AM library usage.

bin/hcc `bin/hcc-config --build --cxxflags --ldflags` -lhc_am \
  ~/hcc/tests/Unit/GridLaunch/glp_const.cpp
./a.out ; echo $?

Test with one HC unit test with atomic function and 64-bit arithmetic.

bin/hcc `bin/hcc-config --build --cxxflags --ldflags` \
  ~/hcc/tests/Unit/HC/hc_atomic_add_global.cpp
./a.out ; echo $?

Push and Create Pull Request for HCC Clang submodule

Push and Create Pull Request for amd-hcc LLD submodule

Push and Create Pull Request for amd-hcc LLVM submodule

Push and Create Pull Request for amd-hcc COMPILER-RT submodule

Push and Create Pull Request for amd-hcc CLANG-TOOLS-EXTRA submodule

*** Wait until all Pull Requests are approved and merged. *** On github when making a pull request, the repository you are trying to update will have a list of reviewers who have the authority to approve pull requests and merge them into the repositories. During the review period, you are required to interact with the reviewers.

For the pull requests to be approved, you must wait for a reviewer to accept the changes you are making. The reviewer will request changes if the code is not ready for merge. It is your responsibility to interact and resolve all conflicts so that the PR is ready for merge.

Update HCC git submodules configuration

  • change to HCC directory
  • git checkout origin/clang_tot_upgrade
  • cd clang
  • git fetch --all
  • git checkout origin/clang_tot_upgrade
  • cd ../compiler
  • git fetch --all
  • git checkout origin/amd-hcc
  • cd compiler-rt
  • git fetch --all
  • cd clang-tools-extra
  • git fetch --all
  • git checkout origin/amd-hcc
  • cd lld
  • git fetch --all
  • git checkout origin/amd-hcc
  • cd rocdl
  • git fetch --all
  • git checkout origin/master
  • git commit -m "[Config] revise submodule configuration", or provide custom commit log
  • git push origin merge_YYYYMMDD:merge_YYYYMMDD Create a pull request to merge merge_YYYYMMDD from your hcc fork into https://github.com/RadeonOpenCompute/hcc on branch clang_tot_upgrade.

Update HCC repo manifest

  • change to HCC directory
  • repo manifest -r > default.xml
  • copy default.xml to HCC manifest directory
  • change too HCC manifest directory
  • git add default.xml
  • git commit -m "[Config] revise manifest", or provide custom commit log
  • git push to push HCC repo manifest online

Upon reaching here, the merge process is completed.