View previous topic :: View next topic |
Author |
Message |
Wewfus n00b
Joined: 23 Mar 2024 Posts: 7
|
Posted: Thu Jan 23, 2025 5:43 pm Post subject: Modern stage1 install? |
|
|
Hello, I haven't run Gentoo since 2004 or so. I'm back and want to run through a classic "stage 1" install on my new laptop for fun. I found the Catalyst wiki entry after discovering stage1 files aren't provided anymore. It seems doable but I had some further questions before I get started and blow my entire weekend on this.
1) Kernel config
I found this helpful page for my laptop which includes a kernel config: https://wiki.gentoo.org/wiki/User:Holgersson/Lenovo_Thinkpad_T14s_(AMD)_Gen_1
I noticed a lot of things are being built as modules instead of being built-in. Is there any reason for this or did that user just prefer doing it that way? As far as I know this laptop has open drivers and I should be able to build them all in, right? I went with the AMD laptop to avoid the issue I've been having with Nivida workstation for years now.
2) GCC
I plan on using GCC. I know this will require building it multiple times which I don't care about. I'm just wondering if the steps have changed considerably since the old days when stage 1 installs were more common.
3) -bin packages
I'm seeing a lot of binary packages in the default install now. Kernel-bin, Rust-bin, and even Firefox-bin is in repos. There also seems to be a project now to offer all packages at -bin. How bad is something like Rust going to be to compile? Can I do it in 16-20GB of RAM without having to fall back to disk for extra space at compile time? I want to avoid the binary but I don't want to have swap at all. I'd prefer to avoid zswap/zram and friends if I can help it as well.
Why is rust-bin the default even in the default install path? Is it really that much of a time sink to compile it? How often will I be compiling it in normal use? As far as I can tell I only need it for my web browser.
4) "Modern" linux vs. pre-2010s Linux
I've been in *BSD land for over a decade now. Not really by choice. Is there anything else major that's changed since I was away? Why is OpenRC profile pulling in so much systemd stuff? Can I avoid most of systemd with USE flags or am I stuck with shims to have working desktop and input devices?
For what it's worth I plan to have basic X11 powered desktop running something like Openbox and dwm. No log-in manager (log-in from tty). Full disk encryption with detached headers+kernel on USB thumb drive. I'm guessing there is no way to have that without initramfs?
I do appreciate any replies. I'm trying to work my way through docs and posts but it's a lot of information to grok through and a "stage 1" install doesn't seem to be very common anymore. |
|
Back to top |
|
|
pingtoo Veteran
Joined: 10 Sep 2021 Posts: 1430 Location: Richmond Hill, Canada
|
Posted: Thu Jan 23, 2025 7:49 pm Post subject: |
|
|
Wewfus wrote: | plan to have basic X11 powered desktop running something like Openbox and dwm | If that is primary goal I see no reason to do it from stage1.
So for stage1 the real question is do you have to or you just want to. Nothing wrong with wanting to do it, it is fun and I am doing now. but it is unnecessary. I am doing it because I want to have small storage foot print for my catalyst stage4 build and take this chance to learn more about Portage.
if you have something let you to believe you have to, may be you can explain why, so we can see if those reason can be avoid if possible. |
|
Back to top |
|
|
NeddySeagoon Administrator
Joined: 05 Jul 2003 Posts: 54749 Location: 56N 3W
|
Posted: Thu Jan 23, 2025 7:52 pm Post subject: Re: Modern stage1 install? |
|
|
Wewfus,
Wewfus wrote: | Hello, I haven't run Gentoo since 2004 or so. I'm back and want to run through a classic "stage 1" install on my new laptop for fun. I found the Catalyst wiki entry after discovering stage1 files aren't provided anymore. It seems doable but I had some further questions before I get started and blow my entire weekend on this.
1) Kernel config
I found this helpful page for my laptop which includes a kernel config: https://wiki.gentoo.org/wiki/User:Holgersson/Lenovo_Thinkpad_T14s_(AMD)_Gen_1
I noticed a lot of things are being built as modules instead of being built-in. Is there any reason for this or did that user just prefer doing it that way? As far as I know this laptop has open drivers and I should be able to build them all in, right? I went with the AMD laptop to avoid the issue I've been having with Nivida workstation for years now.
|
When a kernel module initalises, be it built as a loadable module or built into the kernel binary, all the things it needs must be available. That includes any firmware it needs to load.
When a module is built in, the firmware must be built it too. When its a loadable module, it loads after root is mounted, so the firmware can be loaded from /lib/firmware. That's the most compelling reason to build things as modules.
A run almost anywhere kernel can be almost fully modular. Its a lot of bloat on disk but unused modules should not be resident. They may load, find nothing to do then exit.
Wewfus wrote: | 2) GCC
I plan on using GCC. I know this will require building it multiple times which I don't care about. I'm just wondering if the steps have changed considerably since the old days when stage 1 installs were more common. |
The GCC build system bootstraps gcc, so every actually builds it three times.
Wewfus wrote: | 3) -bin packages
I'm seeing a lot of binary packages in the default install now. Kernel-bin, Rust-bin, and even Firefox-bin is in repos. There also seems to be a project now to offer all packages at -bin. How bad is something like Rust going to be to compile? Can I do it in 16-20GB of RAM without having to fall back to disk for extra space at compile time? I want to avoid the binary but I don't want to have swap at all. I'd prefer to avoid zswap/zram and friends if I can help it as well. |
Packages with suffix -bin are generally binaries provided by upstream.
Gentoo used a different mechanism for distributing binary packages. That's the BINHOST. To pull in Gentoo provided packages you need to configure the BINHOST then tell emerge to use it, with either the -g or -G option.
16-20G RAM will struggle to build big packages in tmpfs (all in RAM) most things will fit. You can put /var/tmp/portage onto HDD on a package by package basis.
Don't do 'no swap'. It does not stop swapping, it only deprives the kernel of one of mechanisms that in has for swapping.
The kernel will drop the code you would like to execute if it has to, then reload it later. That's swapping too.
Wewfus wrote: | Why is rust-bin the default even in the default install path? Is it really that much of a time sink to compile it? How often will I be compiling it in normal use? As far as I can tell I only need it for my web browser. |
The bootstrap path for rust is very new to gentoo. It used to be that rust was needed to build rust, so you had to start with the -bin.
The rust that you can bootstrap may not be in Gentoo stable yet.
Rust is getting in everywhere now, not just web browsers.
Wewfus wrote: |
4) "Modern" linux vs. pre-2010s Linux
I've been in *BSD land for over a decade now. Not really by choice. Is there anything else major that's changed since I was away? Why is OpenRC profile pulling in so much systemd stuff? Can I avoid most of systemd with USE flags or am I stuck with shims to have working desktop and input devices? |
OpenRC does not pull in much systemd stuff. I think that there are about three small pieces abstracted from systemd. Then elogind, is a rewrite of logind.
I have none of this new fangled stuff. The old way still works.
Wewfus wrote: | For what it's worth I plan to have basic X11 powered desktop running something like Openbox and dwm. No log-in manager (log-in from tty). Full disk encryption with detached headers+kernel on USB thumb drive. I'm guessing there is no way to have that without initramfs? |
I still use startx and I build xorg-server withe the USE=suid option, so it runs as root. That avoids the need to hide the setup things in some other software that must run as root.
You need user space tools to mount the root filesystem, so correct. An initrd is required. However, it can be a kernel module free initrd, so you make it work and leave it alone for the like of the hardware.
Wewfus wrote: | I do appreciate any replies. I'm trying to work my way through docs and posts but it's a lot of information to grok through and a "stage 1" install doesn't seem to be very common anymore. |
_________________ Regards,
NeddySeagoon
Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail. |
|
Back to top |
|
|
bstaletic Guru
Joined: 05 Apr 2014 Posts: 459
|
Posted: Thu Jan 23, 2025 9:07 pm Post subject: |
|
|
I had a long post ready, but I guess I did not click "submit"? Anyway...
For the rust bootstrap, you need USE=mrustc-bootstrap, which is not on by default, might fail on clang and might fail on arm. Testing is appreciated. Also, the USE flag and mrustc are stable-masked.
That said, bootstrapping needs to build mrustc->rust 1.74->rust 1.75->...->rust-latest.
It also needs LLVM 17, LLVM 18 and LLVM 19.
I keep my entire /var/tmp on dist and compiling with LTO, with 4 threads needs up to 12GB as far as I know. I have 8GB RAM and as much swap. Though only gcc, LLVM, clang, rust and firefox end up touching swap.
Not even that, if I am not using the machine, so firefox is not taking up useful RAM.
systemd components that you "can't" avoid are systemd-udev and systemd-tmpfile.
Udev can be replaced with mdev, or even static /dev.
without-systemd overlay has additional alernatives.
Both systemd components are installed through systemd-utils, which is a collection of utilities from the systemd project, but buildable without the rest of the project. |
|
Back to top |
|
|
Wewfus n00b
Joined: 23 Mar 2024 Posts: 7
|
Posted: Thu Jan 23, 2025 9:57 pm Post subject: |
|
|
pingtoo wrote: |
if you have something let you to believe you have to, may be you can explain why, so we can see if those reason can be avoid if possible.
|
I'm doing it because I want to and will make a small stage4 for my "base" system before I build everything to make my desktop/WM work. I'm going to do it regardless if it's suggested or not. I imagine people would be happy to have more new users doing it. Since such users are more likely to help maintain the distro in the future.
NeddySeagoon wrote: |
Don't do 'no swap'. It does not stop swapping, it only deprives the kernel of one of mechanisms that in has for swapping.
The kernel will drop the code you would like to execute if it has to, then reload it later. That's swapping too. |
I've gone without swap file/partition since...2005 I think? It has never been an issue. I don't care if the kernel panics due to running out of RAM. In practice this has never been an issue and I run some fairly heavy workloads. I'd rather not have a partition hanging around eating space for no reason or mucking around with a swap file. If I really need a "swap" I'll just use zram. The only stuff I've ever had to use notmpfs for is Chrome based projects and Rust in my few tests. But those were on a machine with 8GB of RAM. Are you saying 32GB of RAM is not sufficient to compile a desktop profile now? (note: I don't intend on using it. I just assume such profiles will pull in at least one or the other).
Quote: | Rust is getting in everywhere now, not just web browsers. |
What common applications are requiring Rust now aside from Firefox? On my Guix machine that's the only thing that pulls it in that I can see aside from the Gnome display manager and it's running a bunch of other "bloat".
Quote: | I still use startx and I build xorg-server withe the USE=suid option, so it runs as root. That avoids the need to hide the setup things in some other software that must run as root. |
Yes. I planned on avoiding elogind and friends if possible. suid Xorg doesn't scare me and I don't see elogind running as root being anymore secure. I found your threads about this helpful. Thanks a lot.
bstaletic wrote: |
That said, bootstrapping needs to build mrustc->rust 1.74->rust 1.75->...->rust-latest.
It also needs LLVM 17, LLVM 18 and LLVM 19. |
Seems like a lot of trouble just to get Firefox working. Why is the ecosystem like this? How often is a new build required to keep firefox happy?
Quote: |
systemd components that you "can't" avoid are systemd-udev and systemd-tmpfile.
Udev can be replaced with mdev, or even static /dev.
without-systemd overlay has additional alernatives.
Both systemd components are installed through systemd-utils, which is a collection of utilities from the systemd project, but buildable without the rest of the project. |
Is opentmpfiles masked for good or is there any possibility of it coming back to the main tree? When I saw the reason for removing it I noticed the systemd-tmpfile had the exact same bug and it wasn't fixed for a long time. Seems kind of odd that bug was used as justification to remove opentmpfiles when the replacement had the exact same issue.
Thanks for your help. |
|
Back to top |
|
|
Wewfus n00b
Joined: 23 Mar 2024 Posts: 7
|
Posted: Thu Jan 23, 2025 10:10 pm Post subject: |
|
|
Concerning systemd: I don't wish to start an init argument for the 1000th time here. I just wish to avoid as much of it as possible because in time I want to eventually port shepherd over or get s6 up and running (I like the IPC and other aspects of s6). I'm only using OpenRC for now because it's well documented within the Gentoo project and I'd prefer getting kernel+userspace going well before I attempt to tackle managing my own init project with little outside help.
The use case for this system is a personal mobile workstation that only one person will be using. I don't need hibernation (or even suspend to RAM). I don't need seat management. In time I'll probably do what I can to avoid things like dbus all together (or write a emulation layer to make them work with s6's IPC). I'll simply boot the machine if I want to use it and shut down or put it on A/C power if I plan to keep it up for awhile.
I know this isn't the typical way a desktop linux is supposed to be set-up in 2025. But if I wanted a typical linux distro I wouldn't be here in the first place. |
|
Back to top |
|
|
bstaletic Guru
Joined: 05 Apr 2014 Posts: 459
|
Posted: Thu Jan 23, 2025 10:11 pm Post subject: |
|
|
Quote: | I planned on avoiding elogind and friends if possible |
My system does not have elogind and works fine.
Quote: | What common applications are requiring Rust now aside from Firefox? |
ripgrep, but there are alternatives.
Python devs are really liking uv (a new package manager) and ruff (a new static analyzer), both of which are written in rust.
dev-python/cryptography is a python library written in rust, which is a dependency of dev-embedded/esptool
Quote: | Why is the ecosystem like this? |
I don't know. I'm sure rust developers have discussed that at length in other places.
Quote: | How often is a new build required to keep firefox happy? |
Latest firefox requires >=devl-lang/rust-1.77.0, which is about 6 months old.
I'll point out that you only need to bootstrap rust once and then you can get rid of all but latest version,
EDIT:
Forgot to answer about opentmpfiles. I do not expect to see it again in ::gentoo and people that want it need to use an overlay. |
|
Back to top |
|
|
NeddySeagoon Administrator
Joined: 05 Jul 2003 Posts: 54749 Location: 56N 3W
|
Posted: Thu Jan 23, 2025 10:26 pm Post subject: |
|
|
Wewfus,
will tell which packages use rust.
From my install
Code: | $ equery d rust
* These packages depend on rust:
dev-util/cbindgen-0.27.0-r1 (dev-lang/rust:1.84.0)
gnome-base/librsvg-2.58.5 (dev-lang/rust:1.84.0[abi_x86_32(-)?,abi_x86_64(-)?,abi_x86_x32(-)?,abi_mips_n32(-)?,abi_mips_n64(-)?,abi_mips_o32(-)?,abi_s390_32(-)?,abi_s390_64(-)?])
mail-client/thunderbird-128.6.0 (llvm_slot_17 ? dev-lang/rust:1.77.1[llvm_slot_17])
media-libs/gstreamer-1.24.11 (ptp ? dev-lang/rust:1.84.0)
media-libs/libopenraw-0.3.7-r1 (dev-lang/rust:1.77.1)
media-libs/mesa-24.3.3 (opencl ? dev-lang/rust:1.84.0)
(video_cards_nvk ? dev-lang/rust:1.84.0)
sys-apps/cyme-2.1.1 (dev-lang/rust:1.84.0)
sys-block/thin-provisioning-tools-1.0.13-r1 (dev-lang/rust:1.84.0)
sys-devel/gcc-14.2.1_p20241221 (rust ? dev-lang/rust:1.84.0)
www-client/firefox-134.0 (llvm_slot_17 ? dev-lang/rust:1.77.1[llvm_slot_17]) |
A system with 32G RAM will build a desktop system in RAM as long as you keep MAKEOPTS= at 8 or less. It may need to be reduced further for the big packages.
I don't have elogind but it requires some ebuild fettling to remove the from REQUIREDUSE, or I suppose you could add elogind to package.provided to keep portage happy.
I go the ebuild route as there was some discussion about removing package.provided a few years back.
opentmpfiles is masked until a dev is interested enough to fix it and maintain it. That hasn't happened since it was masked. _________________ Regards,
NeddySeagoon
Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail. |
|
Back to top |
|
|
pingtoo Veteran
Joined: 10 Sep 2021 Posts: 1430 Location: Richmond Hill, Canada
|
Posted: Thu Jan 23, 2025 10:56 pm Post subject: |
|
|
Wewfus wrote: | pingtoo wrote: |
if you have something let you to believe you have to, may be you can explain why, so we can see if those reason can be avoid if possible.
|
I'm doing it because I want to and will make a small stage4 for my "base" system before I build everything to make my desktop/WM work. I'm going to do it regardless if it's suggested or not. I imagine people would be happy to have more new users doing it. Since such users are more likely to help maintain the distro in the future. |
So we have similar goal. my goal for stage4 is so I can easy rebuild entire thing on any one of my SBC and my usually practice for Gentoo update is delay as long as I can. so I have static environment I can trust that it will always work.
Quote: | I've gone without swap file/partition since...2005 I think? It has never been an issue. I don't care if the kernel panics due to running out of RAM. In practice this has never been an issue and I run some fairly heavy workloads. I'd rather not have a partition hanging around eating space for no reason or mucking around with a swap file. If I really need a "swap" I'll just use zram. The only stuff I've ever had to use notmpfs for is Chrome based projects and Rust in my few tests. But those were on a machine with 8GB of RAM. Are you saying 32GB of RAM is not sufficient to compile a desktop profile now? (note: I don't intend on using it. I just assume such profiles will pull in at least one or the other). | You could also consider use zswap or both zram/zswap together. |
|
Back to top |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
|