В kernel32.dll существует, казалось бы, бесконечный цикл обратной пересылки.C++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 В kernel32.dll существует, казалось бы, бесконечный цикл обратной пересылки.

Сообщение Anonymous »

Я пишу ручной инжектор карт x86 для Windows 10.
При написании кода, отвечающего за разрешение импорта, я нашел функцию из kernel32.dll (

Код: Выделить всё

windows\syswow64\kernel32.dll
) под названием «SleepConditionVariableSRW», который является пересылкой на «api-ms-win-core-synch-l1-2-0.SleepConditionVariableSRW». DLL, с которой я тестировал свой инжектор, полагается на нее и импортирует ее из kernel32.dll.
Когда я загружаю модуль (из windows\syswow64\downlevel) и посмотрите на экспорт, SleepConditionVariableSRW снова является сервером пересылки, но снова в kernel32.dll. Я бы понял, если бы это была обычная обратная пересылка и набор API пересылался в kernelbase.dll или что-то в этом роде, но для меня это просто не имеет смысла.
Я использую DLL тестирование с импортом функции из kernel32.dll:
Изображение

Код: Выделить всё

kernel32.dll
экспортируем функцию в качестве пересылки в набор API:
Изображение

Набор API экспортирует функцию в качестве пересылки обратно в kernel32.dll, который в первую очередь перенаправляет набор API:
Изображение

Я просмотрел каждую копию этого набора API по всему моему диску и проверил экспорты, чтобы увидеть, не пересылал ли какой-либо из них, даже x64, эту функцию в какой-либо модуль, кроме kernel32.dll. Они этого не сделали.
Я внедрил DLL, которую тестировал, с помощью LoadLibraryA и проверил ссылки на функцию, и она вызывает SleepConditionVariableSRW из базы ядра. .dll. Как загрузчик образа Windows определил, в каком модуле он находится? Я думал, что имя пересылки функции всегда будет содержать правильный модуль для поиска экспорта.

Подробнее здесь: https://stackoverflow.com/questions/790 ... rnel32-dll
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • В kernel32.dll существует, казалось бы, бесконечный цикл обратной пересылки.
    Anonymous » » в форуме C++
    0 Ответы
    22 Просмотры
    Последнее сообщение Anonymous
  • Любая разница между kernel32.dll Sleep и Thread.Sleep()
    Anonymous » » в форуме C#
    0 Ответы
    35 Просмотры
    Последнее сообщение Anonymous
  • Сократить длинное имя файла с помощью kernel32.dll в c#
    Anonymous » » в форуме C#
    0 Ответы
    23 Просмотры
    Последнее сообщение Anonymous
  • GetoverlActResultex не может быть расположен в kernel32.dll .ş [закрыто]
    Anonymous » » в форуме C#
    0 Ответы
    3 Просмотры
    Последнее сообщение Anonymous
  • Как правильно сбежать с обратной чертой, чтобы соответствовать буквальному обратной черте в однокласснических и двойных
    Anonymous » » в форуме Php
    0 Ответы
    13 Просмотры
    Последнее сообщение Anonymous

Вернуться в «C++»