An implementation of sudo for DOS, to run the given command with full privileges. It can be used to edit important system files, run disk partitioning tools, and so on!

  • Rose@slrpnk.net
    link
    fedilink
    arrow-up
    3
    ·
    13 hours ago

    I actually first thought that was weird and wasteful. Then I remembered that, uh, Commodore 64 often uses a similar thing. Basically, a lot of assembly and compiled languages just put the machine code into the BASIC memory, preceded by a stub BASIC program that’s basically just “10 SYS addr” with that address pointing just past the end of the stub program itself. BASIC’s LOAD command handles it just fine because program files don’t have any header information besides load address. BASIC handles the loaded program just normally because the program has the end token, so as long as you don’t modify the BASIC program, it’ll be fine.

    • sjmulder@lemmy.sdf.orgOP
      link
      fedilink
      English
      arrow-up
      3
      ·
      13 hours ago

      Luckily the .exe’s MZ header is pretty small. But in this case it was necessary: when DOS loads a .com binary, it can’t know how much memory it will need, so DOS just gives it all free memory. But then the program can’t launch another, because all memory is in use. So that’s why I had to add the MZ header which allows specifying the memory needs.