android13/external/toolchain-utils/compiler_wrapper
liiir1985 7f62dcda9f initial 2024-06-22 20:45:49 +08:00
..
testdata initial 2024-06-22 20:45:49 +08:00
README.md initial 2024-06-22 20:45:49 +08:00
android_config_test.go initial 2024-06-22 20:45:49 +08:00
android_llvm_next_flags.go initial 2024-06-22 20:45:49 +08:00
bisect_flag.go initial 2024-06-22 20:45:49 +08:00
bisect_flag_test.go initial 2024-06-22 20:45:49 +08:00
build.py initial 2024-06-22 20:45:49 +08:00
bundle.README initial 2024-06-22 20:45:49 +08:00
bundle.py initial 2024-06-22 20:45:49 +08:00
ccache_flag.go initial 2024-06-22 20:45:49 +08:00
ccache_flag_test.go initial 2024-06-22 20:45:49 +08:00
clang_flags.go initial 2024-06-22 20:45:49 +08:00
clang_flags_test.go initial 2024-06-22 20:45:49 +08:00
clang_syntax_flag.go initial 2024-06-22 20:45:49 +08:00
clang_syntax_flag_test.go initial 2024-06-22 20:45:49 +08:00
clang_tidy_flag.go initial 2024-06-22 20:45:49 +08:00
clang_tidy_flag_test.go initial 2024-06-22 20:45:49 +08:00
command.go initial 2024-06-22 20:45:49 +08:00
command_test.go initial 2024-06-22 20:45:49 +08:00
compile_with_fallback.go initial 2024-06-22 20:45:49 +08:00
compile_with_fallback_test.go initial 2024-06-22 20:45:49 +08:00
compiler_wrapper.go initial 2024-06-22 20:45:49 +08:00
compiler_wrapper_test.go initial 2024-06-22 20:45:49 +08:00
config.go initial 2024-06-22 20:45:49 +08:00
config_test.go initial 2024-06-22 20:45:49 +08:00
cros_hardened_config_test.go initial 2024-06-22 20:45:49 +08:00
cros_host_config_test.go initial 2024-06-22 20:45:49 +08:00
cros_llvm_next_flags.go initial 2024-06-22 20:45:49 +08:00
cros_nonhardened_config_test.go initial 2024-06-22 20:45:49 +08:00
disable_werror_flag.go initial 2024-06-22 20:45:49 +08:00
disable_werror_flag_test.go initial 2024-06-22 20:45:49 +08:00
env.go initial 2024-06-22 20:45:49 +08:00
env_test.go initial 2024-06-22 20:45:49 +08:00
errors.go initial 2024-06-22 20:45:49 +08:00
errors_test.go initial 2024-06-22 20:45:49 +08:00
gcc_flags.go initial 2024-06-22 20:45:49 +08:00
gcc_flags_test.go initial 2024-06-22 20:45:49 +08:00
go.mod initial 2024-06-22 20:45:49 +08:00
go_exec.go initial 2024-06-22 20:45:49 +08:00
goldenutil_test.go initial 2024-06-22 20:45:49 +08:00
install_compiler_wrapper.sh initial 2024-06-22 20:45:49 +08:00
kernel_bug.go initial 2024-06-22 20:45:49 +08:00
kernel_bug_test.go initial 2024-06-22 20:45:49 +08:00
libc_exec.go initial 2024-06-22 20:45:49 +08:00
libgcc_flags.go initial 2024-06-22 20:45:49 +08:00
libgcc_flags_test.go initial 2024-06-22 20:45:49 +08:00
main.go initial 2024-06-22 20:45:49 +08:00
pie_flags.go initial 2024-06-22 20:45:49 +08:00
pie_flags_test.go initial 2024-06-22 20:45:49 +08:00
print_cmdline_flag.go initial 2024-06-22 20:45:49 +08:00
print_cmdline_flag_test.go initial 2024-06-22 20:45:49 +08:00
print_config_flag.go initial 2024-06-22 20:45:49 +08:00
print_config_flag_test.go initial 2024-06-22 20:45:49 +08:00
remote_build_flag_test.go initial 2024-06-22 20:45:49 +08:00
remote_build_flags.go initial 2024-06-22 20:45:49 +08:00
reset_compiler_wrapper.sh initial 2024-06-22 20:45:49 +08:00
rusage_flag.go initial 2024-06-22 20:45:49 +08:00
rusage_flag_test.go initial 2024-06-22 20:45:49 +08:00
sanitizer_flags.go initial 2024-06-22 20:45:49 +08:00
sanitizer_flags_test.go initial 2024-06-22 20:45:49 +08:00
stackprotector_flags.go initial 2024-06-22 20:45:49 +08:00
stackprotector_flags_test.go initial 2024-06-22 20:45:49 +08:00
sysroot_flag.go initial 2024-06-22 20:45:49 +08:00
sysroot_flag_test.go initial 2024-06-22 20:45:49 +08:00
testutil_test.go initial 2024-06-22 20:45:49 +08:00
thumb_flags.go initial 2024-06-22 20:45:49 +08:00
thumb_flags_test.go initial 2024-06-22 20:45:49 +08:00
unsupported_flags.go initial 2024-06-22 20:45:49 +08:00
unsupported_flags_test.go initial 2024-06-22 20:45:49 +08:00
x64_flags.go initial 2024-06-22 20:45:49 +08:00
x64_flags_test.go initial 2024-06-22 20:45:49 +08:00

