Re: Error crosscompiling 14.0-ALPHA1 on amd64 for arm64.aarch64
- In reply to: Juraj Lutter : "Re: Error crosscompiling 14.0-ALPHA1 on amd64 for arm64.aarch64"
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sun, 13 Aug 2023 22:11:48 UTC
On Aug 13, 2023, at 14:37, Juraj Lutter <otis@FreeBSD.org> wrote: > On 13 Aug 2023, at 23:13, Mark Millard <marklmi@yahoo.com> wrote: >> >> On Aug 13, 2023, at 14:01, Mark Millard <marklmi@yahoo.com> wrote: >> >>> On Aug 13, 2023, at 13:19, Juraj Lutter <otis@freebsd.org> wrote: >>> >>>>> On 13 Aug 2023, at 21:13, Mark Millard <marklmi@yahoo.com> wrote: >>>>> >>>>> But the offical CI builds on amd64 do not have the problem. >>>>> >>>>> We still have not found what is different about your context from the >>>>> standard context used for CI builds and snapshot builds, all of which >>>>> have worked find building on amd64 to target aarch64 with armv7 support. >>>> >>>> My src.conf: >>>> >>>> WITHOUT_PROFILE=yes >>>> WITHOUT_TESTS=yes >>>> WITHOUT_STATIC=yes >>>> >>>> WITHOUT_LLVM_TARGET_ALL=yes >>> >>> Starting below this is wrong presuming all >>> builds are actually done on amd64: >>> >>>> .if "${TARGET}" == "arm64" && "${TARGET_ARCH}" == "aarch64" >>>> KERNCONF?=GENERIC-MMCCAM >>>> REPODIR?=/data/poudriere/packages/pkgbase >>>> MODULES_EXTRA="rpi_ft5406" >>>> WITH_LLVM_TARGET_AARCH64=yes >>>> WITH_LLVM_TARGET_ARM=yes >>>> .else >>>> KERNCONF?=GENERIC-NODEBUG >>>> REPODIR?=/data/poudriere/packages/pkgbase >>>> WITH_LLVM_TARGET_AARCH64=yes >>>> WITH_LLVM_TARGET_X86=yes >>>> .endif >>> >>> Ending here. >>> >>> This is written as if there were separate toolchains for >>> each target. That is not how llvm/clang/lld works, >>> unlike gcc. One toolchain covers all the targets. That >>> is what the FreBSD llvm support is structured for. >>> >>> You want the one llvm/clang/lld toolchain that includes >>> everything required to build any/all of: >>> >>> A) amd64 >>> B) i386 for amd64's lib32 >>> C) aarch64 >>> D) armv7 for aarch64's lib32 >>> >>> So the *_LLVM_TARGET_* parts would be more like: >>> >>> WITHOUT_PROFILE=yes >>> WITHOUT_TESTS=yes >>> WITHOUT_STATIC=yes >>> >>> WITHOUT_LLVM_TARGET_ALL=yes >>> WITH_LLVM_TARGET_AARCH64=yes >>> WITH_LLVM_TARGET_X86=yes >>> WITH_LLVM_TARGET_AARCH64=yes >>> WITH_LLVM_TARGET_ARM=yes >> > > If you look closer, you will see that: > > WITH_LLVM_TARGET_AARCH64=yes Looks like the above was my typing mistake: WITH_LLVM_TARGET_AMD64 ? > WITH_LLVM_TARGET_X86=yes > > is in effect when I do “make buildworld” without any TARGET and TARGET_ARCH, i.e. when I build the OS for the host (that is, 14.0/amd64). WITH_LLVM_TARGET_??? and WITHOUT_LLVM_TARGET_??? control building the LLVM/clang/lld toolchain. What matters is when the llvm/clang/lld materials are built and installed, and when they are used. The way the builds work for building aarch64 and armv7 buildworld and/or buildkernel materials on amd64, the one-and-the-same toolchain is used thus inside one buildworld/buildkernel run: A) some amd64 files are generated that are later poteitnally run by the amd64 system. (So there is amd64 code generation involved.) B) lots of aarch64/armv7 files are generated that are not run by the amd64 system. (So there is aarch64/armv7 code generation involved too.) The same toolchain is used for both (A) and (B) inside one buildworld run. The toolchain has to support all those targets inside the one buildworld/buildkernel run. The whole type of analysis of avoiding having targets you intend to use not being in some of your toolchain builds is just inappropriate for FreeBSD and how it uses LLVM. Prat of the point of LLVM is to avoid having distinct tool chains (or toolchain builds) for different targets of interest. One toolchain is sufficient. You need to quit using the conditional logic for ???_LLVM_TARGET_??? definitions if your builds are going to systematically work. What you are doing is not like what the CI or snapshot build so that work just fine. no FreeBSD documentatino suggests what you are doing. Make things work more like those and things should work just fine. > But once I specify make TARGET=arm64 TARGET_ARCH=aarch64, only the lines: > > WITH_LLVM_TARGET_AARCH64=yes > WITH_LLVM_TARGET_ARM=yes And that is a problem with what you are doing, givne your use of WITHOUT_LLVM_TARGET_ALL=yes . > are in effect. The line “WITH_LLVM_TARGET_ARM=yes” has only been added today for a test, but it did not make any difference. As I would expect. Make sure that all the targets you are going to build for have "WITH_" status all the time in the amd64 build system, not just sometimes. "WITHOUT_" status should only be for targets that you will never use when building via the amd64 build system. === Mark Millard marklmi at yahoo.com