77 Commits

Author SHA1 Message Date
71500529c9 spec: restored changelog 2023-02-03 14:25:58 +04:00
e7cda0e8f4 Worked around "bad_elf_symbols" pseudo-error
Moved target GCC libs into a noarch subpackage
2023-02-02 22:44:45 +04:00
a73b457758 la64: avoid idiotic "ERROR: static library violation" 2023-01-31 21:34:04 +04:00
58d0441101 spec: fixed build glibc issues with make 4.4 2023-01-31 21:03:46 +04:00
b25632c9ca spec: set packager to make gyle.alt happy 2023-01-31 19:59:56 +04:00
be7fea1d23 spec: enable gold based on target support 2023-01-31 19:59:39 +04:00
1b6ee0ceab spec: use vendored zlib 2023-01-31 19:58:48 +04:00
bc28a5dc67 spec: remove lib/bfd-plugins
These conflict with native ones and are not particularly
useful (for a cross-toolchain)
2023-01-31 17:38:02 +04:00
f3329910f4 loongarch64: apparently glibc has no libanl 2023-01-31 17:36:59 +04:00
c103bec4bb spec: added target_has_gold flag
Apparently gold does not support neither to riscv nor loongarch
2023-01-31 17:36:21 +04:00
1ade77ca76 cross-toolchain.spec: sync with altcross-2stage.sh 2023-01-30 19:08:59 +04:00
717595bbc6 Added GCC prerequisites (gmp, mpc, mpfr, isl) to repo
Since I store GCC tarball anyway, let's add the prerequisites
too so altcross-2stage.sh does not need internet duing the build
2023-01-29 23:35:21 +04:00
0d282996f0 altcross-2stage.sh: disable -Werror, nls
-Werror causes too many spurious build failures
Building NLS requires cryptic tools
2023-01-29 16:14:21 +04:00
d62998a357 altcross-2stage.sh: apply GCC patches only if present 2023-01-29 16:11:26 +04:00
9de3efe06c binutils: use official tarball
Building from a git snapshot fails due to some missing documentation files,
and apparently there's no way to disable building the docs.
2023-01-29 15:08:30 +04:00
9e785c2c03 gcc: use upstream snapshot 20230128 2023-01-28 20:54:35 +04:00
3f690b308c Use upstream binutils 2.40 2023-01-28 20:37:25 +04:00
d2646c4bea Revert "Downgraded binutils to v20220807"
This reverts commit 07e54665b44d9d37e7a4eaeb9f31312b9c1dccfb
for the downgraded version produces the very same error when
compiling recent (6.2-rc) kernel
2023-01-28 02:43:07 +04:00
2a92904f17 altcross-2stage: use in-tree sources 2023-01-28 02:05:10 +04:00
e8dce540b1 Added Linux sources from kernel.org 6.1 2023-01-28 02:04:03 +04:00
087a18bcc7 Added glibc-2.36 sources from yetist
https://github.com/yetist/glibc/releases/download/v20221009/glibc-2.36-20221009.tar.xz
2023-01-28 02:04:02 +04:00
3d5a2e3868 gcc: do use lib64 2023-01-28 02:04:02 +04:00
c8b0db14cf Added gcc sources from yetist
https://github.com/yetist/gcc/releases/download/v20221025/gcc-12.2.1-20221025.tar.xz
2023-01-28 02:04:01 +04:00
07e54665b4 Downgraded binutils to v20220807 2023-01-28 02:04:01 +04:00
2aed7a8d20 Added binutils sources from yetist
https://github.com/yetist/binutils-gdb/releases/download/v20221009/binutils-2.39-20221009.tar.xz
2023-01-28 02:04:00 +04:00
4cd5948add spec: bits for loongarch64 cross-toolchain
Note: toolchains in sisyphus are too old and don't support
loongarch yet
2022-11-21 16:29:10 +04:00
b034a392ed bye.S: print "bye-bye ..." message
(for now only for aarch64 and armv7)
2022-11-21 16:29:10 +04:00
9519d1f099 altcross-2stage.sh: fixed the smoke test 2022-06-05 23:36:48 +04:00
3fb2681856 20220605-alt1 2022-06-05 19:49:24 +04:00
356b7e47c9 Use 2-stage bootstrap
Apparently GCC 12 needs proper glibc for all-target-libgcc.
In particular libatomic fails to build due to missing/incorrect
definition of MB_LEN_MAX:

