Модераторы: feodorv, GremlinProg, xvr, Fixin
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Написание пакера. Проблема с аппаратным DEP, Запрет выполнения кода 
V
    Опции темы
Zmaster555
Дата 14.1.2013, 17:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 22
Регистрация: 14.1.2013

Репутация: нет
Всего: нет



Здравствуйте, пишу подобие упаковщика. Ну или если быть точнее, то пока экспериментирую. Итак, все по-порядку:

ImageBase моей программы 0x00400000, создаю по адресу 0x13140000 (только без комментариев насчет этого IB) образ пакуемой программы с инициализацией таблицы импорта и всего прочего. Далее передаю управление точке входа в пакуемую программу, предварительно восстановив регистры и стек. Запускаю, все прекрасно работает. Но я заметил что это работает не на всех компьютерах. Запускаю в отладчике на неработающем компе, дохожу до OEP и вижу что-то типа access violation at oep, данные не могут быть исполнены. Ну после недолгого google-ния пришел к окончательному выводу, что код не дает исполнить аппаратный DEP (у меня на компе процессор поддерживает только программную реализацию). 

Итак вопрос: 

Как мне реализовать все это дело, чтобы DEP не ругался? Ведь другие упаковщики как то это делают. И еще немного не понятно, почему страница по адресу 0x13140000+EP отмечена DEP-ом как не исполняемая?
PM MAIL   Вверх
korian
Дата 15.1.2013, 01:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 651
Регистрация: 8.3.2008
Где: Украина, Харьков

Репутация: 4
Всего: 17



На скока я помню, хотя могу ошибаться (давно это было), там есть code segment и data segment (сюдя же входит и stack и тд).
Так вот, code segment может выполняться, но если любым из способов EIP меняется на data segment срабатывает DEP.
Ну и конечно все шо я написал, косается тока x386 архитектуры. Шо там в других я хз.
Что, и как, и на каких операционках, и куда кладется надо изучать дополнительно под конкретную систему. Ну и соответственно как писать в code segment и как вообще выделить память под это дело.

PM   Вверх
xvr
Дата 15.1.2013, 11:46 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 7046
Регистрация: 28.8.2007
Где: Дублин, Ирландия

Репутация: 40
Всего: 223



  • Заказываете память, куда будете распаковывать, через VirtualAlloc( MEM_COMMIT | MEM_RESERVE)
  • Распаковываете в возвращенную память
  • Делаете на нее VirtualProtect(PAGE_EXECUTE_READ)
  • Запускаете

PM MAIL   Вверх
DarthTon
Дата 17.1.2013, 11:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 106
Регистрация: 7.2.2009

Репутация: 5
Всего: 6



С DEP вас ещё ждут проблемы при обработке Exception'ов, если хендлеры находятся в секции не имеющей флага SEC_IMAGE. 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Системное программирование и WinAPI"
Fixin
GremlinProg
xvr
feodorv
  • Большое количество информации и примеров с использованием функций WinAPI можно найти в MSDN
  • Описание сообщений, уведомлений и примеров с использованием компонент WinAPI (BUTTON, EDIT, STATIC, и т.п.), можно найти в MSDN Control Library
  • Непосредственно, перед созданием новой темы, проверьте заголовок и удостоверьтесь, что он отражает суть обсуждения.
  • После заполнения поля "Название темы", обратите внимание на наличие и содержание панели "А здесь смотрели?", возможно Ваш вопрос уже был решен.
  • Приводите часть кода, в которой предположительно находится проблема или ошибка.
  • Если указываете код, пользуйтесь тегами [code][/code], или их кнопочными аналогами.
  • Если вопрос решен, воспользуйтесь соответствующей ссылкой, расположенной напротив названия темы.
  • Один топик - один вопрос!
  • Перед тем как создать тему - прочтите это .

На данный раздел распространяются Правила форума и Правила раздела С++:Общие вопросы .


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Chipset, Step, Fixin, GremlinProg, xvr. feodorv.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Системное программирование и WinAPI | Следующая тема »


 




[ Время генерации скрипта: 0.0639 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.