You can make PS2 games in JavaScript

(jslegenddev.substack.com)

217 points | by tosh 7 hours ago ago

50 comments

  • forgotpwd16 7 minutes ago

    Cool article. AthenaEnv is an alternative follow-up to, also by same dev, Enceladus which uses Lua instead. Besides games they're used, and even more popular for this use case, homebrew apps. Examples being RETROLauncher & POPSLoader for Enceladus, and OSD-XMB for Athena.

  • kamranjon 6 hours ago

    This is pretty incredibly - Fabrice Bellard builds stuff that just has such a wide spread impact - so cool that QuickJS enabled an old system like PS2 to have a bit of a homebrew revival through this AthenaEnv project

    • mschuster91 6 hours ago

      My photoshop skills are near zero, otherwise I'd have long gone and edited xkcd 2347 [1] to say next to the pillar "Something Fabrice Bellard probably implemented while half asleep just to prove he could do it".

      There's a lot of FOSS projects that have something written by him in their dependency chain.

      [1] https://xkcd.com/2347/

      • sandermvanvliet 5 hours ago
        • bigfishrunning 3 hours ago

          Why use an LLM to do something that would take exactly the same amount of time and a lot less energy to just do in something like MS paint?

          • wiseowise an hour ago

            > Why use an LLM to do something that would take exactly the same amount of time and a lot less energy to just do in something like MS paint?

            Can you prove that it'll take same amount of time for someone with

            > My photoshop skills are near zero

            to replicate the same level of quality as the generated image? From the looks of it, LLM managed to generate pixel perfect (or at least similar) font and probably took a fraction of a minute for the author to generate.

            • PostOnce 44 minutes ago

              1] delete the text

              2] select any handwriting font

              3] replace the text

              no one will know the font was changed, no skills required.

              AI is going to utterly cripple people intellectually and motivationally.

              If you can't even do the above ten second process, you may want to make more of an effort before you find yourself utterly fucked and starving.

              • forgotpwd16 24 minutes ago

                >no one will know the font was changed

                You're underestimating the effect typography has.

                >you may want to make more of an effort

                You seriously saying someone should put effort in editing a comic they didn't even cared on editing until they saw someone's comment? And somehow you equate the not putting effort to editing such comic to being fucked and starving?

                AI hate sometimes makes people really lose their mind. Doing pointless random shit like this is a legit AI good application. Something that needs no creativity nor intellect to do. Just time. (And, most certainly, more than 10s.)

          • theultdev 3 hours ago

            I'd like to see metrics on that. But intuitively I'd say AI is faster.

            Basically it's opening the tab and typing your thought vs speed running paint.

            @sandermvanvliet what was the process and how long do you estimate it took you?

            Personally it would take me awhile to find the template, the exact font and get the positioning just right.

            I could make a crude one fast, and I've seen many crude versions of this meme. But matching the font is a bit more work, maybe there's a generator for it, but that's not paint nor do I know where it exists.

            • deaddodo 2 hours ago

              “Speed running paint”? You mean opening the image and dragging a text box over the existing text, changing the font to comic sans, and typing the text?

              There are complicated workflows in Paint, this is not one of them.

              • wiseowise an hour ago

                > comic sans

                It's not comic sans though, you've already failed.

                • fooofw 21 minutes ago

                  Why have you failed though? Is the point to try to deceive people to think that XKCD actually published something else? Why not modify the xkcd one without hinding the fact that you modified it?

                • cluckindan 42 minutes ago

                  Yeah, everyone knows xkcd uses its own font, Humor Sans.

                • deaddodo an hour ago

                  Ok

        • youainti 4 hours ago

          thanks!

      • 0x1ch 4 hours ago

        Looked him up, he quite literally pushed the first commits of QEMU ever. Edit: And was the sole developer until 2007!

        • deaddodo 2 hours ago

          Fabrice’s DNA is infused in the FOSS ecosystem. He’s an avid and prolific developer. FFMpeg, Qemu, libbf, softfp, BPG, jslinux, etc, etc, etc.

        • tombert 2 hours ago

          And ffmpeg. And TinyC. And a bunch of other things. The dude is a legend.

  • Flux159 3 hours ago

    The interesting part here is about AthenaEnv. It looks like it uses QuickJS for the Javascript interpreter and wraps around the native system libraries that the PS2 provides.

    I'm wondering if there's a modern similar project that would allow writing Javascript Canvas games (WebGPU / WebGL) and publishing on Switch/2, PS5, and Xbox.

    From my understanding, they explicitly disallow JITs so you can't just wrap your JS game with Electron / Node Webkit and use V8. I'm not sure if anyone has tried publishing a game using a V8-jitless electron fork - the sdks for consoles are under NDA so there's not really much written about it publicly & most games using Unreal or Unity don't deal with these things themselves.

    PC, Mac, and even mobile are surprisingly easier here because you can just run the JS via electron or in a webview on mobile.

    • JSLegendDev 2 hours ago

      I think the game Cross Code (a game written in JS) was ported to consoles using a pretty complex process.

      Here is a detailed blog post about the topic : https://www.radicalfishgames.com/?p=6892

      • Flux159 an hour ago

        Yeah, I saw the video about that earlier which is what led me to wonder if there was a native JS way now.

        They used Kha in order to port only the console versions, the desktop versions remained JS from my understanding: https://github.com/Kode/Kha which is built on top of Haxe. This works, but it also means not having a single codebase anymore which would be one of the benefits of a JS based system.

        There are other options here - something like using an AOT JS compiler like Porffor, but from my understanding it's never been tested (and would probably be missing a lot of support to get it working - like shimming canvas & providing a WebGPU context that the compiled JS could execute against).

    • _james 2 hours ago

      The official Nintendo 3DS and Wii U SDKs both provided an Electron-like framework that allowed games to be written with web technologies. I seem to recall that it was discontinued at some point before the Switch? The Switch does have a WebKit browser applet that games can call to display web-based content, but it's pretty limited since JIT is disabled like you say. I've only ever seen it used for e-manuals.

  • dinobones 6 hours ago

    Mega cool, I’m curious if there’s a way to burn the ISO to a disc and get this playing on a physical console?

    • tylergetsay 5 hours ago

      Combined with https://github.com/CTurt/FreeDVDBoot, I think it would be possible

    • accrual 5 hours ago

      FreeMcBoot on a memory card + USB flash drive (or internal disk) is a popular option to play on real hardware. Saves wear and tear on the optical drive too.

      • Forgeties79 2 hours ago

        I have sat on a freemcboot mem card for probably 6 years now. I’ll get around to it eventually…

        • accrual an hour ago

          It's a good time! I feel the PS2 is an iconic member of any living room TV setup, especially with an SSD, a couple controllers, and component out. Nice to have for hangouts!

    • bakugo 5 hours ago

      You'd need to hack the console to get it to load a burned disc, but if you can do that, you can also just load it from USB.

      Though I guess you could burn it to a disk anyway purely for the sake of authenticity.

      • SpecialistK 4 hours ago

        USB on the PS2 is limited to 1.0 or 1.1 speeds, so a disc may work better anyway.

        • deaddodo 2 hours ago

          Just to clarify, the difference on the PS2 is:

          * CD: 3.6MB/s

          * DVD: 5-8MB/s

          * USB: 0.8-1.1MB/s

          So the disk would almost definitely be the better option.

          • kcb an hour ago

            Can also use a micro SD adapter through the mem card slot. Generally considered a bit better experience than a USB drive.

    • deadbabe 5 hours ago

      Why use physical disc instead of some optical drive mod

      • hamdingers 5 hours ago

        ODEs aren't common for the PS2 because they already support flash drives, network shares, and (for fats) full size hard drives.

  • saghul an hour ago

    A similar thing, also using QuickJS, but for the Nintendo Switch: https://github.com/TooTallNate/nx.js (I'm not the author).

    • Flux159 an hour ago

      Nice, this is similar to what I was wondering about - it looks like it's pretty limited in capability right now (looks like it only supports canvas2d at the moment: https://nxjs.n8.io/runtime/rendering/canvas), but in theory it would allow you to make a layer to convert WebGPU or WebGL games for Switch (ignoring the huge performance drop going from v8 / jit JS engines to QuickJS).

  • IvanK_net 2 hours ago

    Maybe they could simply make a modern web browser for PS2, where you would simply open a website with the game :)

    • wk_end an hour ago

      Chrome apparently has a minimum memory requirement of 4GB, so you'd need to shrink it down to one-one-hundred-and-twenty-eighth its size to squeeze it into the PS2's 32MB of RAM.

      • cluckindan 40 minutes ago

        Easy peasy, just remove the telemetry.

  • ikamm 5 hours ago

    Already been posted here twice by the dev in the past two months...

    https://news.ycombinator.com/item?id=45436166

    https://news.ycombinator.com/item?id=45778448

    • hombre_fatal 4 hours ago

      What's the point of linking discussions that have one comment each?

      The reason you see @dang link past submissions is so we can read previous interesting discussion, not to shame submissions that got no traction.

  • twosdai 6 hours ago

    Super cool. Thanks for sharing this. I've been looking for something like this for a while.

  • mclau153 6 hours ago

    people will do anything to avoid using .gdscript and Godot....

    • ronsor 6 hours ago

      I like Godot, but you're not getting it running on a PS2.

      • charcircuit 5 hours ago

        gdscript does not do any fancy JIT or AOT compiling. I don't see why you can't get gdscript running fairly easily.

        • wk_end 2 hours ago

          gdscript itself, sure, why not. Porting the entire Godot engine would be a real feat though, especially because of the PS2’s technical limitations.

    • turnsout 6 hours ago

      To be fair, it's not as simple as building in Godot and exporting to PS2.

  • martijnvds 4 hours ago

    IBM PS2?