Veranstaltungen

Lecture with integrated exercise

Reverse-Engineering Software Systems

Name in diploma supplementReverse-Engineering Software Systems
Organisational Unit Lehrstuhl für Sichere Software Systeme (https://www.syssec.wiwi.uni-due.de/)
LecturersProf. Dr. Lucas Davi
SPW4LanguageGerman
Cyclewinter semesterParticipants at mostno limit

Preliminary knowledge

Kenntnisse mindestens einer Programmiersprache (Java, C, C++, Python, Rust, …) und Erfahrung in systemnaher Programmierung

Abstract

In dieser Veranstaltung sollen die Studierenden lernen Computerprogramme auf Binärebene (ohne vorhandenen Quellcode) zu analysieren und ggf. die Programmlogik zu ändern. Dabei werden im Vorlesungsteil die notwendigen theoretischen Inhalte vermittelt, welche anschließend im praktischen Teil der Übung angewendet werden sollen. Ein besonderer Fokus liegt dabei auf Intel x86 basierten Systemen auf denen die meisten klassischen Anwendungen lauffähig sind. Zusätzlich werden auch gängige Fehler in Programmen erläutert und analysiert wieso diese für Angriffe ausgenutzt und vermieden werden können. Ziel der Veranstaltung ist es, dass die Studenten ein grundlegendes Verständnis über die Möglichkeiten im Bereich Reverse-Engineering haben und dort bewährte Tools einsetzen können.

Contents

  1. Grundlagen der Prozessorarchitektur
  2. x86 Assembler (32 und 64 Bit Systeme)
  3. Compileroptimierungen
  4. Methoden zur Kontrollfluss- und Datenflussanalyse
  5. Programmfehler erkennen und beheben
  6. Programmobfuskation

Literature

Eldad Eilam, „Reversing: Secrets of Reverse Engineering“, Wiley Verlag

Teaching concept

Präsentationensfolien, Moodle-Kurs, Praktische PC-Labore, schriftliche Hausarbeiten

Participants

  • AI-SE-Ba-2017 > Vertiefungsstudium > Wahlpflichtbereich I: Informatik > (5th-6th Semester, Elective) Modul "Reverse-Engineering Software Systems"
  • SE-Ba-2023 > Wahlpflichtbereich > Wahlpflichtbereich Informatik > Wahlpflichtmodule aus dem Bereich Informatik > (5th-6th Semester, Elective) Modul "Reverse-Engineering Software Systems"
WIWI‑C1152 - Lecture with integrated exercise: Reverse-Engineering Software Systems