Программирование


Ответить в тред Ответить в тред

Check this out!
<<
Назад | Вниз | Каталог | Обновить тред | Автообновление
516 33 199

В этом треде мы изучаем самый компактный и низкоуровневый /asm/ Аноним # OP 24/03/19 Вск 06:07:06 13691801
15431646599080.png (1Кб, 250x200)
250x200
15431646599081.png (25Кб, 799x820)
799x820
15431646599092.png (10Кб, 718x274)
718x274
15431646599093.png (3Кб, 643x337)
643x337
В этом треде мы изучаем самый компактный и низкоуровневый язык Ассемблер и смежную с ним область: Реверс-инженеринга (RE).

Вы пишите на ассемблере или собираетесь начать на нём писать? Программируете микроконтролёры, пишете драйвера для ОС, а то и саму ОС? Вам сюда.
Вы изучаете алгоритмы работы закрытого софта, пишите патчи бинарников? Вам тоже сюда.

Попрошайки с "решите лабу по асме за меня" идут в общий тред, а лучше нахуй.

Книги по RE:
beginners.re - "Reverse Engineering для начинающих"- бесплатная современная книга на русском языке. К прочтению вкатывающимся и прочим ньюфагам обязательна!
Чтобы не палить свой адрес почты, вот прямая ссылка https://beginners.re/f572d396fae9206628714fb2ce00f72e94f2258f/
https://mega.nz/#!Bc9VVAYC!Vk6CFlW6VIoskLNgDKXbsL6FacDQeOKe6LX92wNicKY Нарваха практический курс по дебагингу
https://www.goodreads.com/shelf/show/reverse-engineering - список книг

Сайты по RE:
http://wiki.yobi.be/wiki/Reverse-Engineering
https://www.reddit.com/r/ReverseEngineering/comments/hg0fx/a_modest_proposal_absolutely_no_babies_involved/
http://www.program-transformation.org/Transform/ReengineeringWiki
http://blog.livedoor.jp/blackwingcat/
https://yurichev.com/blog/
http://wiki.xentax.com/index.php/DGTEFF
https://exelab.ru/

Инструменты для RE:
Дизассемблеры:
0) IDA Pro 7.2 когда подберут пароль к архиву
1) IDA Pro 7.0.torrent (x64 only, для XP нужно патчить PE + вылеты)
2) IDA Pro 6.8.torrent
3) IDA Pro 5.0 - бесплатная версия для некоммерческого использования
4) Radare 2 - наконец прикрутили гуй, но по прежнему нужна только клиническим, не умеющим в скачивания торрентов, или пользователям альтернативных ОС
5) Остальное

Все книги и статьи Криса Касперски (R.I.P.)
https://yadi.sk/d/CxzdM1wyea4WP или https://rutracker.org/forum/viewtopic.php?t=5375505
+ https://rutracker.org/forum/viewtopic.php?t=272818

Книги по ассемблеру:
"Архитектура компьютера" Э. Таненбаум
С.В. Зубков: Assembler. Язык неограниченных возможностей.

Сайты по ассемблеру:
Замена почившему wasm.ru- https://wasm.in/
https://www.unknowncheats.me/wiki/Assembly
http://asmworld.ru/
https://software.intel.com/en-us/articles/intel-sdm
http://www.nasm.us/doc/
https://sourceware.org/binutils/docs/as/index.html#Top
https://msdn.microsoft.com/en-us/library/afzk3475.aspx

disassembler.io Дизассемблер онлайн

Для ковыряющих винду и софт под неё, сайты с описанием структур со смещениями и разными версиями оных:
http://msdn.mirt.net/
http://terminus.rewolf.pl/terminus/
http://geoffchappell.com/

Предыдущие
№5 https://arhivach.ng/thread/395971/
№6 тонущий >>1301036 (OP) если кому нужен тред, сами архивируйте, я в следующий добавлю.
Аноним 24/03/19 Вск 11:08:08 13692312
>>1369180 (OP)
Пора бы уже гидру в шапку добавить.
Аноним 24/03/19 Вск 16:57:32 13693893
>>1369231
>добавлять в шапку црушный зонд
Аноним 24/03/19 Вск 17:13:01 13693934
>>1369389
ЦРУшные зонды у тебя в процессоре. А шапку надо обновить.
Аноним 24/03/19 Вск 19:45:58 13694865
Как экспортировать символ на fasm?
Аноним 24/03/19 Вск 19:54:08 13694926
>>1369393
Тащемта по дефолту там прослушивается порт и включена возможность удаленного подключения. Есть в гидре конечно и свои плюсы, как-то легче что-ли первичный анализ бинарника сделать, но для реальной работы она не катит все таки.
Аноним 24/03/19 Вск 19:55:14 13694947
По-моему Сишный компилятор больше инструкций добавляет, а с опцией -O3 вообще мрак получится.
Кто-то поможет объяснить, почему так?
https://godbolt.org/z/zTCRf7
Аноним # OP 24/03/19 Вск 20:25:31 13695178
>>1369231
Ссылку прикрепи ответом на первый пост, добавлю.
24/03/19 Вск 22:39:54 13696029
>>1369180 (OP)
> если кому нужен тред, сами архивируйте
https://arhivach.ng/thread/415252/ (#6)
https://arhivach.ng/thread/437556/ (и этот сразу заодно)

>>1369486
> Как экспортировать символ на fasm?
public internal_name as '_external_name' или просто public name, если переименовывать не нужно.

>>1369494
У тебя в крестах локальная переменная, в Си - глобальная. Во втором случае оно смогло в автоматическую векторизацию (обрабатывает несколько шагов цикла за раз), попробуй собрать с -fno-tree-vectorize, если важен размер кода.
Аноним 24/03/19 Вск 23:11:29 136961310
>>1369492
Откровения школьника в этом ИТТ треде.
Аноним 24/03/19 Вск 23:38:25 136962511
>>1369602
>глобальная
Точно, спасибо.
Аноним 25/03/19 Пнд 01:57:32 136966012
a
Аноним 25/03/19 Пнд 03:07:51 136967713
Аноним 25/03/19 Пнд 04:41:55 136968314
>>1369677
Да, крестовые алгоритмы из стандартной библиотеки лучше оптимизируются, потому что компилятору доступно больше информации. В Си можно так: https://godbolt.org/z/ShqpCI (к сожалению, без const не свернет).
Аноним 25/03/19 Пнд 05:14:13 136968715
>>1369683
Ну, кстати с флагом -fno-tree-vectorize оптимизируется также.
Значит таки лучше на крестах учиться писать для скорости то? Думаю да
Аноним 25/03/19 Пнд 05:48:29 136968816
>>1369687
Да. Но именно на современных крестах, а не на C++98.
Аноним 27/03/19 Срд 21:20:49 137101917
Ебать я даун.
Написал программу, неправильно проверил и сижу ищу ошибку которой не существует.
Как в анекдоте про иностранца, собирающего холодильник, и русских, которые подкидывают ему детальки.

Ладно одной проблемой меньше.

Как в этом прекрасном языке строки вводятся, выводятся? Чот из методички нихрена не понял.
Пните меня хоть в правильное место.
Прерывания какие-то досовские, значения регистров для вызова правильной подпрограммы, вообще охуеть.
Аноним 27/03/19 Срд 22:24:45 137110818
Знающие семпаи-аноны, подскажите, а чисто по-приколу можно на ассемблере игру написать?
Аноним 27/03/19 Срд 23:05:22 137118319
Аноним 28/03/19 Чтв 00:17:31 137120420
image.png (1324Кб, 1280x720)
1280x720
>>1371108
Ну Spacewar! нахерячили же в 62 году. Скорее всего на ассемблере, либо вообще на двоичном запилили (Маловероятно, но возможно).
(Хотя чёрт его знает что было на PDP-1 Вдруг и компилятор чего нибудь высокого. Хотя вряд ли)
Аноним 28/03/19 Чтв 00:18:14 137120521
Аноним 28/03/19 Чтв 01:12:09 137121422
>>1371204
300кк\сек на связи судя по антуражу.
Аноним 28/03/19 Чтв 01:30:02 137121523
>>1371204
если подкрасишься ничего так будешь, учи мейкап
Аноним 28/03/19 Чтв 01:44:10 137121924
Конечно на двоичном! Да чё вы, ещё Никола Тесла игры писал когда электрон гонял по прутику, хули там
Аноним 29/03/19 Птн 15:25:58 137194425
изображение.png (167Кб, 1458x514)
1458x514
Чому краказяблики вылезают?
Аноним 29/03/19 Птн 15:38:41 137194726
>>1371944
тому что ты не достаточно няшный
Аноним 29/03/19 Птн 21:43:33 137209427
>>1371944
Том что выполнение начинается с первой строчки, а у тебя там вместо кода переменная. Утащи ее вниз. И еще тому, что для int 21h/func=9h DX должен указывать на строку, завершенную долларом, а у тебя не указывает и не на строку.
Аноним 30/03/19 Суб 08:48:29 137222528
Аноним 30/03/19 Суб 20:33:34 137244129
Ребят подскажите сколько цыклов процессора идет на выполнение комманд ассемблера таких как mov inc sub div и остальных. Или подскажите где это искать ибо у самого лапки и не нашел.
Аноним 30/03/19 Суб 20:41:58 137244830
>>1372441
>цыклов
Тактов.
>подскажите где это искать
intel manual
Аноним 30/03/19 Суб 21:24:36 137246831
>>1372448
>>1372448
Не ну для 8088 все есть а для рабочих процов + архитектуры нет.
Ну спс хоть за что-то.
тактов/цыклов дискасс
Машинный цикл — промежуток времени между двумя последовательными обращениями центрального процессора к внешней оперативной памяти команд/данных, или обмена 1 словом данных с периферийными устройствами, в том числе в циклах обработки аппаратных прерываний и является составляющей частью исполнения машинной команды.


Такт процессора или такт ядра процессора — промежуток между двумя импульсами тактового генератора, который синхронизирует выполнение всех операций процессора.
Аноним 30/03/19 Суб 21:26:03 137246932
>>1372468
Бля цЫкл
цЫкл карл
Соре за цыклцикл
30/03/19 Суб 21:51:25 137247933
>>1372468
> для рабочих процов + архитектуры нет
Суперскалярная архитектура, мам. Какие именно такты ты считать собрался? Почитай Intel Architectures Optimization Reference Manual, почитай Агнера Фога для начала.
Аноним 30/03/19 Суб 21:53:21 137248034
Стикер (0Кб, 512x512)
512x512
30/03/19 Суб 21:54:26 137248135
Аноним 30/03/19 Суб 22:53:34 137251336
Аноним 01/04/19 Пнд 10:04:32 137309137
Аноним 01/04/19 Пнд 16:53:41 137326238
Как сгенерировать фейковую IAT? Посоветуйте, что гуглить.
Аноним 01/04/19 Пнд 19:14:23 137331139
Аноним 01/04/19 Пнд 21:11:41 137339240
>>1373311
А на С/С++ можно так? Есть примеры?

мимо
Аноним 01/04/19 Пнд 21:20:28 137339941
Аноним 01/04/19 Пнд 22:00:38 137341942
>>1373392
Нет никакой разницы, на каком языке генерировать структурки. Хоть на жс пиши.
Аноним 01/04/19 Пнд 22:25:41 137343943
>>1373419
Хуюрки.
Как он тебе на джоэсс откомпиляет хоть что-нибудь да со своей IAT?
Аноним 01/04/19 Пнд 22:36:15 137345144
>>1373399
>искать в кернеле GetProcAddress
Ты шутишь так?
Аноним 01/04/19 Пнд 22:40:02 137345745
Изучаю язык ассемблера, использую nasm ассемблер и линкер от Microsoft, пытаюсь вызвать С-функцию call puts, но при ее вызове выбрасывается ошибка "Access violation reading location" что я не так делаю?
Аноним 01/04/19 Пнд 22:44:16 137345946
>>1373311
Завтра посмотрю. Под фейковым импортом я понимаю технологию, когда программа дёргает апи динамически при помощи парсинга таблицы импорта dll, а собственный импорт у неё фейковый или вообще спизжен у калькулятора.
Аноним 01/04/19 Пнд 22:58:11 137346547
>>1373439
> Как он тебе на джоэсс откомпиляет хоть что-нибудь да со своей IAT?
А как на Си компиляют? Какая разница-то, какой у тебя язык? Ну делаешь UInt8Array, создаешь от него DataView, пишешь туда по очереди поля IMAGE_DOS_HEADER, пишешь туда стаб, пишешь туда IMAGE_NT_HEADERS, пишешь IMAGE_SECTION_HEADER, пишешь данные секций, в том числе и секцию с твоей фэйковой директорией импорта, делаешь Blob, он сохраняется браузером, как обычно файлы скачиваются. Если хочется код генерить, есть готовые либы. Если не хочется, можно через FileReader загрузить бинарник и пропатчить его точно таким же способом.
Аноним 01/04/19 Пнд 22:59:41 137346648
>>1373459
Один импорт парсит, другой GetProcAddress в ядре вызывает. Тебе экспорт парсить надо, обсуждалось в прошлом треде.
Аноним 01/04/19 Пнд 23:03:23 137346949
>>1373457
> учусь водить машину, но когда я нажимаю педаль газа, у нее отваливается бампер, что я делаю не так?
КОД ТАЩИ
Аноним 01/04/19 Пнд 23:04:50 137347150
>>1373469

global main
extern puts

section .text
main:
mov rdi, message
call puts
ret
message:
db "Test", 0
Аноним 01/04/19 Пнд 23:37:11 137349051
>>1373471
Ты уверен, что ты линкуешься 64-битным линкером? Ты уверен, что первый аргумент для Microsoft-овой конвенции вызова должен быть в RDI? Ты уверен, что ты shadow space в стеке под аргументы зарезервировал?
Аноним 02/04/19 Втр 13:43:34 137372152
Я начал заниматься кряканьем софта некоторое время назад. Подскажите, на каких форумах я могу найти заказы на взлом?
Аноним 02/04/19 Втр 14:06:12 137374053
Аноним 02/04/19 Втр 14:11:36 137374254
Треда для системников нет, а в С/С++ сидят одни ньюфаги хеллоуворлдщики поэтому спрошу здесь. Пишу классический non pnp драйвер, все вроде работает, но при выгрузке внезапно синий экран. PAGE FAULT IN NONPAGED AREA.
В DriverEntry:
DriverObject->DriverUnload = &Unload;

Unload rouitne:
VOID Unload(
IN PDRIVER_OBJECT DriverObject
)
{
IoDeleteSymbolicLink(&SymbolLink);
IoDeleteDevice(DriverObject->DeviceObject);
}

Где проебался-то?
Аноним 02/04/19 Втр 20:12:14 137390355
>>1373490
Спс, разобрался, надо было в регистр rcx писать адрес строки.
Аноним 03/04/19 Срд 00:27:05 137404656
>>1373742
> SymbolLink
Что там? Фолт при выгрузке или слегка после?
Аноним 03/04/19 Срд 09:25:54 137409657
Как перейти в защищенный режим?
Аноним 03/04/19 Срд 09:52:26 137410058
>>1374096
Собираешь валидную таблицу дескрипторов, кладешь ее в GDTR, ставишь бит PE в CR0, выполняешь дальний jmp на начало 32-битного кода. Ну и там загрузка всяких SS и отключение прерываний по вкусу.
Аноним 03/04/19 Срд 13:20:51 137422059
>>1374100
Спасибо,а теперь наебень кода на асме, заранее спасибо.
Ну или скажи где про это можно нормально почитать, а то я конченый.
Аноним 03/04/19 Срд 13:31:28 137423060
Аноним 03/04/19 Срд 13:56:39 137424361
>>1374230
Подожди, ты самый умный или как? Расскажи как быть таким же умным. Я вот не могу уйти в защищённый режим. Ты вот красиво по пунктам расписал, оно понятно все, но вот код не понятно, акты в порты какието, таблиц куча, джампы, и вот везде кал написан а мне непонятно, объясни заранее спасибо
Аноним 03/04/19 Срд 14:17:30 137426362
>>1374046
Юникод строка, валидная. Фолт во время вызова Unload.
Аноним 03/04/19 Срд 14:20:00 137426863
>>1374100
На сколько я помню, это уже с 2017 года не прокатывает, с приходом hyperguard'а.
Аноним 03/04/19 Срд 14:21:30 137427364
Аноним 03/04/19 Срд 14:34:56 137429165
>>1374230
Более фундаментальное есть почитать? Я так понял, Windows Internals поможет, да?
Аноним 03/04/19 Срд 14:39:18 137429666
>>1374268
Чо? А гипервизоры-то тут каким местом вообще?

>>1374263
Понятно, что строка. Где у тебя симлинк конкретно? Проверь ради разнообразия, что тебе IoDeleteSymbolicLink возвращает. Алсо, ты уверен, что у тебя после анлоада колбеки какие-нибудь не остаются торчать?

>>1374291
Ты хочешь перейти в защищенный режим из винды, лол?
Аноним 03/04/19 Срд 15:47:19 137433167
>>1374296
Из третьего защищенного режима в нулевой.
Аноним 03/04/19 Срд 15:59:09 137434468
>>1374331
> Из третьего защищенного режима в нулевой.
Из третьего кольца, ты хотел сказать. Режим на то и защищенный, чтобы ты так не смог.
Аноним 03/04/19 Срд 17:04:05 137438169
>>1374296
Из сейфмода 9х собрался, умник
Аноним 03/04/19 Срд 17:45:37 137439970
Аноним 03/04/19 Срд 17:50:29 137440371
>>1374381
В 9x как раз без проблем можно было запатчить IDT, перейдя из r3 в r0 буквально десятком инструкций, без дров. И наличие или отсутствие сейфмода при этом никак не мешало.

>>1374399
Ну теперь-то ясно. Я просто думал, что в изначальном вопросе спрашивали про банальный переход из реалмода, а вы тут хацкеры, оказывается.
Аноним 03/04/19 Срд 19:15:54 137449172
>>1374291
Да, читай 7 издание 1 часть, потом сразу 6 издание 1 и 2 часть наверни, чтобы почувствовать разницу и прощупать логику m$.

