Re: Error crosscompiling 14.0-ALPHA1 on amd64 for arm64.aarch64

From: Mark Millard <marklmi_at_yahoo.com>
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