Off-Topic > Off-Topic - Tiny Tux's Corner
Cosmos a "Fat Linux Distro"
mocore:
--- Quote from: mocore on December 05, 2023, 10:59:26 AM ---
--- Quote from: CardealRusso on December 05, 2023, 05:45:56 AM ---will a binary compiled on an x86_64 machine work on any other platform, 32bits, arm etc?
--- End quote ---
however https://justine.lol/ape.html mentions emulation ... which i presume is how arm is supported.
--- Quote ---You only use the emulator if you need it.
For example, it's helpful to be able to have cool visualizations of how program execution impacts memory.
It'll be nice to know that any normal PC program we write will "just work" on Raspberry Pi and Apple ARM.
--- End quote ---
--- End quote ---
ftr i found some clarification @ https://github.com/jart/cosmopolitan/issues/73# ARM, POWER PC, etc.
--- Quote from: https://github.com/jart/cosmopolitan/issues/73#issuecomment-787207628 ---Cosmopolitan supports x86_64, i386, ARM, MIPS, Alpha, HP-PA, PowerPC, RISC-V, s390x, and Xtensa
because your Actually Portable Executables will re-exec themselves under qemu automatically if the host architecture isn't x86_64.
--- End quote ---
idk if using qemu is still how other architectures are supported
...
this issue on https://github.com/jart/cosmopolitan/issues/61# Compiling Lua
mentions an interesting property
--- Quote from: https://github.com/jart/cosmopolitan/issues/61#issuecomment-792359199 ---Your Lua interpreter is also a zip file. You can use a tool like InfoZIP to insert Lua scripts into your Lua binary. Such scripts can be launched as follows:
echo 'print(2 + 2)' >hello.lua
zip o/tiny/third_party/lua/lua.com hello.lua
o/tiny/third_party/lua/lua.com zip:hello.lua
4
--- End quote ---
this seams reminiscent of busy box multi call
and make me wander how/if the same trick might work with actually portable awk ?
as this could potentially address one of the points made in "AWK As A Major Systems Programming Language — Revisited" (https://forum.tinycorelinux.net/index.php/topic,25301.msg171413.html#msg171413)
about 'What Awk Lacked'
--- Quote from: AWK As A Major Systems Programming Language — Revisited ---[I can’t believe I didn’t discuss this in the paper, because I was certainly aware of it then!] Lack of any convenient mechanism for adding libraries. When awk is being invoked from a shell file, the shell file can do substitutions or use multiple -f options, but those are mechanisms outside the language, and not very convenient ones. What’s really wanted is something like you get in Python etc., where one little statement up near the top says “arrange for this program to have the xyz library available when it runs.”
--- End quote ---
mocore:
while researching more on this general tangent
more or less along the lines of this
https://old.reddit.com/r/Zig/comments/104zfy7/actually_portable_executable_in_zig/
reddit post
--- Quote from: reddit.com/r/Zig/#@maccam912 ---actually_portable_executable_in_zig
There is a blog post about it being done in Rust, for reference: https://ahgamut.github.io/2022/07/27/ape-rust-example/
My understanding is that this Cosmopolitan project creates its own libc. And there is a cosmopolitan.a library it needs to link with. The blog post above does those things, but being on a mac I still need to cross-compile to linux to make the executable run on all the supported operating systems.
Basically, I'm asking if Zig's cross compile abilities and better interop with C would make any of this easier? I think it would be cool to have a "cosmo" target for zig that would build binaries that work on any of the supported OSs. It also seems like black magic that it can work at all, so I would not be surprised if this was way more complicated than I realize. I myself have very little background on how this actually works so I'm hoping for some insight from the knowledgeable people here.
--- End quote ---
+WRT above ~ https://news.ycombinator.com/item?id=34373392 interesting comment
...i happened to find some vaguely on topic ( with selective filtering :P )
https://gavinhoward.com/2021/09/comments-on-cosmopolitan-and-culture/
along the lines of lacking ' need to re-invent'
--- Quote from: nick65go on December 05, 2023, 07:52:31 AM ---Anyway, I deviated from the subject, just to explain that today we do NOT need to re-invent the wheel.
--- End quote ---
tough it is enlightening to find/follow the random "rapid unscheduled? disassembly" threads
https://github.com/jart/cosmopolitan/pull/259#issuecomment-912988914
kind of reminds me of "Bjork Teardown of Sony Trinitron TV" https://forum.tinycorelinux.net/index.php/topic,26612.0.html
nick65go:
The idea behind this universal OS portability is about CPU architecture unification, to build/bypass on common sys-calls.
If we start with the end goal in mind (as we should always see the big picture first before jumping into details) I wonder why such a nice good to have achievement did not get traction world-wide with so many brilliant brains. Maybe because the big majority of developers do paid work (from inside corporations) to develop Linux/MacOS/Windows? And their goals are not aligned, because each of them wants to conquer the world by themself (vanity, or money greed).
Because I can not personally contribute to this project, I stay aside and wish it good luck. In IT era (of easy communication) is strange that high hierarchy Linux leaders are silent about such approach of portability. Maybe A.I. will "unify" all this NIH (not invented here) vanity.
gadget42:
more links of interest(for future reader's convenience):
this forum post:
https://forum.tinycorelinux.net/index.php/topic,6646.msg171883.html#msg171883
mentions:
https://justine.lol/pledge/ and https://justine.lol/make/
which led to:
https://redbean.dev/
and:
https://justine.lol/index.html
and:
https://justine.lol/cosmopolitan/
also, Justine Tunney includes this interesting link as well:
https://opensource.googleblog.com/2017/03/operation-rosehub.html
Navigation
[0] Message Index
[*] Previous page
Go to full version