>>1374296
Спасибо, разобрался. Надо каждый раз что-ли строку инициализировать?
Аноним 04/04/19 Чтв 08:48:12 137478573
Как вернуться в реальный режим(в дос обратно, чтобы все работало)
Аноним 04/04/19 Чтв 10:25:02 137481574
>>1374785
Ну... кладешь в в IDT реалмодную таблицу, в GDT дескрипторы, чтобы на реалмод похоже было (16-битные сегменты, лимит мегабайт вот это все), прыгаешь в такой 16-битный сегмент, сбрасываешь CR0.PE, опять прыгаешь, чтобы CS перезагрузить уже реалмодным значением, перезагружаешь все остальные сегментные регистры сохраненными значениями (если у тебя DOS) или любыми разумными (если не DOS).
Аноним 06/04/19 Суб 10:25:30 137584575
>>1369180 (OP)
Программята, я тут по залёту. Препод сказал что повысит мне оценку если я принесу ему ёлочку на ассемблере, но у нас, блядь, было всего две пары по нему два года назад. Нагуглил только какую-то сложную ёлку с анимацией, а это слишком подозрительно. Поможете или я могу нахуй пройти?
Аноним 06/04/19 Суб 23:20:55 137630176
Реверсач, сегодня наткнулся на файл с тремя kernel32.dll в импорте. Что за магия?
Аноним 06/04/19 Суб 23:49:46 137632677
Аноним 07/04/19 Вск 02:52:14 137642678
>>1376301
Шутка про программиста и два стакана вышла на новый уровень.
Аноним 07/04/19 Вск 14:41:45 137670379
aleq5S6dY.jpg (69Кб, 600x495)
600x495
Анон, где можно посмотреть/спиздить исходные коды различных девайсов, всякие мигалки на 100500 диодов заебали
Аноним 07/04/19 Вск 22:49:44 137695180
>>1376326
Судя по-всему это было сделано намеренно.

>>1376426
Что за шутка?
Аноним 07/04/19 Вск 22:53:22 137695481
Пол года уже прошло. Иду 7.2 бесплатно завезли? Если да, то где скачать?
Аноним 08/04/19 Пнд 06:41:59 137705082
Появилась недавно идея, сделать электронный замок для ящика стола. Короче говоря, я сажусь за ПК, ввожу пароль. Ящик открывается. Для этого нужно придумывать какую-то муть с подключением всего механизма к ПК. Впринципе, если б я это пилил на какой-нибудь ардуинке И вместо пароля- обычная кнопочка, то проблем бы это не составило. Но т.к я хочу сделать это через ПК, то возникает масса вопросов. Как организовать ввод-вывод (Через какие порты) Можно через usb, но как??
Если на той же ардуино много разных портов ввода-вывода, и на каждый можно подавать напряжение по отдельности, либо считывать с него, то как это делать посредством usb провода?
Натолкните на инфу по этому вопросу. Я даже слабо представляю как такое гуглить
Аноним 08/04/19 Пнд 07:15:00 137705183
>>1377050
Ну погугли спеку юсб, как там инфа кодируется не подойдёт тебе юсб, попробуй выход на колонки
Аноним 08/04/19 Пнд 07:22:12 137705384
>>1377051
> не подойдёт тебе юсб, попробуй выход на колонки
Это как вообще? Просто как провода от jack 3.5 обрезать, и в качестве пинов использовать?
Аноним 08/04/19 Пнд 07:31:17 137705585
>>1377051
Ну, не подойдёт если ты не хочешь ответное устройство городить
>>1377053
Ну зачем сразу отрезать, впаяй в свой замок разъем и возьми повод джек-джек
Аноним 08/04/19 Пнд 09:30:03 137707186
>>1377050
> Если на той же ардуино много разных портов ввода-вывода, и на каждый можно подавать напряжение по отдельности, либо считывать с него, то как это делать посредством usb провода?
Ну придумываешь кастомный протокол, кидаешь пакетики в устройство, чтобы управлять output-портами, периодически опрашиваешь устройство на предмет событий с input-портами. На компе через libusb, на устройстве - зависит от микроконтроллера, хоть вручную, хоть через многочисленные USB-либы. И вообще, ты сюда мимо, тебе в /ra/.
Аноним 08/04/19 Пнд 12:31:05 137712987
>>1375845
Бери прсотую сишную елку и перепиши на асм. Или дизассемблируй. Вот уж проблема то.
Аноним 08/04/19 Пнд 12:31:41 137713088
>>1376703
Если линукч, то наверно в ядре его
Аноним 08/04/19 Пнд 12:45:38 137713789
>>1377129
А можно просто конпелятору опцию указать и он будет генерить асм-код завместо бинарника.
Аноним 09/04/19 Втр 16:41:26 137781690
Аноним 09/04/19 Втр 17:01:06 137781791
14749971836651.jpg (77Кб, 400x400)
400x400
Аноним 09/04/19 Втр 18:57:47 137788192
>>1377817
>дизасемблировать занятие так себе
И ты об этом пишешь в треде реверсеров?!
Аноним 09/04/19 Втр 19:10:32 137789093
9DASeokcaXw.jpg (54Кб, 604x457)
604x457
>>1377881
> Вы пишите на ассемблере или собираетесь начать на нём писать? Программируете микроконтролёры
Не, отреверсить то можно, но мне бы сначала с просто кодингом разобраться, все ж мы люди
Аноним 09/04/19 Втр 21:46:04 137796294
Какой диалект на linux использовать - nasm или gas?
Насколько я понял, то gas более типичен для данной ОС, а основное отличие в том, что используется не intel синтаксис, а AT&T (хоть gas и поддерживает intel syntax). AT&T вроде более нагляден и понятен.
Аноним 09/04/19 Втр 21:48:20 137796395
Аноним 09/04/19 Втр 21:55:18 137796996
Аноним 09/04/19 Втр 23:35:57 137800997
Аноним 09/04/19 Втр 23:40:35 137801398
>>1377963
Вот как только томаш stabs осилит (нативно, а не через внешний костыль, который парсит fas), вот прямо сразу. А до тех пор fasm советовать широкому кругу особенно под linux бессмысленно, и даже сраный nasm будет лучше.
Аноним 10/04/19 Срд 10:43:17 137820199
>>1378013
Кстати, кто-нибудь знает, как из фасма / фасм-г экспортировать отладочные символы и импортировать их x64dbg? В каком формате это надо делать?
Аноним 10/04/19 Срд 11:03:12 1378206100
fsdg
Аноним 10/04/19 Срд 13:18:15 1378242101
Аноним 10/04/19 Срд 17:11:08 1378386102
Аноним 10/04/19 Срд 17:33:11 1378404103
10/04/19 Срд 17:53:00 1378421104
>>1378404
Кэп? Куча бреда в его статьях и книгах никак не отменяет того факта, что по ним училось большинство реверсеров в 2000х.
10/04/19 Срд 18:14:22 1378455105
>>1378404
Почитал. Критикующий ничем не лучше: тоже достаточно неточностей, фактических ошибок и просто вкусовщины.
Аноним 11/04/19 Чтв 01:01:32 1378894106
Реверсач, я заебался. Как все это байтоебство монетизировать? Уже 2 года тут варюсь, да нравится, да интересно, но без денег на энтузиазме сами понимаете... Вакансии искать сложно, их просто нет. Что делать?
Аноним 11/04/19 Чтв 01:05:58 1378896107
>>1378894
приватные читы
малварь
Аноним 11/04/19 Чтв 02:31:28 1378916108
>>1378894
Вирусная аналитика
Аноним 11/04/19 Чтв 03:00:15 1378927109
>>1378896
Эту ерунду школьникам оставь. Пусть их бутылят.

>>1378916
Я что-то ни разу вакансий не видел, еще бы они были, брать рандома с улицы так себе затея.
Аноним 11/04/19 Чтв 04:56:36 1378952110
>>1378927
За читы не бутылят и это достаточно прибыльная ниша. Но судя по ответу у тебя мозго только на байтоебство хватает, так что остается тебе только страдать и тешить себя мыслью о том что не тупой, потому что "уже 2 года тут варюсь".
Аноним 11/04/19 Чтв 06:08:27 1378959111
Аноним 11/04/19 Чтв 16:54:23 1379210112
Аноним 11/04/19 Чтв 17:04:40 1379217113
>>1378927
Ты где смотришь вакансии? Зайди на сайт Касперского и дрвеба, есть там вакансии
Аноним 11/04/19 Чтв 18:23:32 1379265114
>>1378952
Бутылят, на за сами читы, а за вытекающие проблемы этого бизнеса. Чтобы развернуть проект, нужна команда 3-5 человек минимум, нужно как то согласовывать разработку, распределять средства между незнакомыми друг с другом людьми в интернете и еще овер9999 подводных камней.

>>1379217
ДС/ДС2, опыт от 3 лет.. Понятное дело, что у гигантов типа касперского и прочих будут вакансии. С нуля без опыта-то куда вкатываться-то? А если я еще и из мухосрани?
Аноним 11/04/19 Чтв 20:52:11 1379367115
>>1379265
Если продолжить сидеть на шее мамки, точно никуда не устроишься.
Аноним 12/04/19 Птн 13:58:32 1379675116
Аноним 12/04/19 Птн 17:45:03 1379837117
Посоветуйте статьи про создание собственного ассемблера и написание простого парсера, лексера и генератора машинного кода. Хочу написать компилятор для своей ВМ.
Аноним 13/04/19 Суб 04:18:55 1380127118
НАДО АКТИВИРОВАТЬ ФУНКЦИЮ ПЕЧАТИ ДОКУМЕНТА
@
ДЛЯ РЕФЕРЕНСА РЯДОМ ЕСТЬ АКТИВНАЯ ФУНКЦИЯ ПЕЧАТИ ОДНОЙ СТРАНИЦЫ
@
ВЫПОЛНЯЕТСЯ ЗА 150 ИНСТРУКЦИЙ, ВСЁ ПРЕДЕЛЬНО ПРОСТО
@
НАШЁЛ, КАК ВЫЗВАТЬ ПЕЧАТЬ ДОКУМЕНТА
@
В ПРОЦЕССЕ ВЫПОЛНЕНИЯ ДЁРГАЕТ НЕБО И АЛЛАХА, ПРОВОДИТ КАКИЕ-ТО СКРЫТЫЕ ПРОВЕРКИ, КОТОРЫЕ ТОЖЕ НАДО ОБОЙТИ
@
СПУСТЯ 1000 ИНСТРУКЦИЙ И 3 ЧАШКИ КОФЕ МЕЧТАЕШЬ О ТОМ, ЧТО ЛУЧШЕ БЫ ШЛЁПАЛ ФОРМЫ НА ДЖАВАСКРИПТЕ


вкатился
Аноним 13/04/19 Суб 05:22:40 1380129119
image.png (60Кб, 225x225)
225x225
>>1377050
Я делал что-то подобное через ft232 - на стороне PC usb + driver, другим концом в микроконтроллер serial RX/TX. Все предельно просто. API на сях, довольно удобный и высокоуровневый.
Код типа такого
FT_SetBaudRate (ftHandle, 9600);
FT_SetDataCharacteristics(ftHandle, FT_BITS_8, FT_STOP_BITS_1, FT_PARITY_NONE);
...
ftStatus = FT_Write(ftHandle, &buf, sizeof buf, &bytesWritten);

и тд. Никаких проблем. Я с армом спаривал, можешь хоть с ардуинкой, с чем угодно. В /ra/ сходи еще.
Аноним 13/04/19 Суб 11:54:25 1380219120
>>1379265
Никуда, продолжай ныть и отговорки придумывать.
Аноним 16/04/19 Втр 18:54:12 1382376121
Пишу лабу. Нашел похожую прогу и вычищаю всякое ненужное говно и разбираюсь что здесь что.
Можете пояснить, зачем он закидывает в стек дс и выкидывает ес? В чём суть? (Без этого лаба не работает, поэтому надо рабобраться)
Для чего обычно это используется?
push ds
pop es
Аноним 16/04/19 Втр 19:29:57 1382394122
>>1382376
>Для чего обычно это используется?
>push ds
>pop es
es=ds
Т.к. прямых команд типа mov es, ds нетути.
Аноним 16/04/19 Втр 19:37:56 1382398123
>>1382394
А что это означает? Нахуя тобишь? Код не сильно большой, надеюсь меня не побьют.
Без него ничего не работает, но я не пойму смысол.

lea SI, StringINP+2 ;взятие адреса входящей строки
lea DI, StringOUT+2 ;взятие адреса исходящей строки
mov CL, StringINP+1

push ds
pop es

Proverka:
lodsb
cmp AL, 20h
je stop
cmp AL, 9
je stop
stosb
stop:
loop Proverka
lea dX,StringOUT
mov AH, 09h
int 21h
quit:
exitcode 0
end
Аноним 16/04/19 Втр 19:46:12 1382404124
>>1382398
>Нахуя тобишь?
Пушто lodsb работает с парой DS:SI, а stosb с парой ES:DI.
Если SI и DI в одном сегменте, то надо как-то сделать, чтобы ES=DS.
Т.к. прямого присвоения типа mov ES, DS нету, то костылишь это через pusd DS/pop ES.
Аноним 16/04/19 Втр 19:49:39 1382408125
image.png (183Кб, 450x565)
450x565
>>1382404
ПАСИБА.
Миллион нефти тебе :3
Аноним 16/04/19 Втр 20:00:08 1382415126
>>1382404
>Если SI и DI не в одном сегменте
слоуфикс
Аноним 18/04/19 Чтв 01:09:41 1383141127
чего в шапке нет ссылки на дизассемблер от большего брата? https://ghidra-sre.org (заходить с впн)
Аноним 18/04/19 Чтв 16:02:37 1383459128
Мимодебилу подскажите.
Проходил туториал от cheat engine и немного разбираюсь в ассемблерах этих. Совсем чуть чуть.
Есть одна игра, и в ней есть кнопка, которая требует 80 левл, чтоб на неё нажать.
Я подумал найти где в ассемблере считается левл и изменить там.
Текущий левл видно в меню персонажа, но я его чит энжином никак не могу найти. Искал уже по типу all, по типу string, ничего нет. Точнее за 2-3 прохода вся таблица исчезает. Будто адрес левла меняется постоянно.
В меню персонажа левл выводится как Level: 4 например.
Нашел эту строку в памяти Level: %d
Сделал Find out what accesses this address
При открытом меню персонажа там есть 2 адреса, которые читают эту строку.
Взял первый, Show disassembler
Если я меняю на nop, то текст пропадает из всего меню персонажа. Все строки. Значит я на верном пути.
Сделал Break and trace instructions и теперь у меня тыща инструкций. Но это не просто printf (string, ADDRESS_OF_LEVEL); а куча хлама, среди котрого хрен найдёшь нужное.

Как мне выследить где хранится ебучий левл?
Аноним 18/04/19 Чтв 16:17:36 1383468129
>>1383459
Кстати статы я так же не могу никак отловить, силу, ловкость, вот это всё. После 2-3 изменений в cheat engine пустая таблица.
Аноним 18/04/19 Чтв 16:26:09 1383471130
>>1383459
>теперь у меня тыща инструкций. Но это не просто printf (string, ADDRESS_OF_LEVEL); а куча хлама, среди котрого хрен найдёшь нужное
Добро пожаловать в ассемблер.
Аноним 18/04/19 Чтв 16:42:55 1383479131
изображение.png (27Кб, 780x399)
780x399
>>1383471
>>1383468
>>1383459
Пиздец.
Я справился. Я победил.
Написал пелену текста как я это сделал, а макаба взяла и удалила мне весь пост.
Лень писать, но я выйиграл. Пикрелейтед - проверка на 80 левл.
Аноним 18/04/19 Чтв 16:45:40 1383480132
Как мне последовать за call инструкцией? То есть есть функция yoba, которая внутри вызывает функцию makaba, ида пишет мол вот смотри: yoba + 0x2b ; call makaba. Как мне блять адрес то макабы получить чтобы вызвать ее? (fnProt)yoba = get_addr(yoba) + 0x2b же? Но так не работает.
Аноним 18/04/19 Чтв 16:56:02 1383485133
>>1383480
>Как мне последовать за call инструкцией?
F7
18/04/19 Чтв 19:31:23 1383592134
>>1383480
Подозреваю, что ты хочешь что-то типа call_target = base + offset + 5 + dword_at(base + offset + 1), где base - это yoba, offset - это смещение инструкции call относительно base, т.е., 0x2b, call_target - вычисляемый адрес makaba, 1 - офсет rel32 внутри инструкции call (всегда 1 в этой форме), 5 - размер инструкции call rel32 (всегда 5 в этой форме), rel32 - это смещение вызываемой фукнции относительно следующей за call инструкции.
Аноним # OP 18/04/19 Чтв 20:16:30 1383627135
>>1383141
Потому что никто уже третий тред не может его нормально прикрепить. Вот так:
>>1369180 (OP)
ОП, добавь в шапку гидру
Аноним 19/04/19 Птн 04:46:16 1383826136
Ассемблер ломает мне мозг. Я думал это машинный язык, а он компилируемый получается.
Вот из примера
>e db 'string',0 ; Определяем строку из 7 байт, заканчивающую нулём
Как это будет выглядеть в хексе экзешника? "e" это имя переменной.
Там ведь не будет слова "e" для переменной?
Аноним 19/04/19 Птн 04:51:01 1383827137
>>1383826
>\t\t
Это макаба добавила. Там в оригинале табуляция.

И потом если этот экзешник открыть чем-нибудь, что показывает ассемблерный код, что он покажет?
Я пока ничего не умею, сам проверить не могу.
Аноним 19/04/19 Птн 05:08:27 1383828138
изображение.png (38Кб, 665x276)
665x276
>>1383827
>>1383826
А, я понял.
>e db 'string',0
превратится в
>73 74 72 69 6E 67 00
а
>mov eax, [e]
превратится в
>mov eax, [0xАДРЕС]
Аноним 19/04/19 Птн 09:16:27 1383861139
image.png (9Кб, 485x164)
485x164
>>1383485
Спасибо конечно, но мне нужно это сделать не в иде, а в рантайме на С.

>>1383592
Теперь я еще сильнее запутался... Вот другой пример прикрилейтед. FUNC - экспортируемая функция в дллке, func_internal - нет, но мне нужно получить к ней доступ, чтобы единичку в последнем параметре заменить на нуль при вызове. Как мне вызвать то func_internal? Делаю GetProcAddress(func), получаю адрес func, смещение по которому находится вызов func_internal = func + C. Но все равно вызвать функцию не получается.
19/04/19 Птн 19:29:20 1384303140
>>1383861
> Как мне вызвать то func_internal?
Псевдокод:
typedef int func_internal_type(int a, int b, int c, int d, int e);
uintptr_t funcptr = (uintptr_t) GetProcAddress(lib, "func");
uintptr_t call_insn = funcptr + 0x0c;
assert(∗(uint8_t ∗) call_insn == 0xe8); // Опкод CALL.
uintptr_t rel32 = ∗(uintptr_t ∗) (call_insn + 1);
uintptr_t call_target_addr = (call_insn + 5 + rel32) & 0xffffffff;
func_internal_type ∗func_internal = (func_internal_type ∗) call_target_addr;
func_internal(1, 2, 3, 4, 5);

