!LemuOOvbWqRXodtSsw:nixos.org

NixOS Reproducible Builds

456 Members
Report: https://reproducible.nixos.org Project progress: https://github.com/orgs/NixOS/projects/3098 Servers

You have reached the beginning of time (for this room).


SenderMessageTime
22 Aug 2024
@emilazy:matrix.orgemilyI see15:58:29
@emilazy:matrix.orgemilythat sounds hard15:58:31
@qyliss:fairydust.spaceAlyssa Rossour foot pgo is reproducible15:58:33
@qyliss:fairydust.spaceAlyssa RossBut there's also an option for more complete foot PGO, which we don't use, that is not reproducible.15:58:52
@emilazy:matrix.orgemilyjust run all our PGO profiling on Antithesis 🙃15:58:56
@emilazy:matrix.orgemily
In reply to @emilazy:matrix.org
by having someone record a profile and shipping that as an input, right?
this does work though, right? it seems like a benign kind of blob to me since the optimization decisions "shouldn't" affect the actual behaviour of the program (and because you can always reproduce an ~equivalent blob, a la bootstrap tarballs)
15:59:47
@emilazy:matrix.orgemilyI think Firefox PGO works like that or something?15:59:55
@qyliss:fairydust.spaceAlyssa RossI don't think it's benign at all.16:00:11
@qyliss:fairydust.spaceAlyssa RossIt's not auditable to my knowledge, and compilers are not generally written to be secure against malicious input.16:00:45
@qyliss:fairydust.spaceAlyssa RossFirefox PGO in Nixpkgs profiles during the build.16:00:53
@emilazy:matrix.orgemilygood point re: malicious input. (I don't have any idea of how elaborate the PGO files actually are)16:05:23
@niko:puppygock.gaynyanbinary 🏳️‍⚧️ left the room.17:18:57
@atemu12:matrix.orgAtemuAn idea that sprung to my mind just now is that we could install the pgo files generated during a build into an output which should allow reproducing the binary if it's otherwise deterministic18:53:09
@atemu12:matrix.orgAtemuThough that again hinges on PGO files not having the ability to make the compiler produce arbitrary output18:54:32
23 Aug 2024
@nam3l33ss:matrix.org@nam3l33ss:matrix.org left the room.09:22:00
24 Aug 2024
@h33p:matrix.orgh33p joined the room.10:19:04
@adbjesus:matrix.org@adbjesus:matrix.org left the room.15:53:46
25 Aug 2024
@von.dev:matrix.orgvon.dev joined the room.08:30:41
@ss:someonex.netSomeoneSerge (utc+3) joined the room.23:03:45
26 Aug 2024
@adis:blad.is@adis:blad.is

I found a reproducibility bug yesterday: https://github.com/NixOS/nixpkgs/issues/337209
The kernel version of the builder causes a Python check hook to fail/succeed depending on the uname of the builder.

It's because of platform_release from https://peps.python.org/pep-0508/#environment-markers

Conceptually the fix is pretty easy: We scrub platform_release and platform_version from the environment.
My problem is that I don't even know what to set them to.
We can probably skip platform_version, but platform_release needs to be a valid version number.

02:29:21
@emilazy:matrix.orgemilypin it to something bigger than any current Linux/macOS/etc. kernel release I guess?02:30:44
@emilazy:matrix.orgemilyprobably relatively few stuff will treat the latest kernel and really new ones differently02:30:55
@emilazy:matrix.orgemilyalternatively we could pin it to the lowest we support on all platforms02:31:01
@emilazy:matrix.orgemilyalthough I don't know if anyone has actually decided what we support for Linux lol02:31:08
@adis:blad.is@adis:blad.is
In reply to @emilazy:matrix.org
although I don't know if anyone has actually decided what we support for Linux lol
Using the version of linuxHeaders would make sense there I think
02:31:38
@emilazy:matrix.orgemily sounds reasonable. and for macOS, apple-sdk (when it exists in a few weeks) 02:32:00
@emilazy:matrix.orgemily though actually you want the darwinMinVersion I guess 02:32:15
@emilazy:matrix.orgemilyand for other platforms, ???02:32:22
@adis:blad.is@adis:blad.is
In reply to @emilazy:matrix.org
and for other platforms, ???
I'm inclined to set it to an empty string on those and let the hook fail loudly
02:32:49

Show newer messages


Back to Room ListRoom Version: 6