README.md

Compiler wrapper

See the comments on the top of main.go. Build is split into 2 steps via separate commands:

  • bundle: copies the sources and the build.py file into a folder.
  • build: builds the actual go binary, assuming it is executed from the folder created by bundle.py.

This allows to copy the sources to a Chrome OS / Android package, including the build script, and then build from there without a dependency on toolchain-utils itself.

Testing Inside the Chroot

To test updates to the wrapper locally:

Run install_compiler_wrapper.sh to install the new wrapper in the chroot:

(chroot) ~/trunk/src/third_party/toolchain-utils/compiler_wrapper/install_compiler_wrapper.sh

Then perform the tests, e.g. build with the new compiler.

Updating the Wrapper for Chrome OS

To update the wrapper for everyone, the new wrapper configuration must be copied into chromiumos-overlay, and new revisions of the gcc and llvm ebuilds must be created.

Copy over sources and build.py to chromiumos-overlay:

(chroot) /mnt/host/source/src/third_party/chromiumos-overlay/sys-devel/llvm/files/update_compiler_wrapper.sh

Rename chromiumos-overlay/sys-devel/llvm/llvm-${VERSION}.ebuild to the next revision number. For example, if the current version is 11.0_pre394483_p20200618-r2:

(chroot) cd ~/trunk/src/third_party/chromiumos-overlay
(chroot) git mv llvm-11.0_pre394483_p20200618-r2.ebuild llvm-11.0_pre394483_p20200618-r3.ebuild

Rename chromiumos-overlay/sys-devel/gcc/gcc-${VERSION}.ebuild to the next revision number. For example, if the current version is 10.2.0-r3:

(chroot) cd ~/trunk/src/third_party/chromiumos-overlay
(chroot) git mv sys-devel/gcc/gcc-10.2.0-r3.ebuild sys-devel/gcc/gcc-10.2.0-r4.ebuild

Commit those changes together with the changes made by update_compiler_wrapper.sh.

The changes can then be reviewed and submitted through the normal process.

Paths

build.py is called by these ebuilds:

  • third_party/chromiumos-overlay/sys-devel/llvm/llvm-*.ebuild
  • third_party/chromiumos-overlay/sys-devel/gcc/gcc-*.ebuild

Generated wrappers are stored here:

  • Sysroot wrapper with ccache: /usr/x86_64-pc-linux-gnu/<arch>/gcc-bin/10.2.0/sysroot_wrapper.hardened.ccache
  • Sysroot wrapper without ccache: /usr/x86_64-pc-linux-gnu/<arch>/gcc-bin/10.2.0/sysroot_wrapper.hardened.noccache
  • Clang host wrapper: /usr/bin/clang_host_wrapper
  • Gcc host wrapper: /usr/x86_64-pc-linux-gnu/gcc-bin/10.2.0/host_wrapper