This started as a throwaway metaphor in a blog post, but is now fully runnable: a toy RTOS with preemptive multitasking inside of Super Mario Bros. on the NES.
Essentially, this is:
- A rudimentary preemptive RTOS
- Using an unmodified NES emulator (FCEUX) as the CPU
- "Unmodified" depending on how you define terms
- With emulator save states as the thread contexts- With support for (very basic) mutexes, interrupt masking, and condition variables
- Demonstrated using Super Mario Bros. 1-1 with sections of the map dedicated to various synchronization primitives
There are many simplifications and shortcuts taken (doesn't even have task priorities), and it doesn't map 1:1 to true multithreading (e.g., emulator save states represent the state of the entire machine including RAM, whereas thread contexts represent a much more minimal slice), but I think it's A) pretty interesting and B) a unique visceral explanation of threads.
Comments URL: https://news.ycombinator.com/item?id=44120241
Points: 31
# Comments: 10
Connectez-vous pour ajouter un commentaire
Autres messages de ce groupe

Hi HN,
MCP Defender is an open source desktop app that automatically proxies your MCP traffic in AI apps like Cursor, Claude, Windsurf and VSCode. It then scans all requests and responses betwee

We just launched Leap, an AI developer agent that helps you build and deploy apps with real backends to your own AWS or GCP cloud.
We built it because every AI app builder we tried fell short. T

Article URL: https://pixelogic.app/every-5x5-nonogram
Comments URL: https://ne

Article URL: https://www.mechanize.work/blog/how-to-fully-automate-software-engineering/
Comments U