Пример на пальцах. Допустим, у тебя есть:
0x10000000: e8 20 01 00 00: CALL 0x10000125
0x10000005: c3: RET
Ты читаешь из инструкции rel32 (little endian, выделено жирным): rel32 = 0x00'00'01'20, берешь адрес следующей инструкции после call: 0x10000005, прибавляешь к нему rel32 (считаешь в 32-битной арифметике с переполнением, rel32 со знаком, но на это похуй) и получаешь адрес вызываемой функции: 0x10000005 + 0x00000120 = 0x10000125. То же самое делается для относительного JMP.
Аноним 20/04/19 Суб 02:20:14 1384523141
>>1384303
Благодарю, вроде все понял, буду пробовать. Есть вообще доп. материал по данной тематике? Как гуглить решение аналогичных задач? Или нужно асм активно вкуривать и само все придет?

Еще вычитал способ с поиском адреса функции по сигнатуре, выглядит проще. Какой из этих двух способ более правильный?
Аноним 20/04/19 Суб 02:59:04 1384525142
>>1384523
Если знаешь название экспортируемой функции, глупо было б искать ее по сигнатуре
20/04/19 Суб 03:47:07 1384527143
>>1384525
Возможно, имеет смысл искать сам опкод по сигнатуре, а то мало ли как компилятор в следующий раз наоптимизирует, офсет изменится, и приехали.

>>1384523
> выглядит проще
Да там на самом деле одно-два выражения всего, если лишних переменных не создавать. И да, я только сейчас случайно заметил, что у тебя 64-битный код, а у меня там unsigned читается. Сорян. Надо вот так хотя бы, тогда и в 32- и в 64-битном коде норм будет:
uintptr_t rel32 = (uintptr_t) ∗(int32_t ∗) (call_insn + 1);
uintptr_t call_target_addr = call_insn + 5 + rel32;
Аноним 20/04/19 Суб 08:35:19 1384562144
>>1384527
1. если он в следующий раз наоптимизирует, твой сигнатура идет нахер
2. тебе не надо знать офсет, чтобы хукнуть импортируемую функцию из ддл
Аноним 20/04/19 Суб 08:40:34 1384566145
Кто шарит в windows debug?
Напишите уравнение: x = (a*3+5)/c+b
Аноним 20/04/19 Суб 08:42:20 1384568146
20/04/19 Суб 16:06:34 1384872147
>>1384562
Если он в следующий раз наоптимизирует, первая вызываемая функция останется первой (ну разве что стекчек появится какой). Чтобы хукнуть экспортируемую, офсет не нужен, но анону нужно самостоятельно вызвать неэкспортируемую фукнцию, которую вызывает экспортируемая.
Аноним 20/04/19 Суб 20:22:59 1385026148
Стоит ли читать Зубкова, учитывая что там большая часть книги описывает работу с dos, win95 и т.д.? Мб есть что-то поактуальнее?
Аноним 20/04/19 Суб 23:00:08 1385127149
Аноним 21/04/19 Вск 09:42:28 1385209150
>>1385026
главное не выбирать долго долго а сесть и начать. кому как, у меня начало было так:
курс с asmworld.ru по FASM + Калашников https://rutracker.org/forum/viewtopic.php?t=4480735
Знаю что Калашников старье не актуальное и все что пишется либо на ХР запускать либо в досбоксе. Чисто чтоб привыкнуть к асемблеру.
А дальше все как в книжке Юричева. компилятор + олька + ида, и в путь. Можно по курсу ольки от Нарвахи пробежаться.
Аноним 21/04/19 Вск 09:42:47 1385210151
>>1384525
Так она не экспортируемая.

>>1384527
Спасибо еще раз. Почитать-то есть что-нибудь на данную тему? Далее планирую похукать функцию. Это же inline hook называется, когда в начало функции пишешь свой jmp, address?
Аноним 21/04/19 Вск 09:46:06 1385211152
Аноним 21/04/19 Вск 09:57:24 1385215153
>>1385211
Итак, мы рассмотрели фреймворк для реверс-инжиниринга Ghidra. Сможет ли он заменить IDA Pro? Я думаю, что на данном этапе своего существования — нет. Дело в том, что Java в качестве языка для написания подобных программ, на мой взгляд, не лучший выбор. И дело, конечно, в скорости.

Дизассемблер работает небыстро, особенно на тяжелых файлах. Скажу больше: файлы размером свыше 150 Мбайт реверсить на Ghidra — то еще испытание. С другой стороны, Ghidra кросс-платформенна, и для кого-то это может быть важно.

Следующий момент — это количество поддерживаемых архитектур и загрузчиков файлов: у IDA Pro их значительно больше. Еще очень не хватает такой же плотной интеграции с отладчиками, как в IDA Pro. Опять же, открытость кодов (если NSA выполнит обещание) — это хорошо, да и возможность добавлять поддержку других архитектур — по-настоящему крутая фишка. Но пока будет выполнена эта работа (и исправлены баги), пройдут годы.

Вообще, у меня сложилось стойкое впечатление, что Ghidra — это не конечный продукт. В том виде, в котором этот фреймворк доступен сейчас, он тянет на бета-версию с публичным доступом, но никак не на версию под номером девять. Кстати, в названии архива есть слово PUBLIC. Наверняка где-то есть еще и версия PRIVATE.

Безусловно, у Ghidra есть свои сильные стороны, и в чем-то она уже превосходит IDA Pro, но слабых мест пока что намного больше. А вот разработчикам IDA есть что позаимствовать в новом инструменте. Например, мне понравилась повышенная информативность кода, представленного в виде графа. Да и само построение графа кода выглядит более строго и упорядоченно. Есть патчинг инструкций без дополнительных плагинов и без разделения на x64 и x86. Зачем держать два ярлыка на рабочем столе, если достаточно одного?
Аноним 21/04/19 Вск 09:58:41 1385217154
Аноним 21/04/19 Вск 10:02:58 1385219155
>>1385215
там после "Здесь видим список всех функций с их сигнатурами" закрыто сайтом. Можешь Ctrl+P и пдфкой сюда?)
Аноним 21/04/19 Вск 11:35:28 1385255156
>>1385215
иногда гидра лучше листинг выдает, чем ida pro 7.0
Аноним 21/04/19 Вск 15:35:03 1385841157
>>1385210
> Я думаю, что на данном этапе своего существования — нет
Учитывая, как легко и красиво пишутся плагины, то иде пизда. И радару пизда.
Аноним 21/04/19 Вск 15:42:16 1385864158
Стикер (0Кб, 512x512)
512x512
>>1385841
>>1385255
Уже установили JRE?

Налажали спец. службы конечно, уж писали бы на сисярпе хотя бы.
Аноним 21/04/19 Вск 15:59:48 1385881159
>>1385864
ничего не наложали. у них при работе скорее всего крутится на сервере с нужными мощностями, а ты подключаешься по сети дебажешь. Да и понятие скорости там не так важно. ну анализирует оно дольше, да и фиг с ним. Главное простота поддержки кода, уровень вхождения.
Цифра 9 - когда начинали .net core наверно был только в зарождении, а тут все сразу из коробки. так что для них выбор очень даже хороший.
21/04/19 Вск 16:41:25 1385917160
>>1385864
> Уже установили JRE?
Ты мимо пробегал? Пробегай, не задерживайся. Мы тут реверсеры, нам приходится реверсить и жабкуандроид, поэтому жре у всех и так установлен.
Аноним 21/04/19 Вск 18:31:12 1385993161
Парни помогите ,жопа горит уже не могу.
При установке драйвера TitanHide столкнулся с ошибкой
StartService fails with error 6 "Invalid Handle" , а также до этого была проблема с загрузкой win без подписи драйвера, при выборе даже в загрузочном меню F8 команда игнорировалась и запускала обычную версию.
Решил ту проблему через msconfig
как же я блять не навижу ебаный шиндовс
Аноним 22/04/19 Пнд 02:09:52 1386277162
Сап, реверсач.
Вопрос мб тупой, но всё же задам: в 2к19 пишутся ли годные малвари на чистом асме? Или это, как правило, сишный код с инлайн асм вставками?
Аноним 22/04/19 Пнд 11:07:18 1386418163
>>1385993
Ты как грузишь драйвер-то? Проблема очевидно c SCM-manager'ом. На сколько я помню проект опенсурс, так что смотри исходники и дебаж.

>>1386277
Прям целые боты естественно не пишутся на асме, люди ценят свое время. А вообще лучше не лезь, анон, сейчас за малварь активно бутылят, да и не выгодно это уже.
Аноним 22/04/19 Пнд 13:47:55 1386567164
>>1386418
Все в ознакомительных целях на самом деле, я хочу в недалеком будущем начать анализировать малвари, сейчас усиленно учу асм и хочу знать полностью его мощь/возможности.

Аноним 22/04/19 Пнд 14:01:19 1386579165
>>1386567

Тогда ты на выбор попадешь или к мусорам из раши, или к мусорам из СШП. Причем, ко вторым тебе шансов попасть больше. Еще есть такой вариант , что после бутылки от отечественных мусаров тебе предложат поработать штирлицом плаща и кинжала на гыгыру или какого вагнера (в противном случае на тебя повесят все глухари и отправят к маньяками и серийным мокрушникам в черный дельфин) тип штатным хакером, где ты в тюрячке/шараге под одобрительные солдатские пиздюли будешь ломать пентагон с IP адреса минобороны, после чего гыгыру и пуйло поджав хвост и поскуливая, сольют тебя мусорам из СШП. Где ты получишь тот же пожизняк-двадцаточку, но уже с многомиллиардными штрафами.

Да, касперский, по последним сводкам тоже на гыгыру и вагнера работает, параллельно многостаночит на прочие кардерские тусовки. Так что ну его нахуй это хекерство - если ты не какой мексиканский главарь Los Zetas и у тебя нет своей личной армии.

Хакеров везде не любят, тащемта. Тут тот случай что даже заведенный трактор/его отсутсвие похеру.

Потому что речь идет о серьезных деньгах серьезных людей по всему миру.
Аноним 22/04/19 Пнд 16:31:14 1386701166
>>1386567
чекать малвари и сигнатуры в базы антивирусные вносить - утомительная работа, быстро надоест, к тому же нет роста как профессионала. А конкретно реверсеры, нужны не в таких больших количествах.
Но это удобный скил лично для себя. Плюс с обилием крякми - всегда для хобби будут задачки головоломные которые порешать.

а так, загляни https://habr.com/ru/post/438376/
Аноним 22/04/19 Пнд 17:23:45 1386721167
>>1386579
Анон, что ты несешь? Речь идет о кристально белой шляпе, которая проводит binary exploitation исключительно в рамках инфосек компании за зарплату. Ни про какие мутные взломы и прочую хрень речи не идет вовсе. Я лишь спросил про мощь асма у более знающих людей (уверен, здесь таких немало), а в ответ полетел бред про бутылку и криминал.
Аноним 22/04/19 Пнд 17:28:13 1386724168
>>1386721
>о кристально белой шляпе
Следователю расскажешь и фсбшникам объяснишь, идиотик.
Аноним 22/04/19 Пнд 17:33:16 1386728169
>>1386724
Ты совсем даунич?с: Инфосек специалисты для чего в соответствующих компаниях работают? Чтобы проводить аудит безопасности для тех или иных продуктов, причем здесь вообще криминал, даунёнок? Им платят деньги за то, чтобы выходил качественный, трудновзламываемый софт.
Аноним 22/04/19 Пнд 17:36:32 1386732170
>>1386728
>Инфосек специалисты для чего в соответствующих компаниях работают?
Чтобы за 15к фублей и статус невыездного подымать россиюшку.
Ну и если что не так - то тут же сесть, разумеется.
Аноним 22/04/19 Пнд 17:42:04 1386735171
>>1386732
А, забыл упомянуть, что речь идет не про рашку и даже не про страны СНГ, но это совсем другая история с:
Пожалуй, подожду адекватного ответа по поводу асма, а то продолжать юзлесс демагогию не имеет никакого смысла.
Аноним 22/04/19 Пнд 17:49:05 1386737172
>>1386721

Открою америку: белых шляп не существует - все инфосек конторы занимаются чернотой на заказ, при этом все сотрудники реально ходят под такими NDA, что вплоть до пули от киллера или пера в переулке.
Аноним 22/04/19 Пнд 17:55:15 1386741173
>>1386737
>белых шляп не существует
Пруф или волейбол
Аноним 22/04/19 Пнд 18:05:17 1386747174
Где моча? Тут /по/рашник протёк!
Аноним 22/04/19 Пнд 18:12:57 1386753175
>>1386735
>А, забыл упомянуть
+15
Аноним 22/04/19 Пнд 18:13:54 1386755176
>>1386747
Протек мочой тебе за щеку, сглатывай.
Аноним 22/04/19 Пнд 19:18:02 1386804177
>>1386701
>к тому же нет роста как профессионала
Тут ты обосрался. Карьерный рост есть:
1. Кататься по дефконам светить лицом, продвигать себя и свою кантору
2. Вкатиться в разработку ав-движка
3. Вкатиться в редтим
4. Пилить девтулы для своей канторы

Самое основное вспомнил.
Аноним 22/04/19 Пнд 19:38:38 1386818178
>>1386701
сейчас бы malware analyst был без профессионального роста, лол :-) Хотя, возможно, с ИБ в рашке действительно настолько все плохо, что на всю страну есть только лаборатория Касперского. Основная же масса айтишников - сброд унылых вебмаQAк :-)
Аноним 22/04/19 Пнд 20:24:55 1386862179
Аноним 22/04/19 Пнд 20:32:58 1386872180
>>1386818
Он прав в том плане, что в пентестинг довольно легко вкатиться, но для того, чтобы продолжить заниматься чем-то действительно интересным, необходимы оче разносторонние знания вкупе с профильным образованием.
Аноним 22/04/19 Пнд 20:45:47 1386880181
>>1385215
>Дизассемблер работает небыстро, особенно на тяжелых файлах.
Этот даун думает, что дисассемблер медленный из-за джавы?

>Кстати, в названии архива есть слово PUBLIC. Наверняка где-то есть еще и версия PRIVATE.
Натурально даун.
Аноним 22/04/19 Пнд 21:05:14 1386889182
Есть, кто шарит за демосцену?
Хочу вкатиться чисто для души поделать, плюс углубить анус свои знания.
Тащемта, с чего начать, куда смотреть? Сам недокодер SoC на си
Аноним 22/04/19 Пнд 21:16:09 1386897183
>>1386889
>Тащемта, с чего начать, куда смотреть?
Шейдеры.
всё
Аноним 22/04/19 Пнд 21:23:07 1386904184
>>1386897
я смотрел сурсы демок, там в си вставлен ассемблер..
это все шейдеры?
Аноним 22/04/19 Пнд 21:48:52 1386914185
>>1386804
ну будем честными, это единицам светит, остальные и будут сидеть "вычленять сигнатуры", в то времяч как жава/шарп джуны получают столько же и в джунах не задерживаются.
Аноним 22/04/19 Пнд 21:49:55 1386916186
>>1386818
рынок для реверсеров очень сильно ограничен. И не только в России.
Аноним 22/04/19 Пнд 22:16:35 1386948187
>>1386916
Погугли сколько есть вакансий в разных странах на должности: malware analyst, security researcher. Все они реверсеры, камон, их не так мало. Да, порог вхождения высокий, но их все равно достаточно.
Аноним 22/04/19 Пнд 22:32:43 1386965188
>>1386904
В старых по-разному может быть.
Современная выглядит так:
var sheider='дохуя длинная строка шейдера в текстовом виде'
call Init_grafika
call zapustit_sheider
loop poka_ne_zakonchitsya

А потом это все кранчем жмешь и получаешь заветные 1-4к.
Аноним 22/04/19 Пнд 22:34:37 1386969189
>>1386965
а как оэлдефажные делать...
Аноним 22/04/19 Пнд 23:51:22 1387051190
>>1386948
ну твой опыт похоже ограничивается только гуглом))
Аноним 23/04/19 Втр 20:37:28 1387462191
>>1386880
Очевидно он медленный из-за джавы. Очевидно у спец. служб есть и приватная софтина. Не понял твоих претензий.

>>1386914
В ДСе зп младшего вирусного аналитика может за 100к переваливать, даже джависты могут позавидовать. Рост возможен и потолок гораздо выше чем у того-же джависта/шарписта.


Аноним 24/04/19 Срд 22:04:47 1388062192
>>1387462
ты это на хх смотришь? или работал там? порог вхождения джав/шарп-иста на такую зп куда ниже чем на того же аналитика. Рост у обычного аналитика не так прекрасен как рассказывают, по большей части ты выполняешь тупую нудную работу. В зависимости от фирмы еще и разной специфичности условия.
Ну и да, совсем забыли тут сказать, работа вирусным аналитиком не так уж и сильно корелируется непосредственно с реверсом.
ну а 100к джавистом/шарпистом можно и в регионах, если добавить немного фриланса
Аноним 24/04/19 Срд 22:09:56 1388067193
>>1388062
А педалить какое-то говно на джаве - это не нудно?)
Вирусный аналитик != реверсер? Анон, ты ебобо? 99.9% малварей требуют глубокого статического анализа, где от вирусного аналитика требуется мэдскиллз по обходу обфускации, пакеров, рантайм шифрования и прочего дерьма. Вирусный аналитик - это реверсер на стероидах, ибо обычный софт, в среднем, гораздо меньше и слабее онально огораживают от отладчиков и дизассемблеров, нежели малвари, и тому есть вполне логичные причины.
Аноним 24/04/19 Срд 23:23:19 1388115194
>>1388067
>99.9% малварей требуют глубокого статического анализа, где от вирусного аналитика требуется мэдскиллз по обходу обфускации, пакеров, рантайм шифрования и прочего дерьма.
Ржали всей лабораторией.
Аноним 25/04/19 Чтв 00:33:59 1388163195
image.png (3Кб, 269x77)
269x77
Аноним 25/04/19 Чтв 00:34:41 1388164196
>>1388115
ой, да что ты пиздишь, наверняка какой-нибудь вебмаQAкич :)
Аноним 25/04/19 Чтв 13:37:50 1388416197
>>1387462
Кому очевидно, тебе?
25/04/19 Чтв 15:06:17 1388459198
>>1388067
> 99.9% малварей требуют глубокого статического анализа
> Ржали всей лабораторией.
Присоединяюсь. 90% малвари состоит из необфусцированного копипастного кода, написанного школьниками на переменах. Глубокий анализ такого заключается в strings virus.exe|grep http. Еще несколько процентов - это вариации на тему ксора с коротким ключом, иногда со скопипащенным из какого-нибудь метасплоита кодом поиска апи по хэшам, но внутри все тот же говнокод. Сколько-нибудь интересные сэмплы очень редки. Ковыряться в этом однообразном говне годами может только совершенно больной человек, даже у JS-макаки жизнь интереснее, чем у вирусного аналитика.
Аноним 25/04/19 Чтв 17:00:45 1388523199
>>1388459
Видать в пидорашке любая отрасль идет с 20-ти летним дилэйем как минимум. Держу в курсе, в 2к19 в цивилизованных странах с таким школьным говном имеют дело программы по анализу вредоносного кода, которые детектят недомалвари в строках, копипасты инфекторов исполняемых файлов и прочее дерьмо.
Анон, интересно, откуда у тебя такие мысли. Только если ты не вирусный аналитик в лаборатории Касперского, но если там такая дичь творится, то земля вам пухом там, хуле
25/04/19 Чтв 19:18:02 1388660200
>>1388523
> Только если ты не вирусный аналитик в лаборатории Касперского
Нет, я с дивана, а ты в целом прав.
Аноним 25/04/19 Чтв 19:57:42 1388697201
>>1388523
сам то чьих будешь где работаешь что такими заявлениями кидаешься? Живешь в каком то маня мирке.
я вот много где посмотрел, вирусная налитика именно такая копипаста как выше тебе уже пояснили. Анализ чего то сложного и интересного. это настолько редко что охереть как.
Аноним 25/04/19 Чтв 22:43:53 1388811202
>>1388459
>>1388697
Да никто не сидит там по 2 года, делая однообразную хуйню. Такой же карьерный рост как и везде. После полугода-год тебя начнут закидывать прикольными тасками, будешь выезжать на конфочки/хакатоны итд.
Аноним 25/04/19 Чтв 22:53:18 1388816203
>>1388459
>>1388115
Вам если сэмп с сискаллами + кастом пакером + вм дадут, побежите сразу к старшему с криками:
>ряяя нипохукать! ряяя нидампица! ряяя где оеп вапще?
Аноним 26/04/19 Птн 00:54:52 1388876204
>>1388811
>После полугода-год тебя начнут закидывать прикольными тасками, будешь выезжать на конфочки/хакатоны итд.
А через два года начнёшь получать 300кк в наносекунду.
Аноним 26/04/19 Птн 01:28:54 1388896205
26/04/19 Птн 02:03:49 1388903206
26/04/19 Птн 13:29:21 1389079207
>>1388903
Не факт, может стилер, лол
185.170.43.187/jjj888/skghn.php
26/04/19 Птн 13:35:19 1389080208
>>1389079
А не, это внезапно майнер.

