💾 Archived View for gemini.ctrl-c.club › ~phoebos › logs › kisslinux-2022-10-06.txt captured on 2023-12-28 at 16:57:58.

View Raw

More Information

⬅️ Previous capture (2023-01-29)

-=-=-=-=-=-=-

[2022-10-06T02:21:56Z] <wael[m]> hi
[2022-10-06T04:54:56Z] <testuser[m]> Hi
[2022-10-06T07:09:31Z] <testuser[m]> where did ioraff go
[2022-10-06T07:10:09Z] <testuser[m]> oh he's back
[2022-10-06T07:43:23Z] <wael[m]> did he go inactive?
[2022-10-06T09:09:19Z] <testuser[m]> is using awk forbidden in KISS
[2022-10-06T09:09:39Z] <testuser[m]> pkg manager 
[2022-10-06T09:09:56Z] <testuser[m]> awk '{print $2}' is much faster than while read -r _ f2
[2022-10-06T09:24:51Z] <testuser[m]> https://codeberg.org/kiss-community/kiss/pulls/85/files
[2022-10-06T09:42:10Z] <wael[m]> how fast
[2022-10-06T09:56:41Z] <wael[m]> btw how does line 8 work in the PR? wouldn't it do for example a/manifest b c d e...
[2022-10-06T09:57:26Z] <wael[m]> also you can't do field argument with grep instead?
[2022-10-06T10:06:39Z] <testuser[m]> splitting
[2022-10-06T10:14:57Z] <wael[m]> what
[2022-10-06T10:15:09Z] <wael[m]> yes is it not possible in grep
[2022-10-06T10:42:17Z] <testuser[m]> illiliti: https://codeberg.org/kiss-community/init/commit/bcf5fbf8ab30c95d4c6a407d8afef1d0a50eddd2 ?
[2022-10-06T10:42:21Z] <testuser[m]> was kall useless all along
[2022-10-06T12:23:19Z] <illiliti> yes
[2022-10-06T12:24:02Z] <wael[m]> hi illiliti
[2022-10-06T12:24:48Z] <illiliti> hi
[2022-10-06T12:26:23Z] <illiliti> testuser[m]: i would use awk only as a last resort
[2022-10-06T12:26:46Z] <illiliti> also speed of while read depends on shell
[2022-10-06T12:40:19Z] <testuser[m]> illiliti: any idea why copy_file_range is broken? The manpage says "First support for cross-filesystem copies was introduced in 5.3.  Older kernels will return -EXDEV when cross-filesystem copies are attempted." but im getting EXDEV on 5.19.9+ when copying from btrfs/ext4 to tmpfs
[2022-10-06T12:40:26Z] <testuser[m]> this breaks toybox cp 
[2022-10-06T12:41:23Z] <testuser[m]> reproducible code is in the manpage itself
[2022-10-06T12:46:12Z] <illiliti> hm
[2022-10-06T12:46:17Z] <illiliti> works for me on zfs
[2022-10-06T12:47:24Z] <testuser[m]> yea its per filesystem thing
[2022-10-06T12:47:34Z] <testuser[m]> clarified on #musl
[2022-10-06T12:48:10Z] <testuser[m]> so bad
[2022-10-06T12:49:04Z] <wael[m]> btrfs moment
[2022-10-06T12:50:03Z] <testuser[m]> no
[2022-10-06T12:50:18Z] <wael[m]> what moment is it
[2022-10-06T12:50:25Z] <testuser[m]> linux moment
[2022-10-06T12:50:32Z] <wael[m]> linux moment
[2022-10-06T12:50:33Z] <illiliti> i think toybox should implement proper fallback
[2022-10-06T12:50:59Z] <wael[m]> how am I supposed to continue even trying toybox now if cp can't even cp
[2022-10-06T12:51:16Z] <testuser[m]> its all filesystems moment that are not in (nfs, fuse, cifs, ceph)
[2022-10-06T12:51:22Z] <testuser[m]> grep -r '.copy_file_range = ' fs/
[2022-10-06T12:51:27Z] <testuser[m]> and zfs*
[2022-10-06T13:07:40Z] <testuser[m]> illiliti: btw why do you use zfs? any specific features you require?
[2022-10-06T13:10:28Z] <illiliti> its encryption is faster than luks
[2022-10-06T13:11:28Z] <illiliti> also zfs is the only way to have FDE without lvm
[2022-10-06T13:11:54Z] <illiliti> lvm is crap, i hate it
[2022-10-06T13:15:30Z] <illiliti> that's main reasons. i think i also should mention that i never had data corruption with zfs
[2022-10-06T13:16:05Z] <testuser[m]> sounds good
[2022-10-06T13:16:08Z] <illiliti> unlike luks+<put your in-tree fs>
[2022-10-06T13:17:18Z] <illiliti> yeah that's surprising, any in-tree fs supposed to be more stable, but in fact it isn't
[2022-10-06T15:27:56Z] <wael[m]> TIL about expand(1p)
[2022-10-06T15:27:57Z] <wael[m]> converts tabs to spaces
[2022-10-06T15:31:41Z] <testuser[m]> illiliti: why exactly is it required to temporarily run and kill mdev during boot?
[2022-10-06T15:32:13Z] <testuser[m]> If the service is going to be started anyway
[2022-10-06T15:41:29Z] <illiliti> because service manager would run device manager asynchronously
[2022-10-06T15:42:08Z] <illiliti> which might lead to race condition and broken permissions in /dev and other nasty stuff
[2022-10-06T15:44:02Z] <illiliti> i know this shit looks like a hack
[2022-10-06T15:45:00Z] <illiliti> but since we don't use systemd, where init and service manager are merged, we can't do better
[2022-10-06T15:46:00Z] <illiliti> this could be a less hacky if there were a portable way to passthrough the control of existing process to service manager
[2022-10-06T15:46:11Z] <illiliti> this way we could avoid killing device manager
[2022-10-06T15:47:22Z] <illiliti> to be clear, we can't make this situation better without hardcoding non-portable things
[2022-10-06T15:52:23Z] <testuser[m]> Hmm
[2022-10-06T15:59:04Z] <testuser[m]> Thoughts about switching to s6?
[2022-10-06T16:01:21Z] <wael[m]> Yes
[2022-10-06T16:01:46Z] <wael[m]> its very good excluding the fact it needs skalib and execline
[2022-10-06T16:06:44Z] <testuser[m]> Bruh do u even know what s6 is
[2022-10-06T16:07:01Z] <wael[m]> pretty damn good service manager or something
[2022-10-06T16:08:56Z] <noocsharp> i've been using artix s6 since i moved away from kiss and it's worked fine, barring the fact that many useful things are systemd services
[2022-10-06T16:09:27Z] <testuser[m]> U mean that as an artix packaging thing right
[2022-10-06T16:09:45Z] <testuser[m]> Useful things being systemd
[2022-10-06T16:10:25Z] <wael[m]> artix has packages that are for the init installed in the system, like networkmanager-s6 for example
[2022-10-06T16:10:30Z] <wael[m]> unless you use arch repos ontop of artix's
[2022-10-06T16:10:49Z] <noocsharp> yeah, it's an artix/arch problem not an s6 one
[2022-10-06T16:12:05Z] <testuser[m]> s6 is good for everything nontrivial like dependencies and stuff, but UX is confusing compared to runit 
[2022-10-06T16:12:12Z] <illiliti> s6 is nice, but if we're going to switch, should we keep init agnostic?
[2022-10-06T16:12:30Z] <testuser[m]> Also it's not clunky at all, like with runit if I'd restart a user's runsvdir, all subprocess would just get orphaned or something
[2022-10-06T16:12:38Z] <illiliti> or support s6 as a sole provider?
[2022-10-06T16:12:39Z] <testuser[m]> Maybe busy box bug or something
[2022-10-06T16:13:21Z] <testuser[m]> Things get hackier the more generic you try to make them
[2022-10-06T16:13:30Z] <testuser[m]> Look at dylan's current branch
[2022-10-06T16:14:01Z] <illiliti> yep, hence my question
[2022-10-06T16:14:17Z] <testuser[m]> this approach is better https://github.com/kisslinux/repo/pull/325#issuecomment-913930319
[2022-10-06T16:14:27Z] <testuser[m]> Still won't be plug and play 
[2022-10-06T16:14:29Z] <testuser[m]> but better
[2022-10-06T16:17:39Z] <testuser[m]> s6 as default + modular scripts 
[2022-10-06T16:18:04Z] <testuser[m]> s6 also has a catchall logger so every single service is logged regardless of an explicit logger
[2022-10-06T16:18:06Z] <illiliti> what about service files
[2022-10-06T16:18:18Z] <testuser[m]> they can be mostly reused
[2022-10-06T16:18:24Z] <illiliti> it's a lot of work to make them generic
[2022-10-06T16:18:58Z] <testuser[m]> They're reusable apart from the directory they're put in
[2022-10-06T16:19:18Z] <testuser[m]> like u can sym link run files to s6 "up" file
[2022-10-06T16:20:21Z] <illiliti> what if service need more functionality than just "run and forget"
[2022-10-06T16:20:27Z] <illiliti> e.g dependencies
[2022-10-06T16:26:56Z] <testuser[m]> Then only dependencies part needs to be duplicated, eg in docker it needs cgroups. So the generic launch script can just do `cgroups_mounted || error` and 
[2022-10-06T16:27:19Z] <testuser[m]> deps will be handled by individual sv manager
[2022-10-06T16:27:26Z] <testuser[m]> But this is a problem if sv manager doesn't have that concept
[2022-10-06T16:27:43Z] <illiliti> maybe we should just keep things simple?
[2022-10-06T16:28:13Z] <illiliti> hardcode one provider but keep scripts simple, so user can replace e.g s6 with runit
[2022-10-06T16:28:30Z] <illiliti> no need for configuration, frameworks and stuff
[2022-10-06T16:30:10Z] <illiliti> yes, one would have to fork init for that
[2022-10-06T16:30:38Z] <illiliti> and rewrite it a bit
[2022-10-06T16:32:32Z] <testuser[m]> We can do that minus the forking init part by making it into more functions
[2022-10-06T16:34:45Z] <illiliti> i don't see how it would help
[2022-10-06T16:39:17Z] <testuser[m]> eg u might not want to run hooks in /etc/rc.d, or not run an emergency shell when every command fails because your init system already has a better mechanism for that
[2022-10-06T16:39:26Z] <testuser[m]> or mount /run because your init already does that
[2022-10-06T16:41:52Z] <illiliti> i see
[2022-10-06T16:42:02Z] <testuser[m]> Like I'm running s6 but I can't run rc.shutdown verbatim cuz it not only unmounts swap, but also handles sending of sig term / kill
[2022-10-06T16:42:20Z] <testuser[m]> tho with s6 everything would be rewritten
[2022-10-06T16:42:29Z] <testuser[m]> If it has to be idiomatic
[2022-10-06T16:42:34Z] <illiliti> but still i think that having single provider would be a lot simpler
[2022-10-06T16:42:50Z] <testuser[m]> like a single oneshot for each thing, eg devtmpfs, tmpfs, procfs etc.
[2022-10-06T16:42:51Z] <testuser[m]> But that seems unnecessary
[2022-10-06T16:43:22Z] <testuser[m]> Core stuff should be available before starting services
[2022-10-06T16:44:24Z] <testuser[m]> I mean all we have to do is change stuff like "log Killing everything; { kall 9; }" into `killall() { log "..."; kall ...; }`
[2022-10-06T16:45:44Z] <testuser[m]> I'll make POC tomorrow
[2022-10-06T16:45:44Z] <testuser[m]> For clearing it up
[2022-10-06T16:46:34Z] <illiliti> look what i mean
[2022-10-06T16:46:41Z] <illiliti> single provider(e.g s6) is better since we don't have to maintain all of this agnostic stuff
[2022-10-06T16:46:53Z] <illiliti> that would make init simpler and easier to understand, and it is actually KISS because user can easily fork it and make changes
[2022-10-06T16:47:29Z] <illiliti> direct support for multiple providers is too much complexity
[2022-10-06T16:48:23Z] <illiliti> you would have to be too "generic", that won't be KISS anymore
[2022-10-06T16:51:23Z] <illiliti> with single provider, we only guarantee that init will be simple
[2022-10-06T16:51:32Z] <illiliti> with multiple providers, we need configuration, frameworks, "genericness"
[2022-10-06T16:51:49Z] <illiliti> it's way too complex
[2022-10-06T16:53:23Z] <illiliti> it's also related to device manager, since it has same problem
[2022-10-06T16:55:42Z] <testuser[m]> Yea I agree with you, I'm not pushing for direct support of anything other than the default, just to make "porting" a little easier. Not adding any setup-specific hacks like case $mdev in udev mdev mdevd, or case $init in busybox, runit, s6, sinit, ...
[2022-10-06T16:56:05Z] <testuser[m]> Making init scripts into sort of a library
[2022-10-06T16:56:30Z] <testuser[m]> Only the bare minimum i.e whatever is present in current init, not services or anything
[2022-10-06T16:59:34Z] <wael[m]> testuser: have you taken a look at sysmgr?
[2022-10-06T17:01:55Z] <illiliti> porting is easy if things will be kept simple and hackable
[2022-10-06T17:03:04Z] <wael[m]> dilyn: why is toybox init unable to run /lib/init/rc.boot? if simply says its unable to run
[2022-10-06T17:03:25Z] <illiliti> forking is a perfectly valid approach here
[2022-10-06T17:04:38Z] <illiliti> we can even have default configurations for various inits as branches
[2022-10-06T17:04:52Z] <illiliti> e.g runit branch for runit support and so on
[2022-10-06T17:05:10Z] <illiliti> user just fork baseinit and change branch
[2022-10-06T17:05:37Z] <illiliti> imho this is very kiss approach
[2022-10-06T17:14:56Z] <testuser[m]> Hmm yeah, it allows to be more idiomatic too, according to init in use
[2022-10-06T17:15:08Z] <testuser[m]> init is like 50 lines of shell
[2022-10-06T17:15:17Z] <testuser[m]> i mean the scripts
[2022-10-06T17:24:27Z] <illiliti> yeah that's why configuration doesn't make sense
[2022-10-06T17:24:53Z] <illiliti> kiss is source-based. forking is easy here. we should exploit this
[2022-10-06T17:33:39Z] <testuser[m]> illiliti: then what about device manager udev configs 
[2022-10-06T17:36:02Z] <illiliti> i've changed my mind, as you see
[2022-10-06T17:36:30Z] <illiliti> i no longer think that we should support all possible device manager
[2022-10-06T17:36:50Z] <illiliti> by default - e.g via configuration
[2022-10-06T17:37:18Z] <illiliti> we should switch to mdevd as a sole provider of device manager
[2022-10-06T17:37:20Z] <wael[m]> just support the 'KISS'iest one and go with it
[2022-10-06T17:37:41Z] <wael[m]> mdevd, the one by creator of s6?
[2022-10-06T17:37:48Z] <illiliti> yep
[2022-10-06T17:38:31Z] <wael[m]> if we are going to switch to s6 might as well do the same for mdevd since dependencies
[2022-10-06T17:41:27Z] <illiliti> mdev.conf is simple enough, really. there's no reason to have abstraction over it
[2022-10-06T17:42:27Z] <illiliti> everyone who uses different device manager, can easily convert it to their format
[2022-10-06T17:42:47Z] <wael[m]> I love my smdev
[2022-10-06T17:43:10Z] <illiliti> keep using it
[2022-10-06T17:43:24Z] <testuser[m]> Ye I think we were going too much in the direction of accounting for all possible cases that could exist, not ones that actually do
[2022-10-06T17:43:34Z] <wael[m]> illiliti: why
[2022-10-06T17:45:02Z] <illiliti> what why? smdev is fine as device manager. if you'd like to use it, there's no lock-in
[2022-10-06T17:46:04Z] <wael[m]> fair
[2022-10-06T17:46:53Z] <illiliti> we should just keep things simple, so user can easily fork and switch components of the system
[2022-10-06T17:47:55Z] <illiliti> that's all we should care about. we shouldn't care about emulation, abstraction, configuration and all of this
[2022-10-06T17:51:38Z] <wael[m]> what about the rc.conf that baseinit used to utilize?
[2022-10-06T17:55:22Z] <testuser[m]> What was that even used for lol
[2022-10-06T17:55:55Z] <illiliti> to configure which service manager to use
[2022-10-06T17:56:00Z] <illiliti> we should drop it
[2022-10-06T17:56:22Z] <illiliti> unless it's used for something else
[2022-10-06T17:58:24Z] <testuser[m]> Um that file doesn't seem to be used at all in init -- no `var:-default` or `var:=default ` in scripts
[2022-10-06T18:00:28Z] <illiliti> it's used in master branch
[2022-10-06T18:42:45Z] <testuser[m]> Do kiss alternatives break if file contains ">" in name?
[2022-10-06T18:51:19Z] <illiliti> perhaps
[2022-10-06T18:57:40Z] <testuser[m]> So bad
[2022-10-06T18:57:44Z] <testuser[m]> Shell moment
[2022-10-06T18:58:11Z] <testuser[m]> I think there would be a ton of such bugs
[2022-10-06T19:10:22Z] <ehawkvu> I figured out a solution to the VERSION markers
[2022-10-06T19:11:12Z] <ehawkvu> https://raw.githubusercontent.com/ehawkvu/kiss-personal/master/bin/kiss-echecksum
[2022-10-06T19:24:37Z] <testuser[m]> https://codeberg.org/kiss-community/repo/issues/120
[2022-10-06T19:26:02Z] <illiliti> you're faster than me :)
[2022-10-06T19:33:49Z] <testuser[m]> https://codeberg.org/kiss-community/kiss/issues/87
[2022-10-06T22:35:57Z] <sad_plan> o/
[2022-10-06T22:36:17Z] <sad_plan> what would be the reason for /dev to be busy whenn mounting it on boot?