Почему мой OneTap так лагает?

cpuid inc.
Забаненный
Статус
Оффлайн
Регистрация
6 Авг 2019
Сообщения
1,071
Реакции[?]
760
Поинты[?]
1K
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Привет.

Эта тема скорее всего похожа на codereview, но это не совсем так.
Просто хочу высказать мои предположения на основе наблюдений - "Почему вт лагает?".

Xored string

-----
Вт юзает xorstr как и многие читы.
В основном он юзается для того "усложить" реверс.
Можно привести много аргументов о том что xorstr должен быть максимально быстрый, но при этом чем быстрее и легче его декодить, тем реверсить это все дело будет проще.

В случае лламы это самый блять юзелесс ксор который я когда либо видел, буквально.
Давайте для примера снимем его ксор при помощи cpp online.
Для того же примера возьмём рандомную заксореную строку из ватермарки:

1595947486525.png

И сразу обращаем внимание на xor операцию а.к.а возвести в значение 0x30.
0x30 как вы могли уже догадаться и есть xorkey.

Теперь заходим сюда на любой cpp online сайт и вставляем три строки кода (
Пожалуйста, авторизуйтесь для просмотра ссылки.
):
1595947715000.png

В структуре Xored строка и ключ. Компилируем и запускаем.
1595947836135.png

В итоге наш xored value превращается в legacy mode за 0,5 секунды.
Офк кто-то может поспорить и сказать что "Ну так ты все равно потратил время, находил это, дексорил, етк". Да, согласен, но тут же есть и обратная сторона, таких ксоров в вантапе тысяча если не больше, и дексорить каждый занимает время. В реверсе офк это время не так важно как в игре, но оптимизации от этого не лучше.
Лучшее решение - частично ксорить, т.е ксорить только самые важные участки кода, ибо даже на казалось бы юзелесс функциях все равно есть ксор.

Fowler-Noll-Vo. (FNV1A в нашем случае)

_____
Тут уже немного посложнее.
Не так много читов (из популярных и не очень) юзают fnv1a, причиной тому является затратность вызова и сложность реализации которая отпугивает пастеров.

Обычно вт юзает FNV1A чтобы достать переменную из Source SDK класса.
Пример: Если нетвар m_lifeState равен 0x0 то мы его фиксим через FNV1A.
SS:


К этому +- нет вопросов т.к после того как нетвар найден ot фиксит сразу же и глобальную переменную к которой обращался, но лично я считаю что это глупо в данном случае т.к нетвары найти не проблема.

Совсем другая сторона извращенности лламы: Поиск модуля через FNV1A. (При поиске сигнатуры)
Это просто пиздец, и мало того что ест фпс до пизды, так это еще и может циклично если что-то устарело, плюс это еще и юзелесс т.к можно просто брутнуть название модуля. (Поиск сигнатур всегда приходится на основные модули: client, engine, etc)

Лучшее решение: Да хотя-бы ксорить, да мы получим убыток в фпс, но не будем вызывать кучу оверрайда, или же на крайний случай использовать t1ha hash (sec + fast) /xxhash (fast + ~sec), или же вариант который идеально подходит для замены fnv1a при работе с маленьким объемом данных - Murmur2A.

Тут скорее всего дело в том что мы пытаемся из Unsafe сделать Safe2Use, но опять же некоторые моменты просто юзелесс.

Для примера возьмём GetActiveWeapon:


Почти вся эта строка юзелесс, и так ненужных проверок в вт куча и больше. Конечно если вырезать их то большого прироста вы не получите, но маленький прирост фпс будет обеспечен.

Как бы это ни было странно, но да, тут тоже есть косяки.

Для примера возьмём startup функцию, которая вызывается каждый фрейм т.к внутри находится функция которая отвечает за рендер & обновление ватермаки, и прочего стаффа который требует обновления каждый +- фрейм.

SS:


Данная функция хукается еще на уровне первичных проверок на дебагер и прочее. Опять же в функциях которые вызываются внутри просто тонны ксора.
Несомненно делать такой хук под функцию из d3x9 это умно, но реализация это пиздец, без преувеличений.
В этой же функции вызывается поиск оффсетов & установка хуков, и в этой же функции вызывается первый рендер меню.
Я конечно понимаю что еще многого не знаю о кс разработке, но разве такое по логике исполнения является приемлимым? Да еще и при этом каждый фрейм ненужные проверки, я уже не говорю о том какую нагрузку испытывает процессор если фреймы стакнулись.

В3 тоже не обошелся без добавления мутаций, но так же и v3 много чего было переработано для оптимизации.
По поводу "защиты" - к примеру ллама выучил арифметическое разделение указателей.

Т.е IEngineInterface0 ^ IEngineInterface1 = EngineInterfacePointer;
Тут опять же много можно спорить было это решение юзелесс или нет, но на мой взгляд - реверсер всегда найдет то, за что отвечают эти два значения.

Итог: Почти все проблемы исходят из реализации "Защиты", и её применения везде где только можно. (Исключительно моё мнение которое имеет обоснования)

p.s Офк msvc коверкает исходники до неузнаваемости для оптимизации, но принципы работы остаются все те же.
 
Последнее редактирование:
cpuid inc.
Забаненный
Статус
Оффлайн
Регистрация
6 Авг 2019
Сообщения
1,071
Реакции[?]
760
Поинты[?]
1K
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Кстати чисто для прикола: Фаталити юзает external GetModule32Next чтобы найти модуль в кске, при этом указывает processId 0, а все для того чтобы заюзать при этом FNV1A.
 
Забаненный
Статус
Оффлайн
Регистрация
1 Май 2019
Сообщения
239
Реакции[?]
91
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
не интересно
 
Чел ты...
Забаненный
Статус
Оффлайн
Регистрация
15 Фев 2020
Сообщения
370
Реакции[?]
76
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Забаненный
Статус
Оффлайн
Регистрация
1 Май 2019
Сообщения
239
Реакции[?]
91
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Чел ты...
Забаненный
Статус
Оффлайн
Регистрация
15 Фев 2020
Сообщения
370
Реакции[?]
76
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Забаненный
Статус
Оффлайн
Регистрация
1 Май 2019
Сообщения
239
Реакции[?]
91
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Чел ты...
Забаненный
Статус
Оффлайн
Регистрация
15 Фев 2020
Сообщения
370
Реакции[?]
76
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Забаненный
Статус
Оффлайн
Регистрация
1 Май 2019
Сообщения
239
Реакции[?]
91
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
НЕВЕРЛУЗ=CКИТ=ЛУЗ
Пользователь
Статус
Оффлайн
Регистрация
30 Дек 2018
Сообщения
420
Реакции[?]
107
Поинты[?]
0
Ну уничтожил лламу просто по фактам
 
Забаненный
Статус
Оффлайн
Регистрация
5 Янв 2020
Сообщения
139
Реакции[?]
51
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
cpuid inc.
Забаненный
Статус
Оффлайн
Регистрация
6 Авг 2019
Сообщения
1,071
Реакции[?]
760
Поинты[?]
1K
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
cpuid inc.
Забаненный
Статус
Оффлайн
Регистрация
6 Авг 2019
Сообщения
1,071
Реакции[?]
760
Поинты[?]
1K
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
Сверху Снизу