[MINING]
pool = 185.170.43.187:8080 ; pool address
wallet = 83VL4uUXJynELY1oc7vqwmdG5L4ykZYtb4XjbYDkDvDvF9Chh7xMZJy4FTPuSEUfYGTBJCFoH6qBcVV1AFakRHjeRPu7hKL
pass = x
proxy = false

[CPU]
cpubase_usage = 20 ; Basic power
cpuidle_usage = 90 ; IDLE power

[GPU]
gpubase_usage = low ; 40% aka basic power
gpuidle_usage = high ; 100% aka IDLE power
Аноним 26/04/19 Птн 13:37:17 1389082209
Сап котаны
Объясните ньюфагу, каким образом дрова исполняются в кольце 2 и 1, и каким образом он исполняются без ведома владельца пк? В общих чертах хотя бы, а то путаница насчет этого
Чуется мне, что все буткиты/руткиты - это малварь, завернутый в нечто похожее на драйвер, чи да?
Аноним 26/04/19 Птн 18:16:22 1389247210
>>1389079
Там чего только веселого не гуглится по этому айпи.
26/04/19 Птн 18:37:27 1389281211
>>1389082
> дрова исполняются в кольце 2 и 1
Никаким. Это влажные мечты Intel, которые никому не пригодились. Пользовательский софт в r3, все остальное в r0.

> В общих чертах хотя бы
> каким образом он исполняются без ведома владельца пк
Процессор при запуске ОС (опустим переключение в защищенный режим) начинает исполнять код в r0. Таким образом ядро ОС исполняется в r0, и оно может, грубо говоря, менять уровень привилегий при переключении потоков (задач), может вместе с процессором изолировать память различных задач, а процессор не дает задачам из r3 исполнять привилегированные инструкции. А вот владелец пека вообще ничего не может, он устройство ввода, его можно даже не опрашивать.

> буткиты/руткиты - это малварь, завернутый в нечто похожее на драйвер
Да, но драйвер - это файл, который работает с системой по какому-то определенному апи и сам предоставляет какие-то интерфейсы, а руткит может не быть файлом или не использовать стандартные апи для драйверов.
Аноним 26/04/19 Птн 18:59:31 1389312212
>>1389281
>а руткит может не быть файлом или не использовать стандартные апи для драйверов.

Это ломает мой девственный мозг новичка, как код может быть исполнен, если он не файл? Из-под чего он исполняется, где хранится код зловреда?
Или руткит инжектят каким-то раком в бут сектор и он хранится, не имея при этом файла, который содержит исполняемый код, тупо запускаясь вместе с ОС при включении компа? А что творится на уровне гипервизора или SMM я пока тоже не представляю.
Аноним 26/04/19 Птн 19:43:40 1389341213
image.png (60Кб, 536x398)
536x398
>>1389082
Смотри пикрил. Обычный юзер ты, твои приложухи, игрухи, итд находится в VTL 0 пользовательском режиме ring3. Драйверымышки, клавиатуры, системные и прочее находятся в VTL 0 режиме ядра ring0, тут же сидят и руткиты/буткиты.
Руткиты - это и есть драйверы, то есть pe-файл с расширением .sys. После отображения в ядро могут скрыть себя множеством способов. С расширением архитектуры винды и добавлением внутренних механизмов защиты, их действия сильно ограничены.
Windows Internals 6 или 7 издание почитай, много чего узнаешь.

>>1389281
>а руткит может не быть файлом или не использовать стандартные апи для драйверов
Апи ядра они используют, без этого никак и функции легитимных/системных драйверов.


Аноним 26/04/19 Птн 20:11:33 1389363214
Аноним 26/04/19 Птн 20:16:52 1389366215
>>1389079
обьясните алгоритм,хотя бы
у меня при циклах каждый раз где-то все наебывается и выходит полная залупа,а не нужный результат
и биткойн кошель кидайте сразу)
Аноним 26/04/19 Птн 21:10:13 1389388216
>>1389366
>обьясните алгоритм,хотя бы
XOR
Аноним 26/04/19 Птн 21:59:31 1389430217
>>1389341
Зачем шестое читать, оноже старое
Аноним 26/04/19 Птн 22:01:15 1389434218
Объясните по дескрипторам потоков/процессов, в книгах фашиста и таненбаума не могу ничего этого найти. Какую книгу читать тогда?
Аноним 26/04/19 Птн 22:23:11 1389458219
>>1389430
В идеале и 6 и 7 прочитать, чтобы прощупать логику маломягких.

>>1389434
Windows Internals. Очень подробно разбираются процессы и потоки, страниц на 300 все очень детально разжевано.
Аноним 26/04/19 Птн 22:26:05 1389460220
>>1389458
И я так полагаю, в книге по ядру линукса тоже есть такое?
Аноним 26/04/19 Птн 22:26:13 1389461221
>>1388896
Может ты ссылку на файл кинешь?
Аноним 26/04/19 Птн 22:27:33 1389462222
>>1389460
Тебе про линукс надо? Тогда не знаю, гугли сам. Нахуй линукс, все деньги у майков.
Аноним 26/04/19 Птн 22:29:10 1389465223
>>1389462
Виндовс само собой, а линукс для души.
Аноним 26/04/19 Птн 22:37:49 1389471224
Аноним 26/04/19 Птн 23:37:10 1389499225
>>1389471
>понадобилось крякнуть программу
Ты дурачек?
Аноним 27/04/19 Суб 00:18:56 1389523226
>>1389499
>вообщем нужно написать декриптор для этой штуки
Аноним 27/04/19 Суб 00:21:12 1389524227
>>1389499
со всем остальным,кроме этого метода,у меня все окей
нужно просто написать декриптор для этих строчек,чтобы можно было бы переводить их в url и обратно
извиняюсь,могу тупить,время позднее
Аноним 27/04/19 Суб 00:59:00 1389533228
Котаны, посоветуйте плиз нормальный сорс, откуда можно почитать/посмотреть про хукинг, желательно на английском, а то все как-то не очень объясняют или это я прост тупой, ГЫ
Аноним 27/04/19 Суб 04:10:48 1389565229
>>1389524
Но ведь это C#, Карл. Почему ты просто пропатчить бинарник не можешь?
Аноним 27/04/19 Суб 09:36:34 1389605230
>>1376951
Программист перед сном ставит на тумбочку два стакана. Один с водой, если захочет пить, а второй пустой, если не захочет.
Аноним 27/04/19 Суб 17:39:32 1389957231
>>1389605
Отличная шутка.
Так как собственный импорт сбилдить на С/C++ в visual studio?
Аноним 27/04/19 Суб 18:26:11 1390024232
>>1389957
Что? Поясни, что значит "импорт сбилдить"? Сгенерировать таблицу импортов? Слинковаться с длл? Сделать библиотеку импорта?
Аноним 27/04/19 Суб 19:33:37 1390099233
>>1390024
Да я сам не знаю. Просто хочу чтобы при просмотре любым pe-viewer'ом в таблице импорта моего хеллоу ворлда отображалось три kernel32.dll
Аноним 27/04/19 Суб 23:24:02 1390255234
>>1390099
Фасм:
format pe gui
entry start
include 'win32w.inc'

start: invoke ExitProcess,0
_ = VirtualAlloc ; "Use" function to prevent fasm from removing it from imports.
_ = CreateFile

data import
library kernel32_1,'KERNEL32.DLL',kernel32_2,'KERNEL32.DLL',kernel32_3,'KERNEL32.DLL'
import kernel32_1,ExitProcess,'ExitProcess'
import kernel32_2,VirtualAlloc,'VirtualAlloc'
import kernel32_3,CreateFile,'CreateFileW'
end data
Аноним 28/04/19 Вск 03:52:57 1390390235
>>1389312
>как код может быть исполнен, если он не файл?
Банально уязвимость в сетевом стеке, типа большой пакет озалупливает ОС, и она передаёт управление куда-то внутрь этого пакета. Файла нет, а троян есть.
>>1389312
>А что творится на уровне гипервизора или SMM я пока тоже не представляю.
И не надо, есть IME, который имеет вышеперечисленных.
Аноним 28/04/19 Вск 11:02:46 1390450236
>>1390390
>Банально уязвимость в сетевом стеке, типа большой пакет озалупливает ОС, и она передаёт управление куда-то внутрь этого пакета.
Эмм, содержимое такого пакета парсится как строка? Поэтому и сам зловред представляет собой строку? (условно, скрипт баша/мелкомягкой силаскорлупы) Просто если там обычный код, который нужно, офк, скомпилировать перед исполнением, то мне сложно представить как этот троян исполнится.
>И не надо, есть IME, который имеет вышеперечисленных.
Не буду кривить душой, не раздуплил причем здесь софт, который позвляет вводить символы, которых нет на клаве
28/04/19 Вск 11:59:02 1390474237
Это просто троллинг тупостью
Аноним 28/04/19 Вск 12:29:26 1390479238
>>1390450
>Эмм, содержимое такого пакета парсится как строка?
Причём тут строки? Мы про бинари.
>>1390450
>Не буду кривить душой, не раздуплил причем здесь софт, который позвляет вводить символы, которых нет на клаве
https://ru.wikipedia.org/wiki/Intel_Management_Engine
Аноним 28/04/19 Вск 12:44:56 1390487239
>>1390479
>Причём тут строки? Мы про бинари.
До сих пор не понимаю как можно пропихнуть бинарник в пэйлоуде пакета, да чтобы он еще и запустился. Только если это не dll/so, который должен экспортироваться в какой-то процесс и нагадить.
>https://ru.wikipedia.org/wiki/Intel_Management_Engine
Спасибо, раздуплил.
Аноним 28/04/19 Вск 12:46:03 1390490240
>>1390479
А это просто тупой, попавшийся на троллинг тупостью.
Аноним 28/04/19 Вск 12:46:20 1390491241
Аноним 28/04/19 Вск 18:49:43 1391094242
>>1390479
Тебя спрашивают про архитектуру винды, а ты ему железячную
фигню пихаешь, о которой ньюфагу еще последующие лет 5 не придется думать даже.

>>1390487
Тебе нужно перестать думать юзермодными абстракциями и загуглить что такое произвольное выполнения кода, переполнение буфера.
У тебя задача вообще какая стоит? Или ты просто исследуешь? Так исследуй блеать! Виртуалку поднял, виндбг подрубил, основные модули в иде открыл, а дальше уже само пойдет.
Аноним 28/04/19 Вск 20:18:23 1391171243
>>1391094
>Тебя спрашивают про архитектуру винды, а ты ему железячную
Больше половины ответа про винду, гений.
Аноним 28/04/19 Вск 21:09:56 1391205244
>>1391094
Ламповый асембли уже давно в тред элитистов превратился. Щас в сипп треде обсуждение асм живее чем тут
28/04/19 Вск 22:37:44 1391249245
>>1391205
Он никогда особенно живым и не был.
Аноним 29/04/19 Пнд 05:47:10 1391345246
>>1391205
Врешь. Сижу в С и С++ тредах, там одни ньюфаги просят помощи с laba_001.sln, ничего серьезного даже близко не обсуждают.
Аноним 29/04/19 Пнд 10:50:48 1391429247
>>1385993
Решил проблему , переустановкой шиндовс.
как же я блять не навижу ебаный шиндовс
Аноним 29/04/19 Пнд 16:16:28 1391589248
>>1388896
бамп реквесту,сразу кидайте свой биткойн кошелек как напишите - кину что есть
нужна консольная прога,которой можно дешифровать это и наоборот- шифровать нужные строки в этот вид
Аноним 29/04/19 Пнд 17:05:40 1391616249
>>1391589
Тебе уже сказали, там банальный XOR по кругу.
Аноним 29/04/19 Пнд 17:08:32 1391622250
>>1391616
я обсираюсь с этими циклами все время и мне выводит какую-то хуйню
поэтому и прошу
Аноним 29/04/19 Пнд 17:15:17 1391626251
>>1391622
Билят.
s=Base64decode('DxEBFw4dF0RfQUZDXlZGWkBEVFBDRBgNCFJLUEoUCVQPC1sXXEI=')
key='geug428ugthrifhnsjehtkrgbjshegb3'

а потом каждый байт xor

res=s[l] ^ key[j]

l от нуля до длины получившихся данных
j = strlen(key); if j>strlen(key) {j = 0}
Аноним 29/04/19 Пнд 17:23:41 1391632252
test
Аноним 29/04/19 Пнд 17:30:15 1391636253
>>1391626
>j от нуля до strlen(key); if j>strlen(key) {j = 0}
слоуфикс
Аноним 29/04/19 Пнд 17:58:00 1391657254
>>1391636
import base64

s=base64.b64decode('DxEBFw4dF0RfQUZDXlZGWkBEVFBDRBgNCFJLUEoUCVQPC1sXXEI=')
key='geug428ugthrifhnsjehtkrgbjshegb3'
y=0
res=[]

for x in range(0, len(s)):
res.append((chr(ord(s[x])^ord(key[y]))))
y+=1
if y==len(key): y=0;

print(''.join(res))
Аноним 29/04/19 Пнд 18:32:11 1391673255
>>1391636
спасибо
>>1391657
не робит,но все равно спасибо,алгоритм понял
Аноним 29/04/19 Пнд 18:53:22 1391682256
>>1391657
Сколько лишних слов!
s = base64.b64decode(...)
key='...'
print(bytes(a ^ b for a, b in zip(s, itertools.cycle(key.encode()))).decode())
Аноним 29/04/19 Пнд 19:11:05 1391693257
>>1391682
хотел помочь нуждающемуся,но назад выходит другой результат
делаю тоже самое,но в обратном порядке,в чем подвоха?
мимо
Аноним 29/04/19 Пнд 19:13:09 1391695258
>>1391693
человеку вроде же как нужен был и шифратор и дешифратор под это дело?
в любом случае,интересно в чем ошибка
в криптографии ноль
Аноним 29/04/19 Пнд 19:14:07 1391696259
Реверсач, выручай
Немного путаница с import address table.
До биндинга import lookup table и import address table указывают на один и тот же адрес (каждый энтри). После биндинга, каждый энтри в import address table меняется на указатель на функцию в дллке (это я понял), но при этом также меняется указатель в каждом энтри import lookup table после биндинга, почему? И нахуя нужен Хинт?
Олсо, указатели на функции в энтри IAT после биндинга - это же VA, а не RVA, я правильно понимаю?
Аноним 29/04/19 Пнд 19:21:08 1391698260
>>1391673
>не робит,но все равно спасибо,алгоритм понял
Это питон 2.7 если что.
>>1391693
Я слабо знаю эти ваши пистоны, а за ''.join ваще бы убивал, но иногда вот приходится на нем писать под себя.
Аноним 29/04/19 Пнд 19:31:55 1391707261
Аноним 29/04/19 Пнд 22:19:16 1391817262
>>1391696
> но при этом также меняется указатель в каждом энтри import lookup table
Не должно такого быть, оно же загрузку сломает. Возможно, линкер делает такую таблицу, где FirstChunk и OriginalFirstChunk указывают на одну и ту же цепочку? Фасм таким страдал раньше. Так-то не должно. Попробуй на другом файле.

> И нахуя нужен Хинт?
Чтобы не выполнять двоичный поиск по таблице в таблице имен в экспортах дллки, а сразу попробовать элемент с указанным индексом. Если таблица экспорта в целевой длл не менялась с момента линковки ссылающегося на нее модуля, получается лукап экспорта за O(1) вместо O(log n). Если менялась... а я вот не знаю, используется ли это значение в качестве первого индекса в двоичном поиске, или оно в таком случае с середины начинает? Cам посмотри реализацию, если интересно.

> это же VA, а не RVA, я правильно понимаю
Да, прибито гвоздями к расположению модулей в памяти и поэтому бесполезно во времена ASLR.

>>1391698
> Это питон 2.7 если что.
Это часы, если что: https://pythonclock.org/ Тик-так.
Аноним 29/04/19 Пнд 22:26:42 1391820263
Аноним 29/04/19 Пнд 23:31:10 1391838264
image.png (51Кб, 146x220)
146x220
Аноним 30/04/19 Втр 02:45:40 1391882265
1355435053367.jpg (13Кб, 359x293)
359x293
Аноним 02/05/19 Чтв 11:42:55 1392929266
Не могу понять как память устроена в винде. Какие-то страницы PML4, PDE, PTE и еще дофига всего там. Для чего это нужно вообще все? Где почитать можно?
Аноним 02/05/19 Чтв 15:16:19 1392980267
Суп, реверсач
Тут есть анонс со знанием ARM?
В плане архитектуры, ассемблера и прочего будет полегче, чем х86? В плане порога вхождения
Аноним 02/05/19 Чтв 15:52:04 1392993268
>>1392980
Ну вот смотри: в ARM вместо одного - два с половиной набора инструкций, всякие DSP-расширения с кучей однообразных арифметических инструкций, выносящие мозг псевдоинструкции (или ебля со сборкой констант по кусочкам, что еще хуже), режимы адресации, которые сложнее, чем в x86, и это все только "обычный" 32-битный код в юзермоде. Плюс AArch64, который по сути отдельная архитектура. Плюс десятки разнообразных, сложных и несовместимых между собой механизмов, про которые нужно знать, если ты соберешься писать под bare metal.

