Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 1 Sep 2023 16:55:46 +0200
From:      Felix Palmen <zirias@freebsd.org>
To:        ports@freebsd.org, emulation@freebsd.org
Subject:   Re: Building a Linuxulator userland from source
Message-ID:  <d3xyk4axjo2j5xctsoolmfdbq6zk6bs3r6dbhs4dnmfjgvhj6t@zy3fuy2yyt4e>
In-Reply-To: <i3kr2kukjwgw2xvjlzgshwe72bjpnln4lvl7prhk77nelzidm6@2g56zi3ku7ec>
References:  <xcztahm3vu3bjghjqqxuoy2xabyjmyfq22jw6mkaaaqo7wa36s@fdq7dlvpuhlk> <i3kr2kukjwgw2xvjlzgshwe72bjpnln4lvl7prhk77nelzidm6@2g56zi3ku7ec>

next in thread | previous in thread | raw e-mail | index | archive | help

--3va5lxz6bz3eknqi
Content-Type: text/plain; charset=us-ascii
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

* Felix Palmen <zirias@freebsd.org> [20230820 12:35]:
> Just a little update on this [...]

Posting yet another status update because I'm about to reach a
"milestone": I just had the first successful build of ffmpeg. I focused
on ffmpeg because that's a requirement for MakeMKV which I now intend to
use as a first PoC for the new userland. Before proceeding there, doing
test builds now on all supported architectures and FreeBSD versions, so
I'll have to wait quite a while ;)

The new Linux ffmpeg port has almost everything enabled that's in the
default options of the FreeBSD ffmpeg port. I just left out very few
things that seemed *too* complex right now, like e.g. Vulkan.

To get there, I created a total of 150 ports now. Still, test-building
this ffmpeg "only" wants to build 124 ports, probably because of Xorg
libraries, once I noticed I need them, I created ports for *all* of
them.

A selection of what I added:

* Languages: TCL, Python, Perl
* Build systems: autoreconf, cmake, meson, ninja (all usable with their
  standard USES, my new USES adjusts what's needed to do Linux builds)
* Lots of "codec" libs: lame, opus, ogg/vorbis, vpx, x264, x265, ...
* Infrastructure libs like libdrm, libglvnd, alsa, v4l, ...

A first takeaway could be that indeed, this will be kind of yet another
Linux distribution, as mentioned in sceptical responses so far. I still
hope it will be possible to limit the scope, we'd only need ports
providing shared libraries that (closed-source or otherwise not
portable) Linux software would need to run in Linuxulator. That said,
there's probably still a lot missing, like e.g mesa-dri (for games and
similar), gtk3/gtk4/qt5 (for GUI apps that aren't statically linked),
and so on.

On the plus side, a lot of ports could be created by just copying the
original port and doing adjustments, and most of the time, the result
was simpler than the original (e.g. almost all patches could be
dropped). I also removed all port options, still unsure whether they
*might* make sense later, but for a first PoC, they just add unnecessary
complexity.

There were almost no surprising build issues so far (so, I guess
accidentally pulling in things from FreeBSD base really isn't a thing,
at least not when building in poudriere), except for one: It seems a
"relative" rpath (using $ORIGIN) doesn't work. To work around this with
one port using that during build, I had to add some explicit
LD_LIBRARY_PATH.

Cheers, Felix

--=20
 Felix Palmen <zirias@FreeBSD.org>     {private}   felix@palmen-it.de
 -- ports committer --                     {web}  http://palmen-it.de
 {pgp public key}  http://palmen-it.de/pub.txt
 {pgp fingerprint} 6936 13D5 5BBF 4837 B212  3ACC 54AD E006 9879 F231

--3va5lxz6bz3eknqi
Content-Type: application/pgp-signature; name="signature.asc"

-----BEGIN PGP SIGNATURE-----

iNUEABYKAH0WIQRpNhPVW79IN7ISOsxUreAGmHnyMQUCZPH7Y18UgAAAAAAuAChp
c3N1ZXItZnByQG5vdGF0aW9ucy5vcGVucGdwLmZpZnRoaG9yc2VtYW4ubmV0Njkz
NjEzRDU1QkJGNDgzN0IyMTIzQUNDNTRBREUwMDY5ODc5RjIzMQAKCRBUreAGmHny
MTFaAP0W+CHxUWTa6j4LGsuHo5xSj6PS0uQhTX1OpVmvALRingEAmb0rSQ05++ig
1dF6SHKXGRRh1vqNKbxc3IclKGqCnQ0=
=GOlO
-----END PGP SIGNATURE-----

--3va5lxz6bz3eknqi--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?d3xyk4axjo2j5xctsoolmfdbq6zk6bs3r6dbhs4dnmfjgvhj6t>