make[4]: Entering directory '/usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/obj_gcc/aarch64-linux-gnu/libatomic'
/bin/sh ./libtool  --tag=CC   --mode=compile /usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/obj_gcc/./gcc/xgcc -B/usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/obj_gcc/./gcc/ -B/usr/aarch64-linux-gnu/bin/ -B/usr/aarch64-linux-gnu/lib/ -isystem /usr/aarch64-linux-gnu/include -isystem /usr/aarch64-linux-gnu/sys-include --sysroot=/usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/stage/usr/lib/aarch64-linux-gnu/sys-root -DHAVE_CONFIG_H -I../../../gcc/libatomic/config/linux/aarch64 -I../../../gcc/libatomic/config/posix -I../../../gcc/libatomic -I.  -Wall   -pthread -g -O2 -DN=1  -c -o load_1_.lo ../../../gcc/libatomic/load_n.c
libtool: compile: /usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/obj_gcc/./gcc/xgcc -B/usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/obj_gcc/./gcc/ -B/usr/aarch64-linux-gnu/bin/ -B/usr/aarch64-linux-gnu/lib/ -isystem /usr/aarch64-linux-gnu/include -isystem /usr/aarch64-linux-gnu/sys-include --sysroot=/usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/stage/usr/lib/aarch64-linux-gnu/sys-root -DHAVE_CONFIG_H -I../../../gcc/libatomic/config/linux/aarch64 -I../../../gcc/libatomic/config/posix -I../../../gcc/libatomic -I. -Wall -pthread -g -O2 -DN=1 -c ../../../gcc/libatomic/load_n.c  -fPIC -DPIC -o .libs/load_1_.o
In file included from /usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/stage/usr/lib/aarch64-linux-gnu/sys-root/usr/include/stdlib.h:1035,
                 from ../../../gcc/libatomic/config/linux/aarch64/host-config.h:25,
                 from ../../../gcc/libatomic/libatomic_i.h:232,
                 from ../../../gcc/libatomic/load_n.c:25:
/usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/stage/usr/lib/aarch64-linux-gnu/sys-root/usr/include/bits/stdlib.h:
In function 'wctomb': /usr/src/RPM/BUILD/cross-toolchain-aarch64-linux-gnu-20210831/stage/usr/lib/aarch64-linux-gnu/sys-root/usr/include/bits/stdlib.h:86:3:
error: #error "Assumed value of MB_LEN_MAX wrong"
   86 | # error "Assumed value of MB_LEN_MAX wrong"
      |   ^~~~~
make[4]: *** [Makefile:859: load_1_.lo] Error 1

Therefore use the (slow) 2 stage bootstrap, i.e. build C-only
toolchain without libc, and use that one to cross-compile
the complete target glibc.
2022-06-05 19:49:24 +04:00
7c1209626a .gear/rules: change specsubst variable for local build
To build locally one need to specify the variable in .git/config.
However a git variable name must not contain `_` character.
Use @targetarch@ in specsubst to avoid the problem
2022-06-05 19:49:24 +04:00
4b07931525 altcross.sh: automatically figure out GCC version 2022-06-05 19:49:24 +04:00
8de5f7662d Added cpp-asm source file for aarch64 2022-06-05 19:44:40 +04:00
12166953e9 altcross-2stage: check if newly build compilers work 2022-06-05 17:50:08 +04:00
1d6ac898e2 Added 2-stage build script 2022-06-05 17:36:08 +04:00
d70f2e4163 20211201-alt1
- Added armv7-targeted (arm-linux-gnueabihf) cross-compiler
- Partially merged improvements by iv@
2021-12-01 17:20:29 +04:00
Alexey Sheplyakov
a08867de40 Use specsubst to set target_arch 2021-12-01 17:20:29 +04:00
edbc53246e Added armv7-targeted cross-compiler (arm-linux-gnueabihf) 2021-12-01 17:20:29 +04:00
Alexey Sheplyakov
3149149e63 20210831-alt1
- Fixed build failure due to LTO enforcement
2021-09-03 19:56:39 +04:00
Alexey Sheplyakov
b993013466 Avoid build failure due to inappropriate checks
Recently yet another post-build check has been added:

/usr/bin/strip: Unable to recognise the format of the input file `./usr/lib/aarch64-linux-gnu/sys-root/usr/lib64/libc.a(getutxid.o)'

which (unsurpisingly) broke the build.
Tell strip to ignore the foreign libraries.
2021-09-03 19:56:39 +04:00
Alexey Sheplyakov
c0cfb9ca59 20210804
Avoid hard-coding versions of {gcc,binutils,glibc}-sources so there's no
need to updated the spec whenever GCC, binutils, or glibc gets rebuilt.
2021-08-05 13:32:52 +04:00
Alexey Sheplyakov
b93316f976 Don't hard-code {gcc,glibc,binutils}-source versions 2021-08-05 13:32:52 +04:00
Alexey Sheplyakov
85c770e81e 10.3.1-alt1
Initial build of proper aarch64-targeted GCC toolchain.
2021-07-30 12:37:38 +04:00
Alexey Sheplyakov
e04d5a0bd8 Avoid 'static library packaging violation' pseudo-error 2021-07-30 12:37:38 +04:00
Alexey Sheplyakov
33dd161ab8 Build GCC 10.3 from sisyphus
For now libsanitizer is disabled to avoid bootstrap problems.
2021-07-29 21:41:10 +04:00
Alexey Sheplyakov
143653be0b altcross.sh: repaired broken sed command 2021-07-29 21:12:21 +04:00
Alexey Sheplyakov
dfe065bd30 altcross.sh: disable libsanitizer to avoid build error
libsanitizer wants limits.h, which is a part of compiler. However
the compiler hasn't been installed yet, since we are building its
runtime. Disable libsanitizer to avoid the problem.

TODO: Perhaps there's a special target to build an install compiler
headers only. Figure it out and re-enable libsanitizer.
2021-07-29 21:11:56 +04:00
Alexey Sheplyakov
58d444cced Ignore boring files 2021-07-29 19:58:37 +04:00
Alexey Sheplyakov
6bd130caa8 altcross: don't hard-code versions of sources 2021-07-29 19:55:36 +04:00
Alexey Sheplyakov
1ca8679a31 8.4.1-alt2 2021-06-15 15:00:14 +00:00