x86 в целом легче, потому что куча софта и информации на любой вкус, потому что локально отлаживаться проще.
Аноним 02/05/19 Чтв 18:24:19 1393091269
>>1392929
Внутреннее устройство Microsoft Windows любого издания.
Аноним 03/05/19 Птн 14:16:23 1393411270
Гайс, чем Линукс легче Винды в плане системного программирования и архитектуры операционной системы в принципе?
Аноним 03/05/19 Птн 14:24:44 1393418271
>>1393411
Не надо линукс, под него непрофитно писать вирусы.
Аноним 03/05/19 Птн 14:36:36 1393423272
>>1393411
> чем Линукс легче Винды
В линуксе компилятор в комплекте. В винде устанавливается за пять минут. Все остальное в винде проще.
Аноним 03/05/19 Птн 14:56:06 1393434273
>>1393411
Во всем он проще + опенсурс.
03/05/19 Птн 16:16:00 1393462274
>>1393434
Исходники винды тоже частично доступны, и качество кода там не в пример лучше. Плюс есть исходники реактос.
Аноним 03/05/19 Птн 16:43:41 1393470275
>>1393418
Щас бы в 2к19 писать вирусы, не будучи при этом госслужащим, которому за это ничего не будет))
>>1393434
Один говорит винда проще, ты говоришь, что Линукс. Аргументы есть?
Аноним 03/05/19 Птн 20:04:21 1393530276
>>1393470
Окей, давай пойдем другим путем. Расскажи нам, что ты понимаешь под системным программированием. Ты хочешь писать юзермодные утилиты? Компиляторы? Драйвера? Ты хочешь дергать за ноги малинку из баш-скриптов?
анон, который предлагал винду
Аноним 03/05/19 Птн 20:18:15 1393538277
>>1393530
Компиляторы и дрова, допустим.
Аноним 03/05/19 Птн 21:24:13 1393559278
Где-нибудь имеются сэмплы вирусов под винду, написанных на современном C++, а не на C++ в стиле C?
Аноним 03/05/19 Птн 23:27:50 1393607279
>>1393462
Все равно придется долго сидеть с идой/виндбг. Реактос спасает, да. Майки тоже молодцы, начали пилить сэмплы и доки нормальные.

>>1393538
Все бабки у майков. А чего ты собрался драйвера-то писать если чего полегче ищешь, лол?

>>1393559
Смысл писать малварь на современном С++? Только если это не полноценный модульный бот. Если тебе надо, то возьми и сам перепиши, какой-то глупый реквест. А лучше не пиши, набутылят, будешь потом плакать.

Аноним 04/05/19 Суб 00:35:31 1393646280
Хз че тут за винду топят аноны, как это дерьмо вообще можно учить?
Обрыганный и кривой реестр, миллиард API функций, половина из которых имеют по несколько лишних пермутаций. Обрыганское, совершенно конченное строение бинарников и обратная совместимость с никому не нужным говном мамонта. Учить Windows Internals == быть мазохистом
Аноним 04/05/19 Суб 00:52:25 1393649281
>>1393646
Ты так говоришь потому что сам нифига не разобрался. Если бы глубже изучал, то понял бы что все это необходимо и это нифига не костыли, а фичи!
04/05/19 Суб 03:53:44 1393683282
>>1393646
> миллиард API функций
Вот в линуксе другое дело - чтобы получить карту памяти процесса, нужно всего лишь написать парсер текстового файла. Это гораздо удобнее, чем запоминать всякие там VirtualQuery!

> Обрыганское, совершенно конченное строение бинарников
Вот в линуксе другое дело - в эльфах есть сегменты и секции, на секции лоадеру насрать, но тем не менее большинство файлов их с собой таскают. Эльфы грузит как бы ядро, но это пока эльфы не с динамической линковкой. В этом случае эльфы грузит (и заново парсит, блять) как бы ld, но как бы не всегда. А формат как бы ОТКРЫТЫЙ и документированный, но сплошь и рядом objdump -d показывает хуй, а readelf так и вообще сегфолт.

> обратная совместимость с никому не нужным говном мамонта
Вот в линуксе другое дело - чтобы скопировать с машины на машину программу, нужно просто взять исходники и скомпилировать программу на целевой машине. Ой, попутно еще поставить перл для мэйка, графические либы для перла, ффмпег для графических либ, иксы для ффмпега... ой, вот уже и гном на машине завелся. А по-другому никак, совместимость ведь не нужна, в глибц опять поправили оформление кода и бампнули версию - пересобирай свои хелловорлды, тебе заняться нечем. А хочешь ебаться по-особому - попробуй линковаться статически, тебе обязательно понравится!
Аноним 04/05/19 Суб 04:35:00 1393686283
Я иногда в ахуе. Как люди, пишущие про "МИЛЛИАРД ФУНКЦИЙ" смогли хотя бы основные функции/методы стдлибы своего ЯП запомнить?
Аноним 04/05/19 Суб 06:00:13 1393694284
>>1393686
Ну вот, например, я пишу на сишке больше 15 лет, но до сих пор не помню порядок количеств и размеров в calloc() и fread(). И ведь это всего лишь сишка, где в стандартной либе полторы функции.
Аноним 04/05/19 Суб 06:58:39 1393698285
>>1393686
А зачем? IDE подскажет. Они без неё даже Hello World без ошибок не напишут.
Аноним 04/05/19 Суб 12:13:03 1393752286
Щас бы быдлоспоры по поводу ОС начинать :-)
Хочешь заниматься вирусной аналитикой - грызи винду и желательно х86 архитектуру.
Хочешь заниматься встроенными системами, мобайл, интернетом вещей - грызи Линукс и желательно ARM архитектуру вдовесок.
Для каждой ОС есть своя область применения. Винда вечно будет популярна среди обычных юзеров, ибо это GUI oriented ОС, и 90% вирусов будет писаться именно под винду. Линукс же всегда будет доминировать на серверах и в мобилах+имбэддэд.
Точно также и со срачем х86 и ARM. Будем откровенными, ARM никогда не догонит х86 по производительности, а х86 не станет никогда такой же энергоэффективной, как ARM.
Два абсолютно разных, несовместимых друг с другом рынка.
Аноним 04/05/19 Суб 14:59:48 1393820287
>>1393694
По-моему базовая либа си последнего стандарта, независимо от компилятора в себе только хедеров штук 20 несёт. А в GCC так вообще сразу ставится glibc с тысячами функций не считая алиасов
Аноним 04/05/19 Суб 15:15:30 1393827288
>>1393820
Ну я преувеличил, конечно, но в стандартной либе математика в основном, и еще wide-функции. А "обычных" часто используемых функций не так уж и много. И все это меркнет в сравнении с крестами или какой-нибудь джавой, которую, кажется, никто полностью не знает.
Аноним 04/05/19 Суб 17:59:30 1393908289
>>1393686
А ты сидел и ботал все это? Ну и лох, иде и гугл все подскажет если надо будет. Гораздо важнее запоминать технологии, как писать код можно, а как нельзя и другие фундаментальные вещи.
Аноним 04/05/19 Суб 18:57:28 1393950290
>>1393752
Вирусный аналитик должен знать и то и другое. Сидя на одной ОС далеко не уедешь.
Аноним 04/05/19 Суб 19:46:20 1393989291
Кто-нибудь пытался написать свой протектор? Или все вмпротекту доверяют? Начал писать пакер и понял, что все это бесполезно без нормального антидампа. Но как вообще можно предотвратить дамп? Scylla легко дампит и фиксит дамп на раз два.
Аноним 04/05/19 Суб 20:02:16 1394002292
А где вообще можно почитать о том, как с нуля написать простую навесную защиту с виртуализацией?

https://www.oreans.com/codevirtualizer.php
Аноним 04/05/19 Суб 20:10:38 1394010293
>>1394002
Где почитать не знаю, погугли llvm.
Аноним 04/05/19 Суб 20:29:10 1394020294
>>1393908
>гораздо важнее
Разве что если ты джун-макака в ООО "Вазгенян Мессенджер" и не хочешь получить пизды от амбициозного тимлидера Заура Камазовича.
Только, в таком случае непонятно что ты забыл а этом треде
Аноним 04/05/19 Суб 20:37:18 1394024295
>>1394020
С++ уже наизусть весь выучил? Несешь хуйню. Я никогда в жизни не учил питон, яву и шарп, но если что-то нужно написать на этих яп, то беру и пишу без задней мысли с помощью доков. Зачем мне учить все это объясни пожалуйста. Еще раз повторяю, гораздо важнее ботать технологии, а не сам яп.
Аноним 04/05/19 Суб 20:49:57 1394036296
>>1394024
А потом
>Сап двач чё за хуйня с этой виндой тупой блин нихуя не понимаю почему мой 2 мегабайтный софт крашит систему
Аноним 04/05/19 Суб 21:29:51 1394066297
142231.jpg (269Кб, 1009x1200)
1009x1200
Сап, низкоуровневые. Есть ли какая-то разница в int 20h и 4Ch функции int 21h? По описанию они одинаковые, вроде, есть причины использовать какой-то определенный выход из программы?
Аноним 04/05/19 Суб 21:57:20 1394087298
>>1394036
Сам себе противоречишь.
Аноним 04/05/19 Суб 23:44:10 1394211299
Знающие, подскажите. Хочу что бы при запуске мой комп начал выполнять инструкции с флешки и нарисовал что то на экране. Все что я нахожу под древние архитектуры, а хочется по x64
Аноним 05/05/19 Вск 01:56:40 1394299300
05/05/19 Вск 02:11:59 1394307301
>>1393989
Какой толк с дампа, если код виртуализован? Да хотя бы если он просто расшифровывается перед выполнением и шифруется после? Ты должен предполагать, что виртуальное адресное пространство и системные вызовы полностью под контролем реверсера, а всякую антиотладку прикручивать лишь для того, чтобы киддисам не скучно было.

>>1394066
Да, есть разница. Для int 20h CS должен указывать на PSP, а еще ты не можешь вернуть статус в ОС.

>>1394211
> хочется по x64
LMGTFY: https://wiki.osdev.org/Entering_Long_Mode_Directly
Удачи с рисованием на экране без прерываний, в защищенном режиме и без малейшего понимания основ.
Аноним 05/05/19 Вск 02:36:52 1394311302
>>1390255
Спасибо. В визуал студио по аналогии можно такое линкером наколдовать наверное. Есть умельцы итт?

Еще интересует сборка TLS без использования CRT, такое возможно вообще?
Аноним 05/05/19 Вск 02:54:24 1394315303
>>1394307
Думаю ты прав. Можешь посоветовать что в приоритете, на что в первую очередь стоит обратить внимание? Виртуализация? На данный момент имею:
Обычный pe-лодырь, как вот тут: https://kaimi.io/2012/09/pe-packer-step-by-step-1/
Антиотладочные трюки из книги The_Ultimate_Anti-Reversing_Reference 2011 года. Не знаю зачем тратил на это время, абсолютно все обходится плагином Scylla Hide. И парочку трюков с гитхабов/блогов.
Убрал все лишние зависимости, все возможные вызовы апи заменил сискалами. Что дальше делать не знаю.
Аноним 05/05/19 Вск 09:22:01 1394363304
Аноним 05/05/19 Вск 13:31:41 1394445305
>>1394315
>Думаю ты прав. Можешь посоветовать что в приоритете, на что в первую очередь стоит обратить внимание? Виртуализация?
Накидайте мануалов по виртуализации кода. Я написал простую VM и ассемблер нескольких инструкций для нее, но дальше не знаю, что делать. Хочу запилить йоба-криптор.
Аноним 05/05/19 Вск 16:02:45 1394509306
>>1393989
>Но как вообще можно предотвратить дамп?
Рискну предположить, что нужно пидорасить хэдеры и код распаковщика/декриптора перез передачей управления защищаемой программе. Естессно, это можно зареверсить и дампнуть в момент, когда образ загружен, но хэдеры еще не пидорнуты. Тут в бой вступает антиотладка, обфускация и тд
Аноним 05/05/19 Вск 16:59:02 1394539307
может кто дать пару подсказок как лучше написать задачу?прога стирающая экран при появлении сочетания латинской буквы "r" после любой цифры
Аноним 05/05/19 Вск 18:32:52 1394577308
Как во встроенном ассемблере вижуал студии зарезервировать байты более коротким способом, чем __emit, и чтобы инструкции резервирования можно было размещать по нескольку штук на одной строке?

__declspec(naked) void Shellcode()
{
__asm
{
pushad
call DeltaOffset
DeltaOffset:
pop ebp
sub ebp, offset DeltaOffset
lea eax, [ebp + dllPath]
push eax
mov eax, 0xEEEEEEEE
call eax
popad
push 0xEEEEEEEE
retn

dllPath:
__emit('C')
__emit(':')
__emit('\\')
__emit('\\')

}
}
Аноним 05/05/19 Вск 18:39:09 1394584309
>>1394577
Попробую сделать макрос #define b(byte) __asm __emit
Не знаю, будет ли работать вложенная инструкция __asm внутри другого блока __asm
Аноним 05/05/19 Вск 19:19:40 1394602310
Как обрабатывать ошибки при заражении файла? В своем инфекторе для удобства я создал структуру:

struct FileInfo
{
....HANDLE hFile;
....HANDLE hMapping;
....LPBYTE hView;
....DWORD dwFileSize;
};

Функция открытия файла возвращает эту структуру. Если hFile == INVALID_HANDLE_VALUE, бросать исключение или возвращать пустую структуру?

Аноним 05/05/19 Вск 20:17:48 1394623311
>>1394602
Поделитесь своими вкусами и мнениями об исключениях в лоу-лвл коденке. Нужны ли они или лучше писать goto cleanup как писали деды?
Аноним 05/05/19 Вск 22:25:27 1394653312
>>1394602
>заражении файла
Ты в нулевых застрял?

>бросать исключение или возвращать пустую структуру
Возвращать NULL.

>>1394623
Как эти вещи вообще связаны? Исключения нужны, без них никак.

>>1394577
Ты что делаешь вообще? Уверен что хочешь писать путь как C:\\ ? Я бы не стал.

Аноним 05/05/19 Вск 23:49:02 1394675313
15281432191660.mp4 (23971Кб, 1280x720, 00:01:18)
1280x720
Аноним 06/05/19 Пнд 00:21:49 1394681314
>>1394675
Подтерся твоей прогой и пошел спать, завтра продолжать строить реальные решения для бизнеса, чем заниматься ассемблированием своего очка.
Аноним 06/05/19 Пнд 01:26:10 1394692315
Стикер (0Кб, 512x512)
512x512
>>1394681
>реальные решения для бизнеса
>asm thread
Даа...
06/05/19 Пнд 01:51:12 1394696316
>>1394311
> В визуал студио по аналогии можно такое линкером наколдовать наверное
Сложно. Вероятно, нужно слинковаться с old-style импорт-либой или с либой, включающей в себя old-style импорт. Других идей у меня нет.

> TLS без использования CRT, такое возможно вообще?
Да, гугли магический символ __tls_used.

>>1394315
>>1394445
Никогда не писал протекторы, но как бы бери llvm ir, или бери capstone и дизассемблируй, превращай инструкции в инструкции своей вм, все в твоих руках. Алсо, погугли мануалы и сдк коммерческих протекторов. Например, как там вызовами функций протектора "размечается" защищаемая функция.

>>1394509
> пидорасить хэдеры
Любые хедеры можно пересоздать с нуля. Например, распакованный регион адресного пространства сдампить одним куском и сделать одной секцией. Да и много ты не напортишь. Чтобы системный лоадер работал, экспорты должны быть на месте, чтобы ресурсные функции работали, ресурсы должны быть на месте, и так далее.

>>1394577
> во встроенном ассемблере
Нинужно, ниподдерживается, делай отдельный асм-файл.

>>1394602
> ....HANDLE hFile;
> ....HANDLE hMapping;
Нинужно. Можно закрывать оба сразу же, как только создал вью.

> заражении файла
Репорт за малварь.

>>1394623
Да, ничего плохого в goto в данном случае нет.

>>1394653
> Исключения нужны, без них никак
Как это никак? setjmp лол.
Аноним 06/05/19 Пнд 17:54:14 1394828317
>>1394696
>Любые хедеры можно пересоздать с нуля.
А если пидорасить ОЕР еще при упаковке и восстанавливать в TLS коллбэке и потом еще пидорасить CRT startup в отдельном треде после запуска?
>Чтобы системный лоадер работал, экспорты должны быть на месте, чтобы ресурсные функции работали, ресурсы должны быть на месте, и так далее.
Так речь же идет об упаковщике, как я понял. Распаковщик берет на себя задачи системного лоадера же. Он же может и пидорасить что нибудь после того, как отработает, не?
Аноним 06/05/19 Пнд 17:55:16 1394830318
>>1394828
TLS коллбэки палятся антивирусами.
Аноним 06/05/19 Пнд 17:57:19 1394831319
>>1394830
Ну речь же о протекторе, в продакшне то софтина может и подписываться будет.
06/05/19 Пнд 19:14:15 1394847320
>>1394828
> Он же может и пидорасить что нибудь после того, как отработает, не?
Разве что импорты, но (в простом варианте) IAT все равно останется, и останется одним куском, любой дампер импорты восстановит. Экспорты окончательно ломать нельзя: другая длл сделает GetProcAddress(GetModuleHandle("твоя_dll_или_exe"), "func"), а экспорты распидорашены. Ресурсы ломать нельзя: ты сам делаешь DialogBoxParam, а ресурсы распидорашены. Это все решаемо, конечно.

> CRT startup
По-моему, Themida раньше так делала. Да и вообще, можно просто взять у нее чеклист: https://www.oreans.com/winlicense_features.php
Аноним 06/05/19 Пнд 21:11:21 1394889321
>>1394847
Можно хоть весь хэдер затереть, если он не будет использоваться, сохранять его в каком-нибудь месте и восстанавливать по-надобности.

>>1394830
Что за бред? Секция TLS ни о чем не говорит, это стандартная фича винды, ею пользуются почти все продвинутые десктоп приложения.

