Coder Social home page Coder Social logo

tetros's Introduction

TetrOS

TetrOS is a small feature rich Tetris clone which is written in Assembly. It fits completely into a 512 byte boot sector as it requires only 446 bytes (which is the maximum allowed size of the first stage boot loader in the master boot record (MBR) of a drive) and is executed during the boot sequence before any operating system is loaded. Actually, it does not need any existing operating system. TetrOS is an operating system, hence the suffix OS in its name.

Video that shows TetrOS in action:

TetrOS - Teris in 512 byte boot sector

And this is the complete machine code:

TetrOS - Machine code

Running TetrOS

There are two options to run TetrOS. Either in an emulator like qemu or via an installation of TetrOS in the boot sector of a real disk, USB stick or some other media.

Running via qemu

Simply run make run. This will execute qemu with the right parameters to run TetrOS. If you're using Ubuntu and qemu is not intalled on your system you can install it via sudo apt-get install qemu.

Running via an USB stick

First, copy the image to an USB stick. For example, if your USB stick is on /dev/sde use the following command to overwrite the first sector of the USB stick with the TetrOS image:

sudo dd if=tetros.img of=/dev/sde

After that you should be able to boot the stick to play TetrOS.

Features

  • Each brick shape has a unique color.
  • Blinking cursor is not visible.
  • Left and right arrow to move a brick.
  • Up arrow to rotate a brick.
  • Down arrow to drop a brick.
  • Game over detection. It stops if a new brick could not be placed.
  • Selects the next brick at random via a linear congruential generator.
  • Nice playing field.

Features missing due to size limits

  • Scores and highscores.
  • Intro.
  • Game over message and restart without rebooting.
  • Show next brick.
  • Increase speed.

Compiling the sources

The repository already contains an image which you can use for testing. However, if you want to compile the image from the sources you need nasm, a general prupose x86 assembler to be installed on your system. On Ubuntu you can can install it via the command sudo apt-get install nasm.

If nasm is installed you can compile the sources by executing make. This will create the image tetros.img. After that you can run the image via qemu or you can copy the image via dd on an USB disk or a disk (see above).

I have tested it with nasm 2.11.08 on Ubuntu 16.04.

Similar projects

tetros's People

Contributors

daniel-e avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.