169 похожих чатов

Вопрос для знающих формат MZ, PE,ELF Известно, что exe может начинаться

с сигнатуры "MZ" или "ZM" (сигнатура ZM по крайней мере была актуальна для DOS).
PE-файл состоит из DOS-stub и PE.

Вопрос: можно ли сделать матрешку, чтобы был не только PE, но и к примеру, отличный от DOS-stub формат исполняемого модуля, к примеру ELF+PE?

12 ответов

9 просмотров

Чтобы запускалось и на UNIX и на windows?

Нет, начало у двух структур абсолютно разное, скрестить их нельзя. Впрочем, как и сделать проверку на то, какой формат нужно подгружать - потому что, опять же, начало структур разное - либо загружаешься с ELF, а в конце будет PE, но тогда PE ты уже не загрузишь, потому что у тебя уже есть ELF, так и наоборот

maplum- Автор вопроса
Rustem B.
Чтобы запускалось и на UNIX и на windows?

Это вряд ли, ELF начинается с подписи ELF

Entusiast
Нет, начало у двух структур абсолютно разное, скре...

Но есть вариант со скриптами (Python). Но тогда лучше сразу всё на скриптах написать

maplum- Автор вопроса
Entusiast
Но есть вариант со скриптами (Python). Но тогда лу...

Не не, задачи делать матрешку или писать скрипты - не стоит. Вопрос - можно ли сделать матрешку, отдельную от PE+DOS

maplum
Это вряд ли, ELF начинается с подписи ELF

Зато в линуксе парсится shebang (#!), а в винде можно посчитать, что это часть инструкции в .com-файле. А PE/ELF нельзя. А, вот как раз это, видимо, выше и запостили.

maplum- Автор вопроса
s54820
Зато в линуксе парсится shebang (#!), а в винде мо...

К .com файлу не прикрутишь PE(( Заголовок должен начинаться или с MZ или с ZM

maplum
К .com файлу не прикрутишь PE(( Заголовок должен ...

Можно распаковывать его рядом с собой и запускать. Но выше по ссылке вариант очень крутой, гораздо лучше.

maplum- Автор вопроса
s54820
Можно распаковывать его рядом с собой и запускать....

Неспортивно. Да, dos и винда сначала запускают .com и если он не найден, то .ехе

maplum
Неспортивно. Да, dos и винда сначала запускают .co...

кстати com вполне может быть обычным PE и винда его запустит как обычно...

Я думаю, так не получится.

Похожие вопросы

Обсуждают сегодня

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Если подытожить: По мнению Розыча и Хемуля и др. - предпочтительно по возможности объявлять в секции имплементации потому-что: 1) Выше скорость компиляции 2) Не замусоривается...
notme
7
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
В дельфе нет никакого коробочного (без установки третьих либ) способа получить CallStack с расшифровкой отладочных символов?
notme
7
Приветики всем!)) Подскажите: есть функция, которая записывает число типа Cardinal в четыре байта, хранимые в TBytes. Можете помочь мне, показав, как должна выглядеть функци...
Моринаро
5
Карта сайта