Вообщем анон выше прав, трюки все эти хорошо, но если вместо кода будет мусор, на разбор которого уйдет месяцок другой, вот это будет действительно неприятно ковырять крэкеру.
Аноним 07/05/19 Втр 00:37:06 1394956322
image.png (574Кб, 477x630)
477x630
Аноны, книга вышла пикрилейтед. Кто-нибудь знаком с творчеством сей авторов? Стоит брать, как считаете?
Аноним 07/05/19 Втр 00:37:26 1394957323
>>1394681
Ой блять, реальное решение для бизнеса у него, у меня вот сейчас реально реальное решение для бизнеса. Высокоуровневые просто обосрутся от такой задачи, она простая но они обосрутся. А если не обосрутся, то всё будет дико тормозить.
Но мой пост был не о этом. А о том что ассемблер нужно !обуздать!. Ассемблер не хочет чтобы его изучали, он хочет работать.
Аноним 07/05/19 Втр 01:52:55 1394982324
>>1394957
В результате моих действий, в конце-концов, пострадают плохие люди, плохие иженеры(и не иженеры вовсе). Которые сейчас потирают свои грязные ручёнки в ожидании большого(огромного) куша от моей конторы, но скоро им прийдёт сообщение: в ваших услугах не нуждаемся. Ниже я опишу что такое плохой инженер.
Плохой инженер не делает технику, не ремонтирует технику. Плохой инженер занижает цену на ремонт, потому что он, сука хитрая, просчитал что ему выгоднее из 10 аппаратов сделать 3 с очень лёгкой поломкой, а к остальным найти отмазку вроде Ремонту не подлежит.
СУКА, КАКЖЕ Я НЕНАВИЖУ ЭТИХ ПИДАРЮГ.
И сейчас эти пидары потюрают свои ручёнки, ага блять.. нашли спасательную ниточку в период кризиса, который они же и создали. Соснут хуйца, нехуй было меня злить.
Аноним 07/05/19 Втр 03:42:52 1394991325
>>1394982
Ахаха, всегда знал что реверсачеры поехавшие.

>Плохой инженер занижает цену на ремонт
Но вот тут согласен.
Аноним 07/05/19 Втр 18:36:33 1395332326
image.png (76Кб, 666x227)
666x227
Как это читать/понимать? Какие знания нужны, подскажите люди добрые
Аноним 07/05/19 Втр 19:13:48 1395351327
>>1395332
Знание PE формата. Читай "Записки исследователя компьютерных вирусов" Криса
07/05/19 Втр 21:00:45 1395402328
>>1395351
> Знание PE формата. Читай "Записки
Ты, видимо, не читал. Это .com.
Аноним 07/05/19 Втр 21:52:19 1395421329
Сап, байтоебач
Насколько актуальны книги Криса Касперского в 2к19?
Аноним 07/05/19 Втр 22:59:10 1395440330
07/05/19 Втр 23:10:22 1395445331
>>1395421
Найди что-нибудь посовременнее. Книги Криса - классика, но только потому что в те времена другого не было. Эти книги состоят из ошибок, петросянства и базовой информации, в которой автор сам поверхностно разобрался во время написания книги. Читать Криса стоит, надеяться что-то понять, читая только лишь Криса - глупо.
Аноним 07/05/19 Втр 23:37:03 1395454332
Аноны, а почему в треде нет движухи по поводу ARM и реверсинга мобильных приложух/мобильных малварей и встраиваемых систем с выходом в тырнет? Годная тема же.
08/05/19 Срд 01:30:47 1395483333
>>1395454
В треде вообще движухи нет. Спрашивай свои ответы, обсудим.
Аноним 08/05/19 Срд 01:52:59 1395494334
>>1395483
В общем, недавно понял, что я не люблю винду, а люблю линукс, плюс узрел ARM асм краем глаза и он мне понравился. Подумываю вкатиться в это дело как следует.
Хотел спросить знает ли кто-то какие-то хорошие источники почитать/посмотреть. На инглише или русском, желательно офк на инглише. Кроме Linux internals, это и ежу понятно.
В общем, знатоки мобайл секьюрити и имбэдэда, если таковые имеются, закидайте меня годнотой плиз.
Аноним 08/05/19 Срд 03:16:09 1395530335
>>1395421
Устарели уже как лет 5 если не больше. Но все о чем он писал, знать необходимо.
Аноним 08/05/19 Срд 10:48:40 1395588336
Как пользоваться сэмплами на арм асме из книги Юричева? Чем компилить сорцы под виндой?
Аноним 08/05/19 Срд 10:58:24 1395589337
>>1395494
>В общем, недавно понял, что я не люблю винду, а люблю линукс, плюс узрел ARM асм краем глаза и он мне понравился. Подумываю вкатиться в это дело как следует.
>Хотел спросить знает ли кто-то какие-то хорошие источники почитать/посмотреть. На инглише или русском, желательно офк на инглише. Кроме Linux internals, это и ежу понятно.
>В общем, знатоки мобайл секьюрити и имбэдэда, если таковые имеются, закидайте меня годнотой плиз.

Проблема арма в том что он наглухо проприетарно огорожен и в большинстве своих реализаций, из исключений разве что школомалина да микроконтроллеры на Cortex M. Кроме того арм очень многое не прощает в многопоточности что прокатывает на шинтеле по причине отсутсвия инвалидации кеша по умолчанию. SIMD там по прежнему с заебами "перед использованием включить те и те флаги и не забыть сохранить" аля MMX/3DNow.

Аноним 08/05/19 Срд 11:01:00 1395590338
Аноним 08/05/19 Срд 11:02:19 1395591339
08/05/19 Срд 17:54:34 1395776340
>>1395589
> Проблема арма в том что он наглухо проприетарно огорожен
Это не более-менее решаемая проблема. Чаще всего можно нарыть мануалы, а то и целые сдк у китайцев. Часто производители SoC закупают IP у одного и того же разработчика (тот же Synopsys DesignWare например), и поэтому можно использовать чужие мануалы, ну и в крайнем случае, можно худо-бедно отреверсить интересующие вещи.
Аноним 09/05/19 Чтв 14:05:48 1396355341
Поясните пж, как вычисляется псевдокодом иды глобальная переменная класса относительно GOT (Global Offset Table). Xrefs не видит, а в псевдокоде есть. В процесс включены операции со Stack Pointer'ом вида: LDR R12, [SP, #0x1A4+var_190]. Научите считать эту дичь.
10/05/19 Птн 02:15:29 1396662342
>>1396355
Сколько-нибудь полный пример тащи.
Аноним 10/05/19 Птн 03:25:15 1396674343
10/05/19 Птн 05:23:31 1396683344
>>1396674
Ну вот смотри. Вся адресация очень простая: в GOT при загрузке кладутся правильные (абсолютные) адреса всякой хуйни, ты знаешь офсет GOT относительно своего кода (при линковке впатчивается линкером), но ты не знаешь, куда именно загрузили твой код. И ты идешь с конца: читаешь из PC адрес кода, вычисляешь относительно этого адреса адрес GOT, читаешь из нужного элемента GOT абсолютный адрес данных, работаешь с этими данными по этому адресу.

По 004D9E14 вычисляется абсолютный адрес GOT: PC + офсет. Не забывай, что инструкции, читающие PC, получают не адрес текущей инструкции, а адрес текущей инструкции + 8, потому что конвейер, потому что ARM. Т.е., чтобы посчитать адрес GOT относительно PC, наш офсет должен быть равен $_GLOBAL_OFFSET_TABLE_ - (0x4D9E14 + 8), мы его берем из R8, а положили его туда по по 004D9E04 (сравни - офсет правильный). В результате после выполнения R8 = PC + R8, в R8 у тебя адрес GOT.

Дальше по 004D9E10 в R3 грузится смещение нужного элемента относительно начала GOT, в котором IDA облажалась (как обычно). Тыкни H по этому литералу, чтобы увидеть просто число, потом тыкни Ctrl+R по нему же (если ничего не произойдет - сходи в конец функции и поищи этот литерал там). В диалоге Reference information пересчитай адрес относительно GOT: type=32-bit full offset, base address = $_GLOBAL_OFFSET_TABLE_ (или адрес GOT числом напиши), галки снять, target address = 0xFFFFFFFF. После этого во втором операнде LDR ты должен заметить правильное имя переменной (имя_ptr). Если видишь что-то типа "dword_abcd - $_GLOBAL_OFFSET_TABLE_" или "off_abcd - $_GLOBAL_OFFSET_TABLE_ " - Enter по имени, и переименовываешь вот это говно_abcd в имя_ptr, т.е., чтобы оно выглядело как имя_ptr dcd имя.

Ну и дальше. По 004D9E28 R3 (офсет в GOT) сохраняется на стеке (компилятор - говно). Дальше по 004D9E7C он обратно читается в R12. Т.е., в R8 GOT, в R12 офсет внутрь GOT, значит по 004D9E90 в R10 из GOT (R8 + R12) читается адрес переменной. Ну а следующие две инструкции пишут по этому адресу и еще рядом. Ну и раз это называется screen size, то очевидно это структура из width и height, тыкаешь Enter на k_screenSize, Alt+Q, все дела.
Аноним 10/05/19 Птн 12:39:29 1396787345
Хочу написать свой дизассемблер по статье https://habr.com/ru/post/128042/ и интел мануалу. Посоветуйте простые реализации дизасма, чтобы можно было изучать теорию и смотреть, как дизассемблирование реализуется на практике. Я нашел крутые вещи типа VirXdasm (дизассемблер, который весит 333 байта), но там очень хардкорные алгосы.
Аноним 10/05/19 Птн 12:44:01 1396790346
>>1396787
Крис Касперски тоже дает много теории, а практики у него нет. Он не показывает, как строятся таблицы, как происходит поиск в них и как обрабатываются составляющие части инструкции. Но излагает он более понятно.
Аноним 10/05/19 Птн 12:48:38 1396795347
>>1396683
Черт, гениально. После настройки в Reference information пойнтер сам обозначился именем, гайд однозначно золотой. А про width и height мне известно. Спасибо за столь развернутый ответ, однозначно сохраню его.
10/05/19 Птн 14:39:47 1396917348
>>1396787
Ну короч берешь Intel SDM, там в конце 2 тома таблицы есть. Ты их копипастишь, разбираешь условные обозначения, разбираешь формат инструкций (в начале 2 тома) - получаешь дизассемблер. На недовасме поищи "Заклинание кода".
Аноним 10/05/19 Птн 15:02:40 1396946349
Аноним 10/05/19 Птн 15:04:44 1396948350
>>1396946
>Заклинание кода

"У буквы "заин" долгая и богатая история. Многие поколения магов пытались определить, в чем заключается ее сокровенный смысл. Некоторые утвеждали, что она несет врагам смерть и страдания от разящего клинка, иные указывали на ее форму и говорили, что этот разящий клинок применим далеко не всегда и не везде, а только в некоторых, хотя и весьма ответственных операциях. "

Хорошее начало дизассемблирования, лол
10/05/19 Птн 15:30:49 1396976351
>>1396948
> Хорошее начало дизассемблирования, лол
Ну это ж аквила, чего ты хочешь.
Аноним 10/05/19 Птн 15:41:05 1396982352
>>1396976
Нормально. Я прям чувствую его фанатизм. Не в пример двачерам.
Аноним 10/05/19 Птн 23:57:05 1397277353
>>1396946
Краткий гайд.

1. Делаешь запрос в гугле а не на дваче
fastest disassembler library
2. git clone...
3. Копаешься в тысячах строк кода сколько тебе угодно
4. Понимаешь, что лучше ничего придумать нельзя, одному уж точно
5. Пользуешься готовыми решениями и не выебываешься.
11/05/19 Суб 00:38:43 1397302354
>>1397277
> Пользуешься готовыми решениями
Капстоун нельзя назвать быстрым и тем более компактным решением. Медиана не поддерживается. Что-то другое подскажешь?

> лучше ничего придумать нельзя
Расскажи это авторам вирусов из 90х, у которых дизассемблер длин с таблицами занимал полкило.
Аноним 11/05/19 Суб 07:53:41 1397377355
Аноним 12/05/19 Вск 10:47:07 1398224356
>>1378386
>Крис дважды по заданию шерифа участвовал в платных боевых операциях по задержанию бандитских группировок. В первой операции четверо ребят вместе с ним, не служивших в армии, брали банду из шести вооруженных человек. Крису пришлось первый раз в жизни, по необходимости, стрелять в человека. Все шестеро были задержаны.
Истории уровня /b какие-то..
Хотя я конечно могу и ошибаться.
Аноним 12/05/19 Вск 13:14:37 1398265357
Аноним 13/05/19 Пнд 14:55:46 1399038358
Меня одного пугает Китай? Китайцы спокойно постят в своих блогах о том как пилят малварь, обходят разные продукты безопасности, буткиты, руткиты, анальные зонды. И их даже никто за это не бутылит! Информация размещена в свободном доступе, на всяких
новостных порталах аля наш XAKEP. Что за пиздец? У них такое законом не запрещено?
Аноним 13/05/19 Пнд 15:05:56 1399048359
>>1399038
разрабатывать малварь не запрещено законом, запрещено распространять с целью порчи/кражи данных.
Аноним 13/05/19 Пнд 16:39:43 1399083360
>>1399038
можно линки на блоги?
Аноним 13/05/19 Пнд 21:47:50 1399295361
>>1399038
>У них такое законом не запрещено?
Так они же буржуйские программы вскрывают. За вскрытие программы из КНР их будет ждать что похуже побольше, чем бутылка.
Аноним 14/05/19 Втр 07:37:12 1399497362
Сап,реверсач
есть сэмл app. any.run/tasks/d55 93b4d -1911- 4d4f-b60d-6eff182efd9b уберите пробелы
Накрыт KoiVM+confuser
Чем вскрывать и как?никаких идей
На tuts4you 1.5 упоминания и то вскользь
Аноним 14/05/19 Втр 13:17:44 1399663363
>>1399497
dnspy, ded4dot, любой анпакер для кофусера с гитхаба.
В чем проблема-то? Ты дебагером пользоваться умеешь?



Аноним 14/05/19 Втр 15:30:12 1399732364
>>1399663
де4дот вообще говно ебанное и виртуализацию не осилит
в днспае его нормально не выходит продебажить
Аноним 14/05/19 Втр 16:54:14 1399793365
>>1399732
Если ты не можешь .net-помойку дебажить, то у меня для тебя плохие новости. Кроме того, зачем тебе девиртуализировать приложение? У тебя задача какая?
Аноним 14/05/19 Втр 18:11:56 1399847366
Чуваки, начал читать книгу Ирвина, в ней используют masm, а у меня линукс. Как быть, что посоветуете? Может выкрутиться как то можно, чтобы запустить masm на линуксе?

Книга нравится, кроме ассемблера рассказывает подробно про процессор. Поэтому другую читать нехочется. Остальные мне показались слабенькими. Может я не прав и есть крутые книги?
Аноним 14/05/19 Втр 18:26:53 1399853367
Аноним 14/05/19 Втр 18:37:06 1399859368
>>1399853
Спасибо, но это виндовая утилита, а у меня линукс. Там сплошные батники и экзешники.
Аноним 14/05/19 Втр 18:41:27 1399863369
>>1399793
вскрыть и получить исходники
>то у меня для тебя плохие новости
не злись,я совсем новичек:3
Аноним 14/05/19 Втр 18:57:38 1399874370
Реверсач, а нахой юзать бесплатную кастрированную айду, если есть гуй Каттер от радар2 с таким же функционалом, только бесплатный и поддерживающий очень много архитектур?
Аноним 14/05/19 Втр 20:09:53 1399938371
>>1399874
>нахой юзать бесплатную кастрированную айду
Действительно, нахой? Есть же торрент.
Кстати, пароль от архива с 7.2 ещё не слили?
>с таким же функционалом
В голосину.
Аноним 14/05/19 Втр 20:26:04 1399949372
>>1399847
Зачем тебе запускать masm на линуксе? Возьми fasm или nasm, почитай про различия в синтаксисе.

>>1399938
> В голосину.
Присоединяюсь.
Аноним 14/05/19 Втр 20:40:22 1399963373
>>1399949
>Зачем тебе запускать masm на линуксе?
Хрен его знает. В книге винда и masm.
Аноним 14/05/19 Втр 20:40:43 1399964374
>>1399949
>fasm или nasm
Что предпочтительней?
Аноним 14/05/19 Втр 20:57:34 1399980375
>>1399964
fasm мощнее, nasm больше подходит для линукса, поддерживает привычную отладочную информацию без костылей.
Аноним 14/05/19 Втр 21:01:41 1399986376
Аноним 14/05/19 Втр 23:13:52 1400090377
>>1399793
>>1399863
хотя даже исходники не нужны,нужно найти порядка 5 разных стрингов и заменить их значения на свои нужные
в любом случае надо как-то снять этот KoiVM
Аноним 15/05/19 Срд 15:21:46 1400505378
Пытаюсь вкатиться в ROP. Как можно автоматизировать поиск гаджетов?
Аноним 15/05/19 Срд 16:25:07 1400589379
Аноним 15/05/19 Срд 16:27:39 1400592380
Вечер в хату!
Прохожу тут курсик по radare2 (да, я вижу по шапке, что он тут не в почёте, но мой вопрос не совсем по нему) - https://github.com/s4n7h0/Practical-Reverse-Engineering-using-Radare2
Там всё на элементарном уровне освоения команд, но вот с пятой лабой янихуянепонел. Задание "найти шелкод и понять что он делает". Ну символ obj.shellcode я вижу. Опкоды по нему парсятся в какое-то говно непонятное - https://pastebin.com/cZxZtJUt
ЧЯДНТ?
Аноним 15/05/19 Срд 16:39:34 1400603381
>>1400592
>.string "^1\xc9\xb1'"

5E pop si
31C9 xor cx,cx
B1XX mov cl,XX
Аноним 15/05/19 Срд 16:55:15 1400627382
>>1400603
Спасибо!
сссука всё-таки дело в радаре оказалось...
"e bin.strings=false" сделал, конечно строковые константы при этом отвалились. Как реинтерпретировать конкретные байты так и не ясно.
Аноним 15/05/19 Срд 20:12:28 1400758383
>>1400589
Мне на С/C++ либа нужна. Есть годные?
15/05/19 Срд 22:17:03 1400829384
>>1400627
Берешь иду, видишь свою "строку", выбираешь ее мышью или стрелками, нажимаешь на клавиатуре C, профит. Берешь r2, нажимаешь кучу кнопочек, чтобы попасть в visual mode, куда-то все же попадаешь, теряешься в набегающих домиках и гей-параде из разноцветного ASCII-арта и цифр, но героически нажимаешь D C, тоже профит (или нет?).
Аноним 15/05/19 Срд 22:51:36 1400852385
>>1400829
Да, действительно. Хотя ни в одном cheat-sheet или quick start это не упоминалось, да и не трогал я этот visual mode.
За пол дня конечно хер столько команд и опций запомнить.
Аноним 18/05/19 Суб 14:13:23 1402447386
В Си треде не отвечают. Продублирую сюда.

