Page 1 of 1

Не парные маркеры.

Posted: Thu May 13, 2010 1:40 pm
by Cyber
Столкнулся с тем во время открытия файла который необходимо защитить, программа выдает сообщение:
найдено 32 не пархных маркеров. Причем все функции которые необходимо защитить перечисленны в окне "процедуры для защиты" правда три из них имеют имена VMProtectMarker1,VMProtectMarker2,VMProtectMarker3

Это вообще нормально?

Re: Не парные маркеры.

Posted: Thu May 13, 2010 2:31 pm
by Admin
Непарные маркеры это ненормально. Могут возникать в том числе и из-за оптимизации кода: http://www.vmpsoft.com/forum/viewtopic.php?f=4&t=216

Re: Не парные маркеры.

Posted: Fri May 14, 2010 6:28 am
by Cyber
Поменял тип оптимизации с Maximum speed to Minimal Size - сообщение о не парных паркерах пропало, но все равно некоторые маркеры не имеют нормального имени, а называются VMProtectMarker1,VMProtectMarker2,VMProtectMarker3. А вот в режиме оптимизации Default все нормально.

В общем в чем искать причину? :)

Re: Не парные маркеры.

Posted: Fri May 14, 2010 6:36 am
by Admin
но все равно некоторые маркеры не имеют нормального имени, а называются VMProtectMarker1,VMProtectMarker2,VMProtectMarker3
Присылайте пример такого файла.

Re: Не парные маркеры.

Posted: Wed May 19, 2010 11:43 am
by Cyber
Присылайте пример такого файла.
Выслал вам файл на info@..

Re: Не парные маркеры.

Posted: Wed May 19, 2010 3:41 pm
by Admin
Непарный маркер возникает из-за оптимизации:

Code: Select all

004035A0 7463                    jz 00403605
004035A2 8B442414                mov eax, [esp+14] 
004035A6 50                      push eax 
004035A7 FFD6                    call esi 
004035A9 55                      push ebp 
004035AA FFD6                    call esi 
004035AC FF15E4804000            call dword ptr [004080E4] -> VMProtectSDK32.VMProtectEnd
004035B2 8BC7                    mov eax, edi 
004035B4 5F                      pop edi 
004035B5 5E                      pop esi 
004035B6 5D                      pop ebp 
004035B7 5B                      pop ebx 
004035B8 83C408                  add esp, 08 
004035BB C3                      ret 
...
-------------- UnpairedVMProtectEnd1 ----------------------
00403657 FF15E4804000            call dword ptr [004080E4] -> VMProtectSDK32.VMProtectEnd
0040365D 8BC7                    mov eax, edi 
0040365F 5F                      pop edi 
00403660 5E                      pop esi 
00403661 5D                      pop ebp 
00403662 5B                      pop ebx 
00403663 83C408                  add esp, 08 
00403666 C3                      ret 
Компилятор развел код на 2 ветки в результате получились 2 VMProtectEnd, второй из которых был признан непарным, т.к. ему не хватает парного VMProtectBegin.

Re: Не парные маркеры.

Posted: Thu May 20, 2010 7:32 am
by Admin
Чтобы отбить желание у оптимизатора разводить окончание функции на 2 ветки (если окончание маркера стоит в конце функции), то для x32 кода можно предложить использовать вот такой маркер окончания блока:

Code: Select all

#define VMProtectEnd2() \
	__asm {nop} \
	VMProtectEnd(); 
Для x64 решение пока не найдено.

Re: Не парные маркеры.

Posted: Thu May 20, 2010 8:38 am
by Cyber
Спасибо за разъяснение.

В общем на данном этапе решением будет отключат оптимизацию т.к нужно поддержка и х64 кода.

А что насчет неправильных имен секций? Это не критично?

Re: Не парные маркеры.

Posted: Thu May 20, 2010 8:46 am
by Admin
А что насчет неправильных имен секций? Это не критично?
С названием маркера ситуация следующая:

Code: Select all

0040347B 68E4A04000              push 0040A0E4 -> ANSI "CTestCoreIface::CTestCoreIface"
00403480 C70788844000            mov dword ptr [edi], 00408488 -> ANSI "p6@"
00403486 895F04                  mov [edi+04], ebx 
00403489 895F08                  mov [edi+08], ebx 
0040348C 895F0C                  mov [edi+0C], ebx 
0040348F 895F10                  mov [edi+10], ebx 
00403492 895F14                  mov [edi+14], ebx 
00403495 895F18                  mov [edi+18], ebx 
00403498 895F1C                  mov [edi+1C], ebx 
0040349B FF15E8804000            call dword ptr [004080E8] <- VMProtectMarker1
VMProtect начинает дизассемблировать код с call dword ptr [004080E8] вверх на дистанцию 20 байт для поиска аргумента для VMProtectBegin. В вашем случае он просто не добегает до push 0040A0E4, т.к. там получается 32 байта. В следующей версии мы увеличим дистанцию для этого алгоритма.

Re: Не парные маркеры.

Posted: Fri May 28, 2010 11:53 am
by Cyber
А когда ориентировочно планирует обновленная версия с иправлением имен секций?

И еще вопрос:
Вы наверное проводили тестирование проиводительности. Насколько мутированный код устпутает в производительности реальному оптимизированному коду?

Re: Не парные маркеры.

Posted: Sat May 29, 2010 2:57 pm
by Admin
А когда ориентировочно планирует обновленная версия с иправлением имен секций?
Буквально сегодня состоялся релиз 2.05, в котором эта проблема исправлена.
Вы наверное проводили тестирование проиводительности. Насколько мутированный код устпутает в производительности реальному оптимизированному коду?
Ориентировочно скорость кода после мутации падает в 10-100 раз.

Re: Не парные маркеры.

Posted: Tue Jun 01, 2010 12:11 pm
by Cyber
Буквально сегодня состоялся релиз 2.05, в котором эта проблема исправлена.
Cпасибо :) все ок.

Еще один вопрос. В настройках проекта есть поле VMExecutorCount=1. Если я использую только мутацию - можно ли сбросить его в 0, чтобы никакого дополнительного кода в exe-шник не прописавалось?

Re: Не парные маркеры.

Posted: Tue Jun 01, 2010 3:06 pm
by Admin
В настройках проекта есть поле VMExecutorCount=1. Если я использую только мутацию - можно ли сбросить его в 0, чтобы никакого дополнительного кода в exe-шник не прописавалось?
Если в проект не включен код, для которого нужна виртуализация, то исполнители ВМ не встраиваются независимо от значения VMExecutorCount. Поэтому нет никакой необходимости обнулять VMExecutorCount на уровне проекта.