User Tools

Site Tools


labs:disassembly

This is an old revision of the document!


Mario Kart Disassembly

In this lab you learn how code and data are represented in memory and how to make low-level changes to a program in an assembly language. You will create modifications (mods) to a game.

Mount your home directory

Use the following commands to connect to your remote home directory:

  • sudo apt install sshfs
  • mkdir tardis-home/
  • sshfs <yournethzlogin>@login.ee.ethz.ch: tardis-home/

Store all your files during this lab in a folder below tardis-home, so it is stored remotely in case your machine crashes.

Exercises

  • 1) Find the correct input to defuse the “bomb”.
  • 2) When you run this program, a pop-up will appear that asks you to pay for a license. Disable this pop-up (or postpone it for a long time).
  • 3) Now, you are ready to hack into SuperTuxKart! The game is installed on your machines. Show us your abilities by modifying the game in cool ways. For instance, make your kart faster, get better items, etc. Before you start modifying the binary, we recommend you to save a backup copy of it so when you break the game, you always have a clean copy. If you prefer, you can also modify a different game.
    Hint: Have a look at the --demangle option of objdump.
  • Text editor: Geany
  • Hex editor: Bless
  • Disassembler: objdump
  • Web assembler/disassembler: https://defuse.ca/online-x86-assembler.htm (Attention: Uses Intel syntax, which has arguments in different order than objdump.)

Hints for SuperTuxKart Modding

labs/disassembly.1490346930.txt.gz · Last modified: 2020/08/31 21:03 (external edit)