Все новости
Это интересно
Сейчас читают
Игры
Аватар Evernews Evernews

Первый Doom смогли взломать и сделать внутри игры «змейку»

2
0
Поделиться
Телеграфировать

Она летает прямо по экрану, поверх монстров и марсианских коридоров.

Первый Doom смогли взломать и сделать внутри игры «змейку»

Разработчик под ником kgsws нашел в коде оригинального Doom эксплойт, позволяющий запускать внутри игры собственный код. Уязвимость, связанная с обработкой сохранений, работает и в первой, и во второй части Doom.

В разговоре с Vice kgsws рассказывает, что решил поискать эксплойт, заинтересовавшись, можно ли добавить в оригинальный Doom что-то новое, не модифицируя саму игру.

Для демонстрации возможностей эксплойта разработчик реализовал в Doom «змейку». Она отрисовывается поверх игры и интерфейса, управление «змейкой» нестандартное: процесс, объясняет kgsws, больше напоминает вождение автомобиля.

Исходники «змейки» и самого эксплойта выложены в открытый доступ. В описании на GitHub разработчик поясняет, что функция игрового движка P_UnArchivePlayers некорректно проверяет состояние спрайта игрока: благодаря этому можно манипулировать структурой данных player_t.

Куча Doom при загрузке аллоцируется в случайном месте памяти, но kgsws выяснил, что отыскать нужные адреса можно благодаря копированию структуры player_t в переменную players[0], местонахождение которой известно. Дальше к нужным местам памяти можно обращаться просто по смещениям.

В итоге разработчик смог создать загрузчик, позволяющий встраивать собственный код в сохранения Doom и Doom 2. Таким образом, уверен kgsws, можно создавать очень продвинутые модификации.

Читать далее
Показали The Witcher 4 — что думаете?
Жду, выглядит интересно
7104 голоса, 60.3%
Трейлер не очень, подожду геймплей
997 голосов, 8.5%
Цири — ведьмачка? Да ну, это шутка
1537 голосов, 13.1%
Больше не доверяю CD Projekt, пусть сначала выйдет
2134 голоса, 18.1%
Теги: Игры, Технологии
Аватар Evernews
Evernews
8074 подписчика