Обходы Microsoft — DetourUpdateThread?C++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 Обходы Microsoft — DetourUpdateThread?

Сообщение Anonymous »

У меня есть несколько вопросов о библиотеке Microsoft Detours. Я использовал ее раньше (успешно), но только что подумал об этой функции:
LONG DetourUpdateThread(HANDLE hThread);
Я прочитал в другом месте эта функция фактически приостановит поток до завершения транзакции. Это кажется странным, поскольку большинство вызовов примера кода:
DetourUpdateThread(GetCurrentThread());
В любом случае, очевидно, эта функция «прикрепляет» потоки, так что, когда транзакция фиксируется (и совершаются обходные пути), их указатели инструкций изменяются, если они лежат «внутри переписанного кода либо в целевой функции, либо в функции батута».
Мои вопросы являются:
Когда транзакция фиксируется, будет ли указатель инструкции текущего потока находиться внутри функции DetourTransactionCommit? Если да, то зачем нам привлекать его к обновлению?
Кроме того, если прикрепленные потоки приостановлены, как текущий поток может продолжать выполнение (учитывая, что в большинстве примеров кода вызывается DetourUpdateThread(GetCurrentThread) ());)?
Наконец, не могли бы вы приостановить все потоки текущего процесса, избегая условий гонки (учитывая, что потоки могут создаваться и уничтожаться в любой момент) время)? Возможно, это делается при начале транзакции? Это позволит нам более безопасно перечислять потоки (поскольку создание новых потоков кажется менее вероятным), а как насчет CreateRemoteThread()?
Для справки, вот выдержка из простой пример:
// DllMain function attaches and detaches the TimedSleep detour to the
// Sleep target function. The Sleep target function is referred to
// through the TrueSleep target pointer.
BOOL WINAPI DllMain(HINSTANCE hinst, DWORD dwReason, LPVOID reserved)
{
if (dwReason == DLL_PROCESS_ATTACH) {
DetourTransactionBegin();
DetourUpdateThread(GetCurrentThread());
DetourAttach(&(PVOID&)TrueSleep, TimedSleep);
DetourTransactionCommit();
}
else if (dwReason == DLL_PROCESS_DETACH) {
DetourTransactionBegin();
DetourUpdateThread(GetCurrentThread());
DetourDetach(&(PVOID&)TrueSleep, TimedSleep);
DetourTransactionCommit();
}
return TRUE;
}


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

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Graphql и круговые обходы. Это проблема только приложения iOS?
    Anonymous » » в форуме IOS
    0 Ответы
    11 Просмотры
    Последнее сообщение Anonymous
  • [Microsoft.ML.ITransformer]» и введите «Microsoft.ML.ISingleFeaturePredictionTransformer`1[System.Object]». '
    Anonymous » » в форуме C#
    0 Ответы
    53 Просмотры
    Последнее сообщение Anonymous
  • Что такое эквивалент Microsoft.Practices.Unity ResolverOverride в Microsoft.Extensions.DependencyInjection?
    Anonymous » » в форуме C#
    0 Ответы
    17 Просмотры
    Последнее сообщение Anonymous
  • Что такое эквивалент Microsoft.Practices.Unity ResolverOverride в Microsoft.Extensions.DependencyInjection?
    Anonymous » » в форуме C#
    0 Ответы
    23 Просмотры
    Последнее сообщение Anonymous
  • Возникло несколько проблем после обновления Microsoft.Graph и Microsoft.Graph.Core – ищем замену этих фрагментов кода.
    Anonymous » » в форуме C#
    0 Ответы
    42 Просмотры
    Последнее сообщение Anonymous

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