Open firmwarecostum opened 8 months ago
The simple answer: This is not currently supported. The place you found is not the only one where we expect built binaries to be executable during the build, for example to generate documentation. I think it would be possible to generate one or two binaries for these cases, depending on what is needed (build time, execution time or both), but someone would need to do the work to extend the build system. I personally do not have a compelling reason to.
Which architectures are you building on and for?
The simple answer: This is not currently supported. The place you found is not the only one where we expect built binaries to be executable during the build, for example to generate documentation. I think it would be possible to generate one or two binaries for these cases, depending on what is needed (build time, execution time or both), but someone would need to do the work to extend the build system. I personally do not have a compelling reason to.
Thank you for your reply. for comparison if i see heimdal has the path --with-cross-tools=dir use cross tools in dir
this is the cross tools path in the directory before that i have to build the host
Which architectures are you building on and for?
arch64
just for fun
I meant "what architecture is the binary being built on, and which architecture will it run on" :-)
Is building inside a docker
container an option?
I meant "what architecture is the binary being built on, and which architecture will it run on" :-) Is building inside a
docker
container an option?
I hate docker and I don't use docker. I built varnish using openwrt-sdk and cross-compiled it
@nigoroll @gquintard
with some tricks I can build it in openwrt. i wish varnish could be cross compiled easily
BusyBox v1.36.1 (2023-11-27 07:02:33 UTC) built-in shell (ash)
_______ ________ __
| |.-----.-----.-----.| | | |.----.| |_
| - || _ | -__| || | | || _|| _|
|_______|| __|_____|__|__||________||__| |____|
|__| W I R E L E S S F R E E D O M
-----------------------------------------------------
OpenWrt 23.05.2, r23630-842932a63d
-----------------------------------------------------
root@OpenWrt:~# varnishadm -h
Usage: varnishadm [-h] [-n ident] [-p] [-S secretfile] [-T [address]:port] [-t timeout] [command [...]]
-n is mutually exclusive with -S and -T
root@OpenWrt:~# varnishadm -v
varnishadm: unrecognized option: v
Usage: varnishadm [-h] [-n ident] [-p] [-S secretfile] [-T [address]:port] [-t timeout] [command [...]]
-n is mutually exclusive with -S and -T
root@OpenWrt:~# varnishd -V
varnishd (varnish-7.4.2 revision cd1d10ab53a6f6115b2b4f3b2a1da94c1f749f80)
Copyright (c) 2006 Verdens Gang AS
Copyright (c) 2006-2023 Varnish Software
Copyright 2010-2023 UPLEX - Nils Goroll Systemoptimierung
root@OpenWrt:~#
root@OpenWrt:~#
root@OpenWrt:~#
root@OpenWrt:~#
root@OpenWrt:~#
Very glad to read, it can you share what you did with the class so it can help others in the future please?
The problems with cross compilation are somewhat tricky to solve. We generate some of our sources with programs compiled at build time. In autoconf linguo we rely on $(host_cpu)
artifacts to run on $(build_cpu)
.
In theory one way to solve this would be to distribute sources we generate at build time, but because of how make dependencies work, we'd need a way to skip a dependency from source to generated source (skipping the $(build_cpu)
binaries). But we'd need to litter our makefiles with conditionals like if NOT_CROSS_COMPILING
statements to only build the problematic artifacts when build and host architectures match.
And of course while that would only work from a dist archive, all bets are off if you apply patches that should affect generated sources, which is common with downstream packaging.
One way to cross-compile Varnish is to build it "natively" and then grab from there missing generated sources in your cross build.
Another way is to configure you system to run aarch64 binaries transparently with qemu. It's probably the simplest as you'd set it up once and forget about it, but not the easiest. If you're cross-compiling you probably have a sysroot in place anyway to get the aarch64 dependencies, so in that regard you're probably already halfway there.
Anyway, I'm also interested in @firmwarecostum's solution. We could add something to the wiki for the time being.
Expected Behavior
is there a way to build cross compilation i built it in openwrt
Current Behavior
no
Possible Solution
no
Steps to Reproduce (for bugs)
no
Context
no
Varnish Cache version
varnish-7.4.2
Operating system
openwrt
Source of binary packages used (if any)
https://varnish-cache.org/downloads/varnish-7.4.2.tgz