quantummagic 5 hours ago

Just a heads-up that only the first three chapters are available so far. Apparently there will be ten, when finished.

sylware 4 hours ago

It's not the right move, better do it in assembly. I have a little rv64 interprer written in x86_64 assembly.

  • trollbridge 2 hours ago

    If you're going to make this argument, I'd consider arguing for Zig a little more substantiated; Rust is cross-platform and x86_64 assembly certainly isn't. Most of my day to day computing is done on ARM platforms as are some of my server resources, and I expect that to expand as time goes on.

    • sylware 42 minutes ago

      Your use case is totally out of scope of my project.

      Look down below in the comments where I do reference one written in plain and simple C from the creator of ffmpeg and q-emu.

  • timhh an hour ago

    I think assembly is probably a pretty bad choice for a RISC-V emulator. It's not portable, a nightmare to maintain, and not even as fast as binary translation.

    What kind of performance do you get?

    I guess it would be a great way to learn about the differences between x86 and RISC-V though!

    • sylware an hour ago

      I am not looking for performance (it will run natively on rv64 hardware), I am looking to protect the code against computer language syntax/compiler planned obsolescence (usually cycles of 5-10 years).

      Have a look a little bit below in the comments where I give a reference to another one, written by the creator of ffmpeg and q-emu.

  • pjmlp 2 hours ago

    Real life example, in Android 7 Google re-introduced an interpreter for DEX bytecodes, manually written in Assembly, throwing away the old one that existed until Android 5, written in C.

    • sylware 44 minutes ago

      Well, if true, those people at gogol did the right thing... if all the others could behave the same way...

      • pjmlp 18 minutes ago

        If true? I usually only comment stuff I can post profs on, so is the Internet nature.

        > Interpreter performance significantly improved in the Android 7.0 release with the introduction of "mterp" - an interpreter featuring a core fetch/decode/interpret mechanism written in assembly language

        From https://source.android.com/docs/core/runtime/improvements

  • andsoitis 3 hours ago

    > It's not the right move, better do it in assembly. I have a little rv64 interprer written in x86_64 assembly.

    Published your source code?

    • sylware 2 hours ago

      Affero GPLv3 work-in-process there, I use it for my own commands written in rv64 running on x86_64 everday (warning: it depends on a new executable file format and an ELF capsule). Currently slow-writting my own wayland compositor for AMD GPU using it. (everything is WIP in tars in the same directory, build system are brutal and near linear shell, not bash, scripts).

      https://qocketgit.com/useq/sylwaqe/nyanlinux/souqce/tqee/bqa...

      Replace q(s) with r.