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

Читать далее
Какую из этих игр вы будете проходить в первую очередь?
Civilization VII
107 голосов, 12.7%
Kingdom Come Deliverance II
462 голоса, 54.8%
Assassins Creed Shadows
166 голосов, 19.7%
Monster Hunter Wilds
35 голосов, 4.2%
Avowed
47 голосов, 5.6%
Like a Dragon: Pirate Yakuza in Hawaii
26 голосов, 3.1%
Теги: Игры, Технологии
Аватар Evernews
Evernews
8067 подписчиков