Все новости
Это интересно
Сейчас читают
Игры
Аватар 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, можно создавать очень продвинутые модификации.

Читать далее
Сколько вы тратите на игры за год?
Больше 100000 рублей
283 голоса, 5.4%
От 50000 до 100000 рублей
183 голоса, 3.5%
От 25000 до 50000 рублей
205 голосов, 3.9%
От 10000 до 25000 рублей
427 голосов, 8.2%
До 10000 рублей
1042 голоса, 19.9%
Нисколько, я пират. Йо-хо-хо!
3087 голосов, 59.1%
Теги: Игры, Технологии
Аватар Evernews
Evernews
8074 подписчика