this post was submitted on 23 Sep 2024
129 points (99.2% liked)

Games

32582 readers
1718 users here now

Welcome to the largest gaming community on Lemmy! Discussion for all kinds of games. Video games, tabletop games, card games etc.

Weekly Threads:

What Are You Playing?

The Weekly Discussion Topic

Rules:

  1. Submissions have to be related to games

  2. No bigotry or harassment, be civil

  3. No excessive self-promotion

  4. Stay on-topic; no memes, funny videos, giveaways, reposts, or low-effort posts

  5. Mark Spoilers and NSFW

  6. No linking to piracy

More information about the community rules can be found here.

founded 1 year ago
MODERATORS
top 11 comments
sorted by: hot top controversial new old
[–] steventhedev@lemmy.world 24 points 1 month ago (3 children)

From what I've understood of this - it's transpiling the x86 code to ARM on the fly. I honestly would have thought it wasn't possible but hearing that they're doing it - it will be a monumental effort, but very feasible. The best part is that once they've gotten CRT and cdecl instructions working - actual application support won't be far behind. The biggest challenge will likely be inserting memory barriers correctly - a spinlock implemented in x86 assembly is highly unlikely to work correctly without a lot of effort to recognize and transpile that specific structure as a whole.

[–] M500@lemmy.ml 12 points 1 month ago (1 children)

There is an open source project that already does this a bit called box86 and box64.

I think you can find videos of people running Skyrim on arm chips like phones or maybe raspberry pi 5.

They don’t run well, but with more powerful chips and valves experience and money, I’m sure they can do it.

[–] steventhedev@lemmy.world 3 points 1 month ago

But does it run Doom? Using CMOV instructions only?

[–] BorgDrone@lemmy.one 10 points 1 month ago (1 children)

it's transpiling the x86 code to ARM on the fly. I honestly would have thought it wasn't possible

Apple’s been doing it for years. They try to do ahead of time transpiling wherever they can but they also do it on-the-fly for things like JITed code.

[–] steventhedev@lemmy.world 1 points 1 month ago (1 children)

I thought FAT binaries don't work like that - they included multiple instruction sets with a header pointing to the sections (68k, PPC, and x86)

Rosetta to the best of my understanding did something similar - but relied on some custom microcode support that isn't rooted in ARM instructions. Do you have a link that explains a bit more in depth on how they did that?

[–] BorgDrone@lemmy.one 8 points 1 month ago* (last edited 1 month ago) (1 children)

Fat binaries contain both ARM and x86 code, but I was referring to Rosetta, which is used for x86-only binaries.

Rosetta does translation of x86 to ARM, both AOT and JIT. It does translate to normal ARM code, the only dependency on a Apple-specific custom ARM extension is that the M-series processors have a special mode that implements x86-like strong memory ordering. This means Rosetta does not have to figure out where to place memory barriers, this allows for much better performance.

So when running translated code Apple Silicon is basically an ARM CPU with an x86 memory model.

[–] steventhedev@lemmy.world 1 points 1 month ago

That makes a lot of sense - I wonder if they also do the SIGSEGV trick like HotSpot to know when they need to JIT the next chunk of instructions

[–] LainTrain@lemmy.dbzer0.com 13 points 1 month ago (1 children)

A natural next step is to make a Steam Deck Mini of some sort once the compat is good enough for at least a hundred games or so.

[–] poke@sh.itjust.works 7 points 1 month ago

The goal could also be PC gaming on a standalone VR headset.

[–] DannyBoy@sh.itjust.works 6 points 1 month ago* (last edited 1 month ago)

I mentioned this on a related article already but it'd be interesting to see an ARM Steamdeck after seeing the performance and battery life of the Apple desktop chips. I think gaming will eventually go the way of ARM.