Аноны, пишу драйвер, использую стороннюю либу при инициализации, далее ею не пользуюсь, а весит она знатно, аж целый метр. В обычном приложении подгружаю длл по-надобности, потом выгружаю. В ядре как эти дела делаются? Неужели придется отдельный драйвер пилить, его дергать и потом выгружать?
Аноним 18/05/19 Суб 14:43:14 1402464387
>>1394956
Матросов годно шарит, он Intel BootGuard сломал пару лет назад. За остальных не скажу.
Аноним 18/05/19 Суб 14:45:54 1402465388
Аноним 18/05/19 Суб 15:45:27 1402491389
Аноним 18/05/19 Суб 20:07:34 1402591390
Аноним 19/05/19 Вск 12:04:16 1402896391
Аноним 19/05/19 Вск 12:29:43 1402912392
Аноним 19/05/19 Вск 19:09:03 1403341393
Аноны, приветствую.
Хочу научиться писать скрипты в айде для автоматизации статического анализа, слышал годная тема, особенно, если прога обфусцирована или же просто слишком грузная для ручной суходрочки.
Посоветуете что почитать или посмотреть. До этого писал скрипты только на баше, но всё же более или менее базовые.
19/05/19 Вск 21:00:35 1403457394
>>1403341
> что почитать
1) Любую книгу по питону.
2) idaapi.py/idc.py/idautils.py
3) Исходники проектов типа flare.
Это просто чтобы научиться писать скрипты хоть как-нибудь. Плюс теория. По теории не подскажу.
Аноним 19/05/19 Вск 22:09:16 1403497395
Сап, Антош. Хочу инжектить свою DLL во все виндовые процессы уровня пользователя в т.ч. svchost на постоянной основе на этапе их создания. Предусловия - полный физический и административный доступ к машине. ОС - шиндошс 10 х64. Я попробовал appinit_dlls, но оно работает только для того, что грузит user32.dll (очевидно). Как я понял, SSDT и вообще все фишки связанные с ядром соснулей, ибо требуют включения testsign для дров. Вроде есть варианты через колбэки и APC - это то, что мне надо? Где почитать?
Аноним 19/05/19 Вск 22:20:58 1403502396
>>1399847
Gas + .intel_syntax noprefix вполне. Впрочем, на вкус и цвет - мне AT&T кажется логичней.
19/05/19 Вск 23:27:20 1403538397
>>1403502
> AT&T кажется логичней
А тебе не кажется нелогичным, что под все остальные архитектуры, кроме интел, у gas сразу же, по умолчанию нормальный порядок операндов?
Аноним 20/05/19 Пнд 03:04:01 1403608398
>>1403497
Судя по твоему набору слов, ты понятия не имеешь что делаешь. Учи архитектуру ОС. Где ты вообще этот баянистый способ реализации руткита вычитал? Ему больше 20 лет.
Аноним 20/05/19 Пнд 12:32:16 1403700399
>>1403608
> Судя по твоему набору слов, ты понятия не имеешь что делаешь.
Как минимум общее представление имею, просто с конкретно такой задачей впервые столкнулся.
> Учи архитектуру ОС.
Пустые понты кидать не хочу, поэтому скажу, что в целом в курсе, могу не знать каких-то тонких деталей, необходимых для данного случая.
> Где ты вообще этот баянистый способ реализации руткита вычитал? Ему больше 20 лет.
Который именно? В интернете, само собой. Если кинешь ссылку на что-то более актуальное - буду благодарен.
Аноним 20/05/19 Пнд 13:35:33 1403748400
Как ОС работает с dll/so в винде/линуксе при загрузке в процесс в случае системных либ типа kernel32.dll и пользовательских типа libmylib.so? Она создает копию либы в виртуальном пространстве процесса или создает отдельный процесс под эту либу (какой нибудь dllhost.exe/svchost.exe) и пользовательские процессы просто напрямую смотрят туда? Если два процесса импортируют одну и ту же либу, если один процесс в ней сделает детур на свой код, то повлияет ли это на второй процесс?
Аноним 20/05/19 Пнд 14:05:47 1403765401
>>1403748
> Как ОС работает с dll/so в винде/линуксе при загрузке в процесс в случае системных либ типа kernel32.dll и пользовательских типа libmylib.so? Она создает копию либы в виртуальном пространстве процесса или создает отдельный процесс под эту либу (какой нибудь dllhost.exe/svchost.exe) и пользовательские процессы просто напрямую смотрят туда?
Первое, только не копию, а отображение с коровой (COW). Это если очень по-простому. В линуксе нет "системных" либ, в винде это только ntdll.dll (kernel32.dll нужна только Win32 процессам).
> Если два процесса импортируют одну и ту же либу, если один процесс в ней сделает детур на свой код, то повлияет ли это на второй процесс?
Опять же COW, иначе каждый мамкин хакер загружал бы в память OpenSSL и отключал бы шифрование во всей системе.
Аноним 20/05/19 Пнд 14:21:12 1403771402
>>1403765
Прочитал про copy on write. А если у либы есть состояние и она сама в себя пишет при вызове определенной функции, чтобы его изменить. Что произойдет, если процесс А вызовет эту функцию? Изменение состояния либы будет заметно в процессе Б, использующем эту же либу? И еще, если ОС копирует в VM процесса либу во время первой записи, то эта либа как то хостится ОСью? Для этого есть какие нибудь системные процессы, или это где то в кишках ОС зарыто и из пользовательского пространства до туда не добраться?
Аноним 20/05/19 Пнд 14:50:29 1403784403
>>1403771
С линуксами вроде понял. При загрузке процесса делается мемори мап на исполняемую и readonly секции shared object'а с дальнейшим копированием в VM space процесса при записи благодаря CoW, а writable-секции так и вовсе при запуске копируются в адресное пространство запускаемого процесса если верить гуру с stackoverflow. А что с видновсами? Я в эльфе не шарю, но вот в РЕ знаю, что file alignment и virtual alignment могут быть (и КМК, почти всегда) разные, там так просто файл не замапишь. Что в винде то происходит?
Аноним 20/05/19 Пнд 15:52:50 1403832404
>>1403784
> Что в винде то происходит?
Да плюс на минус то же самое, с другими названиями и реализациями. В теории и архитектуре ОСей последние лет так 30 если не 50 никаких существенных изменений не происходило, и старый добрый Таненбаум до сих пор прекрасно все описывает. Совершенствуются конкретные механизмы, да - за ними тебе к Руссиновичу и в исходники ReactOS.
Аноним 20/05/19 Пнд 18:45:13 1403916405
image.png (7Кб, 365x147)
365x147
сап,реверсач
что за протектор для дотнета?NB2.Properties(особо в них не шарю,извините)
в гугле пусто
Аноним 20/05/19 Пнд 19:38:11 1403928406
Как в айде темную тему поставить?(
Аноним 20/05/19 Пнд 22:15:14 1404002407
>>1403765
> в винде это только ntdll.dll (kernel32.dll нужна только Win32 процессам).
Кстати ntdll.dll не грузится в пико процессы.
Аноним 21/05/19 Втр 14:30:48 1404241408
>>1403700
Гугли cплайсинг.

>>1403748
У тебя задача какая? Ты хочешь узнать можно ли похукать все глобально? Можно, но без танцев с бубнами не обойтись.

>>1403765
>только ntdll.dll
Если процесс wow64, то еще 4 либы сверху, насколько я помню.

>>1403928
IDA Skins гугли.

>>1403916
Выглядит как обычный конфусер. Гугли de4dot.

Аноним 21/05/19 Втр 14:52:50 1404251409
>>1404241
вроде какой-то кастомный конфузер,после де4дот во всяком случае херня выходит
Аноним 21/05/19 Втр 15:01:44 1404255410
>>1404251
А ты думал тебе чистенький сурс вытащат? Нет таких инструментов. Вообще пиздуйте в C# тред со своими кофусерами, заебали срать здесь высокоуровневой парашей.
Аноним 21/05/19 Втр 16:04:11 1404267411
>>1402447
Бамп вопросу. Или просто забить на этот 1 мб? У юзверя ведь много ресурсов.
Аноним 21/05/19 Втр 17:59:21 1404292412
>>1404255
>пиздуйте в C# тред
там вообще не шарят
Аноним 21/05/19 Втр 18:13:36 1404299413
>>1404292
Ну тогда в PHP-тред, там даже кнопку ответа не найдут.
Аноним 23/05/19 Чтв 05:12:24 1405062414
Объясните, пожалуйста, начнающему ассемблерщику мне. Я не понимаю. В Long mode (x86-64) опреранды могут задаваться их линейными адресами (в качестве immediate-аргументов в командах). Но ведь при загрузке требуемые данных (которые мы хотим адресовать) могут быть размещены достаточно произвольно - страница с данными может быть в разных местах памяти. И адрес данных будет меняться от загрузки к загрузке. А значение immediate-аргумента не изменяется. Как же инструкция доберётся до нужных данных? Видимо, я что-то упускаю. Извините, за корявую формулировку.
Аноним 23/05/19 Чтв 08:52:15 1405083415
>>1405062
Не совсем понял, о чем ты конкретно. Нарисовал бы пример что ли.
> страница с данными может быть в разных местах памяти
Таблица страниц.

> адрес данных будет меняться от загрузки к загрузке
Вместе с адресом кода. RIP-relative адресация, редко (гораздо реже, чем в 32-битном режиме) таблица поправок.
Аноним 23/05/19 Чтв 13:27:50 1405146416
Говорят, современные компиляторы АСМов сосут, это правда?
Аноним 23/05/19 Чтв 14:01:06 1405152417
>>1405083
Ну вот например.

data: dd 123456789h
...
mov rax , [data]

Место данных data в памяти определяется во время загрузки, а immediate-аргумент команды mov ([data] - некоторый адрес) фиксирован (при трансляции, видимо).
Аноним 23/05/19 Чтв 15:17:04 1405174418
>>1405146
БАМП.

Оптимизация у АСМов сосёт, да?
Понятно.
Аноним 23/05/19 Чтв 15:20:31 1405177419
>>1405174
Какая оптимизация? Ты уверен, что хорошо понимаешь, как действуеет ассемблер, и для чего он применяется?
Аноним 23/05/19 Чтв 15:26:39 1405179420
>>1405146
Сосут по сравнению с чем? И что в них такого нового появилось за последние 30 лет?

>>1405152
Ну вот, оно сассемблируется с ошибками, потому что ты кладешь дворд в rax, а еще потому что 123456789h не влезает в dd с вычислением адреса относительно адреса следующей инструкции, т.е. будет:
mov rax,[rip+(data-next_instruction)]
next_instruction:
...
data dq 123456789h
Вот если бы у тебя положение секции данных менялось относительно кода, то при загрузке пришлось бы патчить адреса.

>>1405177
У асмов есть оптимизация. Например, можно воткнуть длинный jmp, а можно короткий. Это работает. Остальную оптимизацию делает приставка к клавиатуре.
Аноним 23/05/19 Чтв 15:27:14 1405180421
>>1405177
Ну говорят, что компиляторы С/С++ сейчас оптимизированы гораздо лучше АСМовских.
Аноним 23/05/19 Чтв 15:28:40 1405181422
>>1405179
А есть какой-нибудь кроссплатформенный ассемблер и бесплатный, но чтобы быстро было?
Аноним 23/05/19 Чтв 15:29:48 1405182423
>>1405180
Говорят, что кур доят. Автоматическая векторизация по-прежнему сосет. Алиасинг в си/си++ по-прежнему создает проблемы. Приставка к клавиатуре по-прежнему рулит. Только она медленная и дорогая, поэтому ей пользуются относительно редко.

>>1405181
nasm/fasm/gas, похуй.
Аноним 23/05/19 Чтв 15:51:45 1405200424
>>1405182
А есть какой-нибудь кроссплатформенный машинный код?
Или кроссплатформенность начинается только с АСМа?
Аноним 23/05/19 Чтв 15:57:33 1405205425
>>1405179
>относительно адреса следующей инструкции
То есть абсолютных адресов в immediate-аргументах не бывает?

>Вот если бы у тебя положение секции данных менялось относительно кода
А что если они загружаются (или даже транслируются) по отдельности? Что, вообще с раздельной сборкой?

>патчить адреса
Как это делается?
Аноним 23/05/19 Чтв 16:03:12 1405209426
>>1405179
Кстати адресация в immediate-аргументах в виде (сегментный регистр + immediate-смещение) имеет смысл в Long mode?
Аноним 23/05/19 Чтв 16:19:06 1405232427
>>1405200
>кроссплатформенный машинный код
Сухая вода? Выбери одно или машинно-специфичный язык (машинный код) или код не зависящий от платформы ('машины').
Аноним 23/05/19 Чтв 16:32:06 1405248428
>>1405205
> То есть абсолютных адресов в immediate-аргументах не бывает?
Ну хватит уже это immediate называть. immediate - это значение, которое ты непосредственно используешь для чего-то, константа, число (в mov eax,1 единица - просто число), поэтому оно immediate и называется. А ты говоришь про офсеты.

Бывают абсолютные адреса. Эффективная адресация осталась, ты можешь не использовать в ней scale/index/base, оставив только 32-битное смещение, тем самым получив абсолютный адрес в пределах первых 4 гб. Алсо, есть mov rax с 64-битным офсетом (да, только для rax).

> А что если они загружаются (или даже транслируются) по отдельности?
Линкер, когда занимается связаванием (link) символов, как раз патчит все ссылки на символ так, как будет в памяти.

> Как это делается?
Ну формируется список адресов (у линкера или если мы про рантайм - то в исполняемый файл кладется) и типов поправок (ну где относительный адрес, где абсолютный, где только кусок какой-нибудь, там дохуя вариантов, особенно для некоторых особо хитровыебанных процессоров). Ну и код (линкер или загрузчик) идет по списку и что-то делает в зависимости от типа. Например, в 32-битном коде для mov eax,[data] линкер положит в инструкцию правильный адрес data, а если у нас дллка виндовая, которая загружена не по своему предпочтительному адресу, то загрузчик прибавит к адресу data внутри инструкции разницу между предпочтительным адресом загрузки дллки и фактическим. Ну это самые простые примеры.

>>1405209
> сегментный регистр +
Для fs/gs сохранилась более-менее, для остальных сегментных регистров база из дескриптора не учитывается и считается равной нулю.

>>1405232
Считать ли x86-код кроссплатформенным, если его раньше всякие трансметы микрокодом выполняли?
Аноним 23/05/19 Чтв 16:34:41 1405250429
>>1405248
> есть mov rax с 64-битным офсетом (да, только для rax)
В смысле, для al/ax/eax/rax, и, конечно же, не только в регистр, но и обратно, из регистра в память.
Аноним 23/05/19 Чтв 16:41:43 1405255430
>>1404267
И ведь никто не помог! Решение: поместить либу в отдельную секцию и пометить ее как сбрасываемую. После инициализации драйвера, загрузчик винды сам её выгрузит.
Аноним 23/05/19 Чтв 16:52:04 1405263431
>>1405248
>Ну хватит уже это immediate называть.
Извините ещё раз за корявость формулировок. Ты прав. Это называется "смещение в команде".

>Линкер, когда занимается связаванием (link) символов, как раз патчит все ссылки на символ так, как будет в памяти.
А если без линкера? Что в случае сборки в бинарный файл?

>Считать ли x86-код кроссплатформенным, если его раньше всякие трансметы микрокодом выполняли?
Думаю, сейчас нет. Машинные инструкции и сейчас в микрокод транслируется процессором. Но ведь программисту микрокоды недоступны. И машинный язык однозначно определён архитектурой ЦП. Нет тут кросплатформенности (в нынешних x86 процессорах).
Аноним 23/05/19 Чтв 17:04:29 1405271432
>>1405263
> А если без линкера? Что в случае сборки в бинарный файл?
Не понял вопроса. Если у тебя ассемблер, нет секций и бинарник на выходе (допустим, fasm и format binary), то ассемблер все равно делает то же самое, что и линкер внутри себя, когда назначает адреса меткам и впатчивает эти адреса в инструкции.

> Но ведь программисту микрокоды недоступны
Это пока процессор не твой собственный. Берешь, значит, много-много баксов и подходящую по размеру FPGA... Хотя вообще-то я пошутил.

> И машинный язык однозначно определён архитектурой ЦП
Набор команд в x86 уже давно имеет мало отношения к архитектуре, это просто абстрактная хрень, которая живет лишь из-за необходимости поддерживать совместимость.
Аноним 23/05/19 Чтв 18:36:10 1405294433
>>1405232
>Сухая вода?
https://ru.wikipedia.org/wiki/Novec_1230


Я всё понимаю, но разве нельзя сделать такую штуку, которая будет некоторые кроссплатформенные команды перефигачивать под конкретное железо и ОС?

Полно их.
Только тут разница в низкоуровневом программировании, ниже, чем у АСМа.
Аноним 23/05/19 Чтв 18:39:51 1405295434
Buf1 db 11
Len1 db ?
Opnd1 db 12 dup( ? )
Buf2 db 11
Len2 db ?
Opnd2 db 12 dup( ? )
Res db 12 dup(' '),'$'

codeseg
startupcode
push DS
pop ES
BEGIN:
;Ввод первого слагаемого
B1:
lea DX, Buf1
mov AH, 0Ah
int 21h
cmp Len1, 0
je B1

Помохите пожалуйста.
Переписываю потихонечку чужой код и не могу понять для чего тут Len1. Точнее я знаю, он туда засунет в последствии кол-во символов в строке.
Но что означает это?
cmp Len1, 0
je B1

Зачем сравнивать Len1 с нулём, и в случае равенства или нуля переходить обратно на начало?
Что это за колдунство?
В лен1 же нихуя нет.
Зачем он сравнивает?
Аноним 23/05/19 Чтв 18:39:52 1405296435
>>1405263
>>1405271
А сейчас на микрокоде писать нельзя проги?

А как обстоит дело и машинными кодами на Видеокартах?
И есть ли под них свой АСМ?
Аноним 23/05/19 Чтв 19:02:27 1405300436
Как сделать сайт на машинных кодах?
Аноним 23/05/19 Чтв 19:06:24 1405302437
>>1405300
Без задней мысли, просто берешь и делаешь.
Аноним 23/05/19 Чтв 19:07:31 1405303438
>>1405302
Так покажи примерчик хоть.
Аноним 23/05/19 Чтв 19:10:11 1405304439
>>1405295
> Зачем он сравнивает?
Ну видимо чтобы запросить ввод повторно, если юзер просто нажал Enter.

>>1405296
> А сейчас на микрокоде писать нельзя проги?
У интела микрокод не документирован, обновления зашифрованы. Максимум, что есть - это статьи про какой-то очень древний AMD, у которого микрокод еще шел без шифрования.

>>1405302
> Так покажи примерчик хоть.
mov ah,09h
imov dx,_text
int 21h
int 20h
_text db 'Content-Type: text/plain',13,10,13,10,'Hello, world!$'
Аноним 23/05/19 Чтв 19:10:15 1405305440
Аноним 23/05/19 Чтв 19:12:28 1405306441
А что на видеокарты до сих пор не завезли кроссплатформенный Ассемблер?

У Нвидиа свои языки, у АМД свои.
Модели видях ещё новые нужны для новых языков.
Херня какая-то.
Аноним 23/05/19 Чтв 19:14:48 1405308442
>>1405305
это ассемблер, а не машкод.
И это сервер, а не сайт.
Аноним 23/05/19 Чтв 19:16:36 1405309443
Аноним 23/05/19 Чтв 19:17:15 1405310444
14801389535820.jpg (41Кб, 600x450)
600x450
Аноним 23/05/19 Чтв 19:20:29 1405312445
>>1405304
> Ну видимо чтобы запросить ввод повторно, если юзер просто нажал Enter.
Пасиба. Понял. А если буковку ввести? Он сожрёт и пропустит дальше по коду?
Аноним 23/05/19 Чтв 19:32:11 1405324446
>>1405312
А если буковку ввести, то во втором байте буфера, т.е., в Len1 уже не будет 0 (а будет 1, например), сравнение не выставит ZF, je не сработает.
Аноним 23/05/19 Чтв 19:40:50 1405332447
Аноним 23/05/19 Чтв 19:43:51 1405335448
>>1405309
Речь идёт о программировании на машкоде, а не о перегоне в него из других языков, улавливаешь?

Так что твой АСМовский сервак ничем не особо не отличается от сервака на Раби. Только побыстрее работает в десятки раз и всё.
Аноним 23/05/19 Чтв 19:53:07 1405342449
БАМП!
Для GPU ASM какой есть универсальный?
Аноним 23/05/19 Чтв 20:09:46 1405350450
2.png (1332Кб, 1920x1036)
1920x1036
Бля, не вижу смысла учить ASM из-за такой хуеты с GPU.

Лучше тогда C/C++ взять, а GPU хуярить на универсальном OpenCL.
Аноним 23/05/19 Чтв 20:44:06 1405366451
>>1405146
Современные писатели на АСМ сосут, это правда.
23/05/19 Чтв 22:11:49 1405423452
>>1405335
Нет, не улавливаю. Хочешь - бери таблицу опкодов и пиши, только кроме кучи дополнительной ебли это ничем не будет отличаться от использования ассемблера. Никаких дополнительных преимуществ, ничего такого, что нельзя с точностью до бита воспроизвести из ассемблера.

>>1405350
> не вижу смысла учить ASM
Не учи, разрешаю.
Аноним 23/05/19 Чтв 22:27:08 1405429453
Господа, нас пытаются тралливалить.
Аноним 23/05/19 Чтв 22:50:43 1405435454
>>1405294
Стандартная библиотека называется. Ты из какого века вылез-то? У асма никогда не было кроссплатформенности.
Аноним 23/05/19 Чтв 22:55:21 1405438455
>>1405429
Да это не троллинг. Сюда действительно иногда дебилы первокурсники из C/C++ тредов закатываются и начинают тупить. Тут только ОП-хуй который с сагой пишет всегда адекватный.
Аноним 23/05/19 Чтв 23:27:30 1405450456
>>1405423
Тогда почему сразу С/С++ не взять?
Ебли же меньше, а скорость работы сложных программ уже выше, потому что не будешь вручную оптимизировать каждую строчку на АСМе.
Аноним 23/05/19 Чтв 23:28:45 1405451457
>>1405435
я читал статьи про кроссасмы всякие.
Аноним 23/05/19 Чтв 23:51:06 1405465458
>>1405451
Ты кроссассемблирование/кросскомпилляцию с кросплатформенностью (языка машинного) не путаешь?
24/05/19 Птн 00:12:18 1405472459
>>1405450
> Тогда почему сразу С/С++ не взять?
Я для тебя специально пояснил: между машинным кодом и ассемблером разница - только ебля. Между ассемблером и более высокоуровенвым языком разница в огромном количестве возможностей и полным контролем над кодом. Ну почти. В ассемблерах обычно ты не можешь выбирать из разных вариантов кодирования одной и той же инструкции, но ты всегда можешь написать под это макрос, если это почему-то важно.

> скорость работы сложных программ уже выше
Зависит только от тебя. Не от компилятора, а от тебя. И нет, причина использования высокоуровневых языков - скорость разработки, а не работы. Модификация оптимизированного ассемблерного кода может закончиться переписыванием с нуля.

> почему сразу С/С++ не взять?
Если ты не пишешь какую-нибудь жестокую математику для SIMD, хитровыебанный JIT, низкоуровневые процедуры для своей ОС типа сохранения/восстановления контектста или обработчика прерывания который все равно выполняет только самую грязную работу, а потом вызывает код на Си - без вариантов стоит брать нормальный высокоуровневый язык, а ассемблер использовать там, где он действительно необходим.

>>1405438
> ОП-хуй который с сагой
Я не оп.
Аноним 24/05/19 Птн 00:33:32 1405477460
Хочу заняться фазингом. Сейчас у каждой второй десктоп приложухи драйвер под копотом, никто писать их толком не умеет, багоров куча. Подводные?
Аноним 24/05/19 Птн 01:28:35 1405481461
>>1405304
>У интела микрокод не документирован, обновления зашифрованы
Зашифрованы чем, универсальным интеловским ключом? Почему тогда до сих пор никто не вытащил из кремния этот ключ электронным микроскопом и не выложил в паблик? Я не верю, что там в каждом камне физическая защита уровня смарткарт на всем УУ.
24/05/19 Птн 01:53:59 1405485462
>>1405481
> Зашифрованы чем, универсальным интеловским ключом
Да, там предполагался 2048-битный RSA. И там несколько блоков под разные семейства с разными ключами:
https://www.dcddcc.com/docs/2014_paper_microcode.pdf
https://www.emsec.ruhr-uni-bochum.de/media/emma/veroeffentlichungen/2017/08/16/usenix17-microcode.pdf

> не вытащил из кремния этот ключ электронным микроскопом и не выложил в паблик
Размер кристалла, техпроцесс. Это тебе не R3051 реверсить.
Аноним 24/05/19 Птн 02:14:37 1405491463
>>1405485
Ну у того же AMD есть такие возможности точно. Могли бы отреверсить и выложить, чтобы мимокрокодилы там регулярно находили всякие непотребства и опускали Intel. Гораздо дешевле, чем вкладываться в рекламу и всякое такое.
Аноним 24/05/19 Птн 13:16:12 1405659464
Куда делся тред про машинный кодинг?
Аноним 24/05/19 Птн 13:21:40 1405663465
>>1405472
Я так нихуя и не понял.
АСМ зачем нужен, если скорость почти та, что на С, но писать дольше и сложнее?

Если сравнить Питоноговно с этими языками, так он в десятки раз медленней работает, тут всё предельно ясно.

Но вот с выбором АСМ вместо С или плюсов не ясно.
Аноним 24/05/19 Птн 13:22:21 1405664466
Аноним 24/05/19 Птн 13:26:27 1405668467
>>1405182
>nasm/fasm/gas
Какой самый быстрый и самый кроссплатформенный?
Аноним 24/05/19 Птн 15:30:06 1405743468
>>1405663
На АСМе пишут куски кода в системах реального времени и ОС, в кодах вирусов, в софте встроенных систем. На чистом АСМе уже давно не программируют, уже как лет 40 точно.
Уметь читать чистый АСМ нужно реверсерам. Статический анализ = чтение чистого ассемблерного листинга с целью восстановить исходный алгоритм функции/блока кода/всей программы, нужное подчеркнуть. Для чего? Чтобы написать похожую программу, написать кряк для нее, найти дыру в безопасности для тех или иных целей и т.п. Нужное подчеркнуть, как говорится.
Аноним 24/05/19 Птн 15:38:42 1405750469
Можете обьяснить BCD-числа и их умножение.

Такая ебанина пиздец. Мама я у них поел просто.

Точнее алгоритм перевода в неупакованный bcd у меня есть, вот он. https://pastebin.com/t4Kgs8hY
Но алгоритм не мой, я черт его знает что там происходит.
И умножение я хуй знает как сделать. Умножение через мул как то ниполучаицца.
Там сначала результат залетает в АХ, потом надо аам делать ради (исправления чего-то?), и результаты раскидываются по двум регистрам.
Теперь сразу два регистра выводить?
Йа тупой, арррр.
Аноним 24/05/19 Птн 17:50:02 1405820470
>>1405663
Он нужен для выполнения специфических задач, где нужен прямой доступ к регистрам, например. Короче с асмом дела обстоят, как в том самом анекдоте: Ньюфаги не знают, олдфаги не помнят.
Аноним 24/05/19 Птн 18:35:18 1405845471
>>1405743
Ну и поэтому компиляторы АСМа сосут в оптимизацию.
Потому что 40 лет назад он всё.
Аноним 24/05/19 Птн 18:36:18 1405846472
Аноним 24/05/19 Птн 18:45:08 1405851473
11760587.jpg (160Кб, 640x468)
640x468
Народ, на каком АСМе можно написать программу, которая будет работать на 32 и 64 архитектуре, Intel, AMD, ARM, а также Винде, Линуксе, Маке и желательно Андроид с Айфоном?
Аноним 24/05/19 Птн 19:13:21 1405860474
petrosyan2.jpg (20Кб, 512x384)
512x384
>>1405845
>компиляторы АСМа сосут в оптимизацию
Аноним 24/05/19 Птн 19:14:36 1405861475
изображение.png (217Кб, 477x353)
477x353
24/05/19 Птн 19:35:12 1405867476
Аноним 24/05/19 Птн 19:42:47 1405871477
>>1405867
А что код на Ассемблере сильно ОС-зависимый?
Аноним 24/05/19 Птн 19:47:21 1405872478
>>1405743
> в кодах вирусов
Размечтался. Сейчас вирусы пишут на Node.js и тянут за собой хром с драйвером контроллера xBox.
Аноним 24/05/19 Птн 20:16:32 1405879479
>>1405871
Ну, если он работает в реальном режиме и загружается с дискеты - нет. А иначе дергать ось тебе таки придется.
Аноним 24/05/19 Птн 20:18:15 1405881480
>>1405879
А что компилятор не может на себя взять работу с АПИ, чтобы можно было сразу для любой оси писать?
Аноним 24/05/19 Птн 20:21:36 1405883481
>>1405881
А компиляторов-то и нет. Можешь хоть в хекс-редакторе писать на асме, хотя это и несколько сложновато. Ну, com уж точно можно.
Аноним 24/05/19 Птн 20:30:19 1405886482
>>1405883
Так универсального ОС АПИ для ассма нет?
Аноним 24/05/19 Птн 20:36:11 1405887483
>>1405886
Нет. Ну, накостылить-то можно, а смысл?
Аноним 24/05/19 Птн 20:47:27 1405890484
24/05/19 Птн 20:49:13 1405892485
>>1405886
А универсального апи вообще нет. Оно либо не универсальное, либо ограниченное и не позволяет пользоваться всеми возможностями ОС.
Аноним 24/05/19 Птн 20:50:15 1405894486
>>1405890
Аналогично. Стандартная библиотека не покрывает всего. Хотя странновато, что потоки в нее включили, а получение листинга директории - нет.
Аноним 24/05/19 Птн 20:55:52 1405895487
Перестаньте кормить этого тролля.
Аноним 24/05/19 Птн 20:58:36 1405897488
Аноним 24/05/19 Птн 21:06:01 1405903489
ололо котик.jpeg (71Кб, 700x488)
700x488
Какой АСМ выбрать и как вкатиться побыстряку за пару дней?

Не смог найти книги "АСМ для чяйников", она есть?

Легко ли будет вкатиться после Пайтона?
Аноним 24/05/19 Птн 21:16:12 1405910490
>>1405903
AVR. Желательно 8535.
Методички ЮУрГУ.
С питона слезать будет больно.
Не, ну а хуле?
Аноним 24/05/19 Птн 21:25:45 1405913491
изображение.png (86Кб, 748x814)
748x814
>>1405903
>Не смог найти книги "АСМ для чяйников", она есть?
Аноним 24/05/19 Птн 21:32:26 1405916492
>>1405910
серьёзно давай, ты тупая?
Аноним 24/05/19 Птн 21:38:34 1405922493
изображение.png (46Кб, 1366x728)
1366x728
>>1405916
Это ты тупая. Вот он, ассемблер. Деньги можно зарабатывать.
Аноним 24/05/19 Птн 22:11:50 1405940494
>>1405438
>Тут только ОП-хуй
Куда вы столько пишите? Завтра придётся перекатывать
Настоящий ОП-хуй
Аноним 24/05/19 Птн 22:13:04 1405941495
>>1405922
Что за допотопный шлак?
Аноним 24/05/19 Птн 22:23:24 1405947496
изображение.png (569Кб, 430x615)
430x615
24/05/19 Птн 22:46:24 1405958497
>>1405750
А в чем вопрос-то? У тебя есть два числа, состоящие из BCD-цифр. Берешь и умножаешь цифры в столбик, как в школе. Самый простой метод.

> я черт его знает что там происходит
Ну берутся цифры одну за другой из ввода, приводится ASCII-код к 0..9 (используя тот факт, что '0'...'9' - это 0x30...0x39, поэтому можно просто взять младшие 4 бита), потом это все зачем-то двигается (хотя удобнее и логичнее хранить числа в little-endian, начиная с младшего разряда).

> аам делать ради (исправления чего-то?)
Ну потому что 09h умножить на 02h = 12h не будет валидным неупакованным BCD. И надо отнять и поделить получить две правильные цифры. Можешь это сделать медленнее вручную, через деление на 10, но это займет несколько инструкций, а тебе дали одну удобную, которая сама сделает из 12h = 18 = (18 / 10, 18 % 10) = (ah = 01h, al = 08h).
Аноним 24/05/19 Птн 22:56:56 1405963498
Асмач, что за йоба-функции по типу: _enable(), _disable(), _writecr(), _mm_... итп? Очень часто их вижу в хэдерах, но не понимаю что они делают и для чего вообще нужны? Да, визуал студио.
Аноним 24/05/19 Птн 23:11:56 1405970499
>>1405958
> Берешь и умножаешь цифры в столбик, как в школе. Самый простой метод.
Но не самый эффективный. habr.com/post/451860/
>>1405963
>_writecr
Записывает регистр CR

P.S. Как избавится от уебанской гугкапчи? В настройках поставил 2капчу, не работает. Абу пидарас
Аноним 24/05/19 Птн 23:23:38 1405978500
>>1405970
Так для чего в целом эти команды нужны? Какой спектр задач решать? Там хэдеры сотнями таких команд засраны.
Аноним 24/05/19 Птн 23:24:01 1405979501
>>1405958
А выводить как два регистра сразу?
Аноним 24/05/19 Птн 23:31:41 1405982502
>>1405978
Компутером управлять.
Аноним 24/05/19 Птн 23:41:13 1405989503
>>1405979
Ну например:
or ax,3030h
mov [output+0],ah
mov [output+1],al
mov dx,mesg
mov ah,09h
int 21h

...
mesg db 'Result is '
output db 'XX'
mesg2 db '.', 13, 10, '$'

Или:
or ax,3030h
push ax
mov dl,ah
mov ah,02h
int 21h
pop ax
mov dl,al
mov ah,02h
int 21h
Аноним 24/05/19 Птн 23:53:41 1405993504
>>1405989
Спасибо тебе, мил человек.
Дай бог тебе здоровья.
Аноним 25/05/19 Суб 01:00:16 1406027505
Аноним 25/05/19 Суб 01:03:52 1406030506
>>1405922
Atmel Studio (ранее AVR Studio) — основанная на Visual Studio бесплатная проприетарная интегрированная среда разработки (IDE) для разработки приложений для 8- и 32-битных микроконтроллеров семейства AVR и 32-битных микроконтроллеров семейства ARM от компании Atmel, работающая в операционных системах Windows NT/2000/XP/Vista/7/8/10.

Чо за лажа?
Аноним 25/05/19 Суб 12:52:45 1406214507
Аноним 25/05/19 Суб 13:04:33 1406217508
>>1405872
Скажи это руткитам, которые орудуют на уровне гипервизора и ниже, лол
Аноним 25/05/19 Суб 14:30:20 1406257509
Стикер (0Кб, 512x512)
512x512
>>1406217
> на уровне гипервизора
> и ниже


А если серьезно, то такие только на бумаге в теории есть. В реале запилить рабочий прототип практически невозможно, разве что в лабораторных условиях и то будет работать все через раз.
Аноним 26/05/19 Вск 00:44:07 1406505510
>>1406257
Ты серьезно думаешь, что такие руткиты выкладывают в паблик? Почитай слитые каталоги АНБ, охуеешь, какие вещи успешно реализуют.
Аноним 26/05/19 Вск 03:30:28 1406532511
>>1406505
Хуйню там слили у анб, никакими гипервизорами, фирмваре даже и не пахнет, сам модуль у них тоже тухлый. В паблике как раз есть вещи по-круче, особенно у китайцев.
Аноним 26/05/19 Вск 18:13:38 1406913512
Сап, аноны
Расскажите нубу кто шарит
Есть ли какая-то сила за разработкой драйверов? Ведь код драйвера имеет больше привелегий, нежели рядова прога (кольца 2 и 1, если не ошибаюсь)
Значит ли это, что существуют малвари, написанные в стиле драйверов? Или завернутые в драйвер?
Аноним 26/05/19 Вск 20:34:56 1406997513
>>1406913
Я другой анон. Как устанавливается малварь в виде драйвера?
Аноним 27/05/19 Пнд 01:49:21 1407137514
>>1406913
>Есть ли какая-то сила за разработкой драйверов
Безусловно. Средняя зп ~150 тыс. долларов в год.

>Значит ли это, что существуют малвари, написанные в стиле драйверов
Да.

>>1406997
Как и обычный драйвер, логично же.
Аноним 05/06/19 Срд 19:15:29 1412360515
Ну что у вас тут? Код то мало-мальский написали хоть, или может реверснули чёнить?
Аноним 06/06/19 Чтв 21:29:48 1413049516
Что будет если поделить на ноль на асме?
Аноним 19/06/19 Срд 16:57:24 1418886517
Настройки X
Ответить в тред X
15000 [S]
Макс объем: 40Mб, макс кол-во файлов: 4
Кликни/брось файл/ctrl-v
Стикеры X
Избранное / Топ тредов