• ChrysanthemumIndica@discuss.tchncs.de
    link
    fedilink
    English
    arrow-up
    3
    ·
    4 days ago

    I do think the 286 also had an MMU (and a surprising 1GB of virtual memory address space!)

    However, entering and exiting protected mode (the mode where the MMU is useful) was painful on the 286, and I believe it slowed the adoption of those features. You had to reset the CPU to exit the mode!

    The 386 was able to switch modes much easier (and added a virtual legacy 16 bit mode as well), allowing legacy software to be more easily integrated and runnable. Basically, I think it was successful because of “business reasons”, especially in the growing IBM PC compatible market. You could upgrade and still continue to run your legacy business software, but now with the ability to potentially run workstation/server level software as well.

    But I’m probably biased because my first real computer was a 386 AT&T workstation with 4 megabytes of RAM, a real workhorse that I learned a lot on.

    • grue@lemmy.world
      link
      fedilink
      English
      arrow-up
      3
      ·
      4 days ago

      The main thing, as I understand it, is that the 386 supported preemptive multitasking, while the half-baked memory management in the 286 was only good enough to support cooperative multitasking. That was a big deal, and not just for business/workstation/server stuff.

      My first computer was a 286, and while I don’t think I understood virtual memory at the time, I definitely remember it not being able to run a bunch of newer software (notably, Windows… 3.11?) because of fundamental incompatibility, not just lack of speed.

      • ChrysanthemumIndica@discuss.tchncs.de
        link
        fedilink
        English
        arrow-up
        2
        ·
        4 days ago

        I think all the x86 processors support preemptive multitasking, but yes for sure you need a good MMU to really simplify things. The two almost always go hand in hand for good reason!

        The memory management on the 286 was definitely buggier and “lesser” than on the 386, but as I understand it was more than sufficient to run a preemptive OS with virtual memory (Concurrent DOS 286 was just such an OS). The 286 just couldn’t run existing legacy 8086 software in this mode out of the box(only through a software emulation layer), so many people simply used it as a fast 8086 running MS-DOS/Windows.

        The 386 fixed this by making it much easier/safer to use this legacy software in a protected mode environment, so something like Windows 3.x could run both DOS applications and it’s own native 16/32-bit ones at the same time. I’m honestly not sure why you couldn’t run Windows 3.11 on your 286, but I’m pretty sure it could be installed on one in standard mode. (I’ve read that some Compaq machines had an issue with that?) You would have only been able to run native 16-bit windows applications though, no DOS without resetting the system.

        Again, I could be wrong (and would be curious to know if I am)! For context, I’ve worked as a firmware/BIOS engineer in the PC industry for 20 years, and spent most of my teenage years programming in assembly on those systems, and this is all from my direct experience with programming for such things. But also I’m old now and my brain don’t always work good…