summaryrefslogtreecommitdiff
path: root/Toolchain
AgeCommit message (Collapse)Author
2020-08-15Travis: Toolchain only depends on headers, not implsBen Wiederhake
When libstdc++ was added in 4977fd22b874fb9d6d089665e36badd03bcde827, just calling 'make install' was the easiest way to install the headers. And the headers are all that is needed for libstdc++ to determine the ABI. Since then, BuildIt.sh was rewritten again and again, and somehow everyone just silently assumed that libstdc++ also depends on libc.a and libm.a, because surely it does? Turns out, it doesn't! This massively reduces the dependencies of libstdc++, hopefully meaning that the Toolchain doesn't need to be rebuilt so often on Travis. Furthermore, the old method of trying to determine the dependency tree with bash/grep/etc. has finally broken anyways: https://travis-ci.com/github/SerenityOS/serenity/builds/179805569#L567 In summary, this should eliminate most of the Toolchain rebuilds on Travis, and therefore make Travis build blazingly fast! :^)
2020-08-15Toolchain: Update README to point to the current build instructionsLuke
This README contains *really* outdated build instructions. Let's put a pointer to the latest build instructions there instead.
2020-08-02Build: Build libstdc++ in parallelBen Wiederhake
2020-08-02Travis: 'configure' is too chatty for CIBen Wiederhake
./configure generates about 3500 lines in a few seconds. Noone will ever read those lines and they make loading the Travis webpage slower. And if there is ever a problem, it will be because the Travis base image changed (which happens only rarely) in a way that interferes with compiling gcc (which is incredibly unlikely), or we update gcc (which happens very rarely) and gcc doesn't like the Travis iamge (which again is incredibly unlikely). In all of these cases, finding the culprit will be self-evident.
2020-07-29Toolchain: Strip cc1Nico Weber
2020-07-29Toolchain: Let's leave cc1 in place for nowAndreas Kling
2020-07-29Meta: Fix shellcheck issues in BuildIt.shBen Wiederhake
2020-07-29Travis: Reduce Toolchain cache item size by 73%Ben Wiederhake
Empirically, every single push or PR has to download *and then upload* about 3.6 GiB of "cache stuff", which takes up about 400 seconds: https://travis-ci.com/github/SerenityOS/serenity/builds/177500795 On every single push/PR! No matter what! Those 3.6 GB consist of: - 3.2 GB Toolchain cache (around 260 MB per compressed item) - 0.4 GB ccache, but is capped at 0.5 GB: https://travis-ci.com/github/BenWiederhake/serenity/builds/177528549 - (And 200 KB for some weird debian package? Dunno.) Investigating in the size, the Toolchain consists mostly of *DEBUG SYMBOLS IN THE COMPILER BINARIES* which comically misses the point. If we ever run into compiler crashes, any stacktrace would be lost anyway as soon as the Travis VM shuts down. Furthermore, Travis will only ever compile Serenity itself, and Serenity forbids C in it's Contribution Guidelines. That's another 20 MB we don't need to cache. Stripping the binaries and deleting the C compiler reduces the uncompressed size from 1200 MB down to 220 MB. The compressed size gets reduced from 260 MB to 70MB. That's a reduction of 73%. It'll take a while until the 'old' toolchains get deleted. I guess it'll take less than a week. From that point onward, the Travis cache will be 1.2 GB, consisting of: - 0.7 GB Toolchain cache - 0.5 GB ccache - (And that weird 200 KB deb file) If network speeds are linear, then this should reduce the "cache network overhead time" from about 400 seconds to about 120 seconds. tl;dr: Strip unnecessary debug infos, delete an unused files, and speed everything up by two minutes. (Both Toolchain cache hits and Toolchain rebuilds!)
2020-07-13Toolchain: Allow building using CMake on macOSStefano Cristiano
2020-06-18Toolchain: Use curl instead of wget (#2574)ร‰rico Nogueira Rolim
- For Linux: curl is already listed as a dependency; - For macOS: curl is pre-installed; - For OpenBSD and FreeBSD: curl is a dependecy of git.
2020-06-05Toolchain: Support building the toolchain with Ninja (#2504)Paul Redmond
This change allows users to use CMAKE_GENERATOR=Ninja ./BuildIt.sh BuildIt.sh assumes the default cmake generator is Make. However, the user may specify CMAKE_GENERATOR=Ninja, for example, to set the default generator. Therefore, instead of calling make to build the LibC target we should call cmake --build to use the correct generated files.
2020-05-29Ports: Fix CMake-based portsPaul Redmond
The SDL port failed to build because the CMake toolchain filed pointed to the old root. Now the toolchain file assumes that the Root is in Build/Root. Additionally, the AK/ and Kernel/ headers need to be installed in the root too.
2020-05-22Build: Add DockerfileYonatan Goldschmidt
2020-05-20Revert "AK: Don't demangle in serenity :("Andreas Kling
This reverts commit 4361a502255e409f04c9325ef73f3cd10f9cafdb.
2020-05-20Revert "LibC: Implement Itanium C++ ABI for static variable guards"Andreas Kling
This reverts commit cdbbe14062ea49f9a9d9b0e5627aba9efd07659a.
2020-05-20Revert "Toolchain: Don't pre-build LibC and LibM, nor pre-install their headers"Andreas Kling
This reverts commit 4e051c6c15f25b58ee67127a9e4bd5e7a8684fea.
2020-05-20Toolchain: Don't pre-build LibC and LibM, nor pre-install their headersAndrew Kaster
We can do away with that shenanigans now that libstdc++ is gone. Also, simplify the toolchain dependency hash calculation to only depend on the toolchain build script(s) and the Patches files we use to modify the toolchain itself.
2020-05-20LibC: Implement Itanium C++ ABI for static variable guardsAndrew Kaster
This is __cxa_guard_acquire, __cxa_guard_release, and __cxa_guard_abort. We put these symbols in a 'fake' libstdc++ to trick gcc into thinking it has libstdc++. These symbols are necessary for C++ programs and not C programs, so, seems file. There's no way to tell gcc that, for example, the standard lib it should use is libc++ or libc. So, this is what we have for now. When threaded code enters a block that is trying to call the constructor for a block-scope static, the compiler will emit calls to these methods to handle the "call_once" nature of block-scope statics. The compiler creates a 64-bit guard variable, which it checks the first byte of to determine if the variable should be intialized or not. If the compiler-generated code reads that byte as a 0, it will call __cxa_guard_acquire to try and be the thread to call the constructor for the static variable. If the first byte is 1, it will assume that the variable's constructor was called, and go on to access it. __cxa_guard_acquire uses one of the 7 implementation defined bytes of the guard variable as an atomic 8 bit variable. To control a state machine that lets each entering thread know if they gained 'initialization rights', someone is working on the varaible, someone is working on the varaible and there's at least one thread waiting for it to be intialized, or if the variable was initialized and it's time to access it. We only store a 1 to the byte the compiler looks at in __cxa_guard_release, and use a futex to handle waiting.
2020-05-20AK: Don't demangle in serenity :(Andrew Kaster
In order to remove libstdc++ completely, we need to give up on their implementation of abi::__cxa_demangle. The demangler logic will actually have to be quite complex, and included in both the kernel and userspace. A definite fixme for the future, to parse the mangled names into real deal names.
2020-05-16Toolchain/Ports: Update to gcc 10.1.0Shannon Booth
2020-05-14Build: Switch to CMake :^)Sergey Bugaev
Closes https://github.com/SerenityOS/serenity/issues/2080
2020-05-11Travis: Fix Cache spamBen Wiederhake
Back in 36ba0a35eecec73c3347c43aeb18f3ea4849117d I thought that Travis would automagically delete theoldest files. Apparently it does not. Note that no dummy changes are needed, because BuildIt.sh lists itself as a dependency for the Toolchain. Hooray for something that works!
2020-05-08Services: Renamed from ServersAndreas Kling
It didn't feel right to have a "DHCPClient" in a "Servers" directory. Rename this to Services to better reflect the type of programs we'll be putting in there.
2020-04-27Toolchain: Don't create repository for patches if not necessaryDevashish
The toolchain builds just fine without the git repository (tested on windows and linux). We can skip setting up the repo and apply the patches directly when we aren't working on the toolchain itself. A flag `--dev` has been added for cases when git repo is needed. Without the flag, regular patch is applied. This significantly improves build times for first time builds.
2020-04-07Toolchain: Make BuildQemu.sh choose the correct ui library when building on OSXOliver Hunt
2020-04-05Toolchain: Fix trailing white space warnings when gcc.patch is appliedBrian Gianforcaro
Noticed the warnings about trailing white space in the patch fly by as I was running Toolchain/BuildIt.sh on a new machine.
2020-03-23Toolchain/Ports: Update gcc to 9.3.0Shannon Booth
Ever closer to C++20! Also fix up some of those pesky "'s
2020-03-21Build: Add FreeBSD support (#1492)BenJilks
2020-03-08Travis: Cache toolchainBen Wiederhake
This should give a significant boost to Travis speeds, because most of the compile time is spent building the toolchain over and over again. However, the toolchain (or libc or libm) changes only rarely, so most rebuilds can skip this step. The hashing has been put into a separate file to keep it as decoupled as possible from BuiltIt.sh.
2020-02-27Toolchain: Add x86_64 cross compiler build scriptJesse Buhagiar
2020-02-21Toolchain: Build demangling into LibC except during toolchain buildAndreas Kling
2020-01-25Toolchain: Fix python build script.Emanuel Sprung
This fixes #995
2020-01-25Toolchain: Fix qemu build script.Emanuel Sprung
2020-01-02Build: add support for building on OpenBSDjoshua stein
This requires gcc8 from ports to build the Toolchain.
2020-01-01Toolchain: Use crtbeginS and crtendS for shared objectsAndrew Kaster
Turns out the reason GCC wasn't as smart about startup code for shared objects as we hoped is because nobody told it to be :D Change the STARTFILE_SPEC and ENDFILE_SPEC in gcc/config/serenity.h to skip crt0.o and to link the S variants of crtbegin and crtend for shared objects. Because we're using the crtbegin and crtend from libgcc, also tell libgcc in libgcc/config.host to compile crtbeginS and crtendS from crtstuff.c.
2019-12-28Toolchain: Fix building binutils on macOS with --enable-sharedStefano Cristiano
2019-12-27Toolchain: Allow building shared objectsAndreas Kling
Here goes a small first step towards dynamic linking.
2019-12-27Build: Allow building serenityOS ext2 root filesystem on macOS hostStefano Cristiano
2019-12-27Toolchain: Statically link serenity cross-compiler on macOS to keep the โ†ตStefano Cristiano
cross-toolchain self contained
2019-12-25Toolchain: Fixup CMake toolchain script to install things in /usrAndreas Kling
Also stop clobbering the host's /usr/local/share for DATAROOTDIR.
2019-12-20Build: get rid of UseIt.shjoshua stein
The build system uses relative paths to the toolchain binaries, so modifying $PATH is no longer necessary, and nothing needs $SERENITY_ROOT anymore.
2019-12-20Toolchain: Use "make install" to install our LibC and LibMAndreas Kling
2019-12-19Toolchain: Redirect git command output to /dev/nullAndreas Kling
Travis is currently failing and whining about the log being too long. It appears to be filling up with output from the git hackery.
2019-12-19Toolchain: Fix outdated MD5 sum of binutils tarballAndreas Kling
2019-12-19Update toolchain to binutils-2.33.1 gcc-9.2.0Philip Herron
Toolchain build makes git repo out of toolchain to allow patching Fix Makefiles to use new libstdc++ Parameterize BuildIt with default TARGET of i686 but arm is experimental
2019-11-25Ports: check for native python3 installation, add build scriptEmanuel Sprung
For python3 cross compilation, a native installation of python3 is needed. This patch adds a build script for python3 to the toolchain and informs the user to run that script if the python port is build and no native python3 with the same major and minor version is being found.
2019-11-11Toolchain: Add QEMU build script and improve documentationEmanuel Sprung
Added a script to build QEMU from source as part of the Toolchain. The script content could be in BuildIt.sh but has been put in a seperate file to make the build optional. Added PATH=$PATH to sudo calls to hand over the Toolchain's PATH setup by UseIt.sh. This enabled the script's to use the QEMU contained in the SerenityOS toolchain. Deleted old documentation in Meta and replaced it by a new documentation in the Toolchain folder.
2019-11-11Toolchain: Fix indentation in BuildIt.sh (#761)Nicolas Van Bossuyt
2019-11-03POSIX compliance: (most) shell scripts converted to generic shellGeorge Pickering
Ports/.port_include.sh, Toolchain/BuildIt.sh, Toolchain/UseIt.sh have been left largely untouched due to use of Bash-exclusive functions and variables such as $BASH_SOURCE, pushd and popd.
2019-09-26Toolchain/BuildIt.sh: Use curl instead of wgetLarkin Nickle
We already use curl for ports, so let's be consistent.