В 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 пересылался в базу ядра .dll или что-то в этом роде, но для меня это просто не имеет смысла.
Я тестирую dll с импортом функции из kernel32.dll
kernel32.dll экспорт функции в качестве пересылки в набор API
Набор API экспортирует функцию в качестве пересылки обратно в kernel32.dll, которая в первую очередь пересылает в набор API
Я просмотрел каждую копию этого набора API на всем моем диске и проверил экспорты, чтобы увидеть, пересылал ли какой-либо из них, даже x64, эту функцию в какой-либо модуль, кроме kernel32.dll, но они этого не сделали. Я внедрил dll, которую тестировал, с помощью LoadLibraryA, проверил ссылки на функцию, и она вызывает SleepConditionVariableSRW из kernelbase.dll. Как загрузчик изображений Windows определил, в каком модуле она находится? я думал, что имя пересылки функции всегда будет содержать правильный модуль для поиска экспорта.

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

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • В kernel32.dll существует, казалось бы, бесконечный цикл обратной пересылки.
    Anonymous » » в форуме C++
    0 Ответы
    7 Просмотры
    Последнее сообщение 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 Ответы
    12 Просмотры
    Последнее сообщение Anonymous

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