this post was submitted on 15 Apr 2025
18 points (78.1% liked)

Linux

53705 readers
822 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 6 years ago
MODERATORS
 

Has anybody been able to build a statically linked binary that shows a Vulkan surface? I've put some context around this problem in the video. I understand that the vulkan driver has to be loaded dynamically - so it's more of a question whether a statically built app can reliably load and talk with it. I think it should be possible but haven't actually seen anyone make it work. I'm aware of "static-window9" by Andrew Kelley but sadly it doesn't work any more (at least on my Gentoo machine T_T).

(I'm also aware of AppImages but I don't think they're the "proper" solution to this problem - more like a temporary bandaid - better than Docker but still far from perfect)

top 11 comments
sorted by: hot top controversial new old
[–] bjoern_tantau@swg-empire.de 25 points 2 weeks ago (1 children)
[–] merthyr1831@lemmy.ml 7 points 2 weeks ago (1 children)

You know it's bad when Linux YouTubers are arguing against Linux ports because Proton is just so much more functional for Linux gamers.

[–] UnfortunateShort@lemmy.world 1 points 2 weeks ago

I mean, why support another API if you have already implemented one, right? Pretty sure there is a Flatpak Version of Proton, wo you can somehow bundle it as well

[–] corsicanguppy@lemmy.ca 5 points 2 weeks ago (1 children)

Has anybody been able to build a statically linked binary

The question should by why you'd want to. Careful if your reply is something about 'one binary to work on a very diverse arrangement of library pinnings' because the next question would be 'why would you think that's either achievable or valuable as a goal'; and toss in a 'why try to ship the same binary in several different repos anyway' bonus question.

In short, if your biggest problem is how to build a binary that works everywhere, you have a lot of questions about responsible build/release processes to answer, and they will be embarrassing for you.

[–] maf@szmer.info 2 points 2 weeks ago (1 children)

I think of demoscene, game jams, desktop pets and other sorts of small home-brew software written by & for small groups of people. There is nothing embarrassing about one-off programs. I understand that what you said is just a figure of speech and you don't really think so (and thank you for a well thought comment) but it still makes me kind of sad to see this kind of shaming. It's discouraging people from being creative.

I'd say my bar is already low. A toy GUI program that draws a triangle and plays a sound should work on my friend's machine (with a different set of system libraries) and it shouldn't randomly break when OS update bumps some library version. AFAIK something like that would require a static binary (INTERP is a no-go) and an ability to dlopen stuff at runtime.

Writing software that "just works" shouldn't be as hard as it is.

[–] tiddy@sh.itjust.works 2 points 2 weeks ago

Sounds like flatpaks/appimages with extra steps

Includes all dependencies? ✔️

A single file? ✔️

Independent of host libraries? ✔️

Limited learning curve? ✔️

Not sure how appimages handle it internally, but with flatpaks you can even be storage efficient with layers, whereas 100s of static binaries could contain an awful lot of duplicates.

[–] ReversalHatchery@beehaw.org 5 points 2 weeks ago* (last edited 2 weeks ago)

Rewrite It In Rust ™, and then it'll work everywhere.

joking of course. you still need different builds for glibc and musl

[–] tiddy@sh.itjust.works 5 points 2 weeks ago (1 children)

Can't see why you dislike appimages, sure not 100% size efficient - but for one off binaries youre probably not spending much time optimizing anyways.

Not that you couldnt make an appimage 2.0 solving all your issues, but we'd just be back to that package manager xkcd all over again

[–] maf@szmer.info 4 points 2 weeks ago

Oh, I don't dislike them. I love them actually. I just wish that vulkan drivers loved them as much as I do :P

[–] Ephera@lemmy.ml 4 points 2 weeks ago* (last edited 2 weeks ago)

I have no experience with this, but I figured a Rust library might have tried to solve it (static linking is very much the norm here) and I found that ash can statically link the "Vulkan loader". I don't know, what that actually means, for example whether it would still load libxcb at runtime. Might be worth looking into what they do...

See the "Optional linking" section here for their description: https://crates.io/crates/ash#optional-linking

[–] maf@szmer.info 4 points 2 weeks ago

I'll also add that I'm aware of glibc's stance on dynamic linking from static binaries. I don't buy the whole NSS argument. It's easily solvable by a basic request/response protocol through some local socket. IMO that argument is just a cheap excuse to justify status quo.