Сохранен 529
https://2ch.hk/pr/res/1406213.html
24 декабря Архивач восстановлен после серьёзной аварии. К сожалению, значительная часть сохранённых изображений и видео была потеряна. Подробности случившегося. Мы призываем всех неравнодушных помочь нам с восстановлением утраченного контента!

ASM & Reverse engineering №8 /asm/

 Аноним OP 25/05/19 Суб 12:50:09 #1 №1406213 
15533968268660.png
15533968268661.png
15533968268672.png
15533968268673.png
В этом треде мы изучаем самый компактный и низкоуровневый язык Ассемблер и смежную с ним область: Реверс-инженеринга (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) Ghidra для любителей анальных зондов от АНБ
6) Остальное

Все книги и статьи Криса Касперски (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://rutracker.org/forum/viewtopic.php?t=407571
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/

Предыдущие
№6 https://arhivach.ng/thread/415252/
№7 https://arhivach.ng/thread/437556/
Аноним 25/05/19 Суб 13:31:28 #2 №1406222 
Почему декомпилятор из асм в Си hex-rays до сих пор не отреверсили и не внедрили у себя ребята из radare2 (r2dec)? Это слишком сложно или слишком нинужно?
Вообще "профессиональные реверсеры" этим пользуются ли? Читал, что он иногда некорректно работает.
Аноним 25/05/19 Суб 13:53:44 #3 №1406235 
>>1406222
>radare2 (r2dec)
Не нужен.
Аноним 25/05/19 Суб 14:18:07 #4 №1406250 
>>1406222
Потому что не хотят садится на бутылку.
Аноним 25/05/19 Суб 14:32:36 #5 №1406259 
>>1406222
Пользуются конечно, глупый вопрос. Каким надо быть мазохистом чтобы в статике простыни ассемблерного листинга рассматривать?
Аноним 25/05/19 Суб 17:23:27 #6 №1406318 
>>1406213 (OP)
№8 https://arhivach.ng/thread/455487/

> Ghidra для любителей анальных зондов
Нет там никаких зондов, бесплатная и вполне применима для чего-то серьезного (в отличие от радара).

>>1406222
> hex-rays до сих пор не отреверсил
Потому что он говно. Меньшее говно, чем другие, но все же никому не хочется в этом копаться. Он, как и вся IDA, состоит из хаков. Проще с нуля написать (нет).

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

>>1406259
> Каким надо быть мазохистом чтобы в статике простыни ассемблерного листинга рассматривать?
Жили и до иксрэйсов, и неплохо жили. И сейчас есть куча архитектур, где никаких иксрэйсов нет и никогда не будет, а реверсить как-то нужно.
Аноним 25/05/19 Суб 18:39:35 #7 №1406347 
>>1406318
>Нет там никаких зондов
Кроме случая, когда она открывала порт наружу для отладки...
Аноним 25/05/19 Суб 19:10:31 #8 №1406364 
>>1406347
> когда она открывала порт наружу для отладки
Как будто это единственное в мире приложение на Java, в котором используются отладочные возможности Java. Как будто тебя на машине нет файрвола, а между тобой и интернетом нет роутера. Может быть, и ида, которая ищет своих друзей в твоей локалке, тоже тебя смущает?
Аноним 25/05/19 Суб 21:39:24 #9 №1406450 
kombo-serrated.jpg
Научите АСУ за 10 минут, плизки.
Аноним 25/05/19 Суб 22:03:37 #10 №1406458 
>>1406450
бамп, за 24 часа тогда хотя бы
Аноним 25/05/19 Суб 22:29:00 #11 №1406465 
Аноны, как обнаружить inline hook в рантайме? Следовать за jmp'ами и смотреть где они находятся?
Аноним 25/05/19 Суб 22:29:21 #12 №1406466 
>>1406465
Куда ведут*
Аноним 25/05/19 Суб 22:36:18 #13 №1406468 
>>1406465
Смотреть начало функций, очевидно же.
Аноним 25/05/19 Суб 23:52:51 #14 №1406486 
>>1406468
Не все с начала сплайсят. Тот же пролог стандартный нет никакой проблемы пропустить даже без полноценного дизасма, достаточно дизасма длин.

>>1406465
> Аноны, как обнаружить inline hook в рантайме?
Прочитать секцию кода с диска и сравнить, например. Она обычно ридонли, RWE сейчас не в почете.
Аноним 26/05/19 Вск 02:21:54 #15 №1406525 
>>1406468
Посмотрел. Что дальше?

>>1406486
В рантайме говорю же. Нет на диске ничего.
Аноним 26/05/19 Вск 02:27:23 #16 №1406527 
>>1406486
>RWE сейчас не в почете
Почему?
Аноним 26/05/19 Вск 03:50:54 #17 №1406533 
>>1406525
>Посмотрел. Что дальше?
Дальше через LDE смотришь, а не джамп ли за границу секции это?
Аноним 26/05/19 Вск 03:51:25 #18 №1406534 
>>1406527
Любой антивирь орать начнет даже без эвристики.
Аноним 26/05/19 Вск 20:43:46 #19 №1407006 
sakurako.png
i.PNG
>>1406213 (OP)
>Ghidra для любителей анальных зондов от АНБ
Это вы про дебаг гидры? Порт же закрыть можно. А в новых версиях дебаг по дефолту выключен. В версиях 9.0.2 и 9.0.4 точно.
C каких пор реверсеры боятся зондов?
Аноним 26/05/19 Вск 21:02:51 #20 №1407016 
Где можно почитать про макрос data import в фасме?
Как он устроен?
Аноним 26/05/19 Вск 21:28:30 #21 №1407032 
>>1407016
> про макрос data import
data - не макрос, а директива, она пишет начало и размер блока data в поля IMAGE_NT_HEADERS.OptionalHeader.DataDirectory, import/export/fixups преобразуется в соответствующий индекс директории, но индексы можно указывать и сразу числом.
А вот чтобы понять, как работают макросы library и import, читай в fasm.pdf про forward и common (хотя бы), ну и начать в любом случае нужно с
https://docs.microsoft.com/en-us/windows/desktop/debug/pe-format
Аноним 26/05/19 Вск 21:36:40 #22 №1407039 
>>1407032
>ну и начать в любом случае нужно с
>https://docs.microsoft.com/en-us/windows/desktop/debug/pe-format

Я знаю. Сейчас я собираю свой минимальный PE-имидж по байтам и параллельно пишу лоадер для него. Но в FASM оказалось много неизвестного для меня.
Здесь есть удобный аналог assume edi:IMAGE_DOS_HEADER? Или как его накостылировать?
Аноним 26/05/19 Вск 23:01:43 #23 №1407086 
>>1407039
Нет, макрос assume как бы есть, но работает хуево. Можно еще virtual at edi
dosheader IMAGE_DOS_HEADER
end virtual, но оно глобально и неотменяемо. В целом в фасме принято делать явно mov eax,[edi+IMAGE_DOS_HEADER.e_lfanew]. Больше писанины, зато все сразу понятно.
Аноним 27/05/19 Пнд 19:12:42 #24 №1407535 
32 бит винда ВСЕ? Есть ли смысл в 2019 году разрабатывать wow64 приложение? По статистике стима < 10% пользователей сидят на 32битной винде.
Аноним 27/05/19 Пнд 19:34:56 #25 №1407542 
>>1407535
16 бит всё. А 32 ещё работают.
Хотя в век современных электронов 2 (4) ГБ н"серьёзному" приложению (например пасьянс) не хватает, так что можно смело переходить на 64 бита.
АЛСО, для асма не актуально.
Аноним 28/05/19 Втр 01:01:24 #26 №1407697 
15554108716640.jpg
В прошлом треде я просил посоветовать кроссплатформенный ассемблер (чтобы один код работал везде), мне посоветовали:
nasm/fasm/gas

1) Правильно ли меня поняли насчёт кроссплатформенности?

2) Какой конкретно диалект АСМа выбрать?
Аноним 28/05/19 Втр 02:06:04 #27 №1407719 
>>1407697
В общем я тут почитал и пришёл к выводу, что GAS не нужен.

И выбирать стоит между NASMом и FASMом.

Первый устарел и больше кода писать, но не знаю, как у второго с кроссплатформенностью.
Аноним 28/05/19 Втр 02:15:43 #28 №1407722 
>>1407719
Так, пришёл к выводу, что надо брать FASM, потому что он новее.

Но не знаю, как у него с производительностью относительно NASMа, видимо, хуёвей.
Аноним 28/05/19 Втр 03:57:32 #29 №1407747 
images.jpg
Покопался я тут в "Ассемблерах" для GPU, там полный зоопарк.

Короче, если хочется что-то универсальное, тогда придётся брать фреймворки OpenCL, OpenGL итп. Естественно, это всё высокоуровневая хренотень.

Почему до сих пор не создали хотя бы мало мальски универсальный Ассемблер для GPU?
Даже то, что каждый тянет одеяло в свою сторону, каждый строит свой рынок не должно было сильно помешать подобному проекту.

Видимо, всем просто по хуй.


А посему и смысла использовать ЦП-Ассемблеры нет в игрушках, как и в sci и Big Data. Всё равно эти фреймворки срежут производительность до своего уровня.

Лучше всё хуярить на C/C++.


А Ассемблер только для ОС и драйверов, ещё встраиваемые.
Вот и всё.
Аноним 28/05/19 Втр 11:43:21 #30 №1407838 
>>1407747
Ты прав, АСМ в общем смысле давно мёртв.
Аноним 28/05/19 Втр 13:00:11 #31 №1407870 
>>1407747
>Лучше всё хуярить на C/C++.
Нет, лучше хуярить на питоне/ноде, а критические участки на C/C++
Аноним 28/05/19 Втр 14:04:33 #32 №1407922 
spacetunnel.jpg
>>1407870
Жирдяй, Питон до 100 раз медленней С, а местами всё ещё хуёвей. Node/JS пошустрее (в 2-3 раза), но всё равно говно.

Даже скорость Java говно, а она самая оптимизированная из всех высокоуровневых; в её оптимизацию больше денег вгрохано, чем в Питон и Раби целиком.

Говорят, её скорость приближается к С и C++ (в 2-3 раза медленней всего). На деле фуфло это всё. Она в 10 и более раз медленней С по тестам итд.

А медленней Питона из мейнстримных ЯП нет вообще.
Аноним 28/05/19 Втр 14:15:58 #33 №1407931 
>>1407922
>А медленней Питона из мейнстримных ЯП нет вообще.
руби?
Аноним 28/05/19 Втр 15:35:45 #34 №1407988 
>>1407931
Блд, сказали же, Питон - самый медленный, миллион тестов в сети есть и самых разных.

Питон 4х версий будет уже просто сосать, он станет неприменим для серьёзных проектов. Будут в учебных целях его дрочить, как когда-то ТурбоПаскаль дрочили, чисто, чтобы научиться программировать на базовом уровне, понять основные принципы итд.

А большинство проектов перекатится на Нод/ЖС. Особенно всё, что веб. Питон к 5й версии в вебе и вовсе сдохнет. (Раби ещё подержится.)
К 6й станет устаревшим языком, который только в школках и будут проходить вместо Бейсика и Паскаля, но основное внимание будет уделяться JS.
Потом Питон выкинут и из школ.

К 7й версии Питон станет историей.

Так что я советую вам с этого питоноговна уже сегодня слезть. Учите нормальные ЯП, C++ тот же, или хотя бы ненормальные, но востребованные вроде JS.
Аноним 28/05/19 Втр 16:31:45 #35 №1408044 
Ребята, а какой компилятор или утилита умеет автоматом перехуяривать код АСМа под разные процы (и желательно API ОС автоматом перехуяривать)?
Аноним 28/05/19 Втр 16:32:35 #36 №1408045 
>>1408044
Самый обычный компилятор языка С
Аноним 28/05/19 Втр 16:47:33 #37 №1408060 
>>1408045
И что gcc ошибки не ебашит так никогда?
Аноним 28/05/19 Втр 16:49:24 #38 №1408061 
>>1408045
это сарказм был? :(
Аноним 28/05/19 Втр 16:51:00 #39 №1408062 
>>1408061
Наполовину, милый школьник.
Аноним 28/05/19 Втр 17:02:19 #40 №1408068 
>>1408062
пизда, вали из нашего треда обратно в общий, так и знал, что это ты тут трольнул, продолжая гнуть свою глупую линию, дохуя перегоняльщиков кода, они тебе только уникальную специфику проца не смогут сделать, а стандартный код сделают.
Аноним 28/05/19 Втр 17:08:09 #41 №1408071 
изображение.png
>>1408068
>КУДАХ БАБАХ КУКАРЕКУ
Разрывом фантазирующего школьника удовлетворен.
Аноним 28/05/19 Втр 17:21:35 #42 №1408078 
Мне кажется пора в /d писать репорт на бан этого тролля. Считай вайпает нам уже второй тред.
Аноним 28/05/19 Втр 17:29:54 #43 №1408085 
>>1408078
Ты только не плачь, у меня аллергия на детские слезы.
Аноним 28/05/19 Втр 23:53:45 #44 №1408342 
А что в АСМе нельзя сколько угодно переменных создавать? Хуясе бред.
Аноним 29/05/19 Срд 00:38:23 #45 №1408361 
>>1408342
Кто мешает?
Аноним 29/05/19 Срд 00:40:48 #46 №1408364 
>>1408361
Твоя мамаша.
Аноним 29/05/19 Срд 00:44:49 #47 №1408368 
>>1408364
Так выеби ее.
Аноним 29/05/19 Срд 00:45:43 #48 №1408370 
>>1408368
Ну ты вообще садист, за что ты так со мной.
Аноним 29/05/19 Срд 00:46:31 #49 №1408371 
>>1408370
Ну может думать научишься.
Аноним 29/05/19 Срд 00:49:04 #50 №1408374 
>>1408371
Не хочу не буду.
Аноним 29/05/19 Срд 11:36:00 #51 №1408583 
А что означает двойное использование регистров?
Ну короче, зачем две скобочки?
mov [BX][SI], AL
Почему нельзя просто [BX]?
Аноним 29/05/19 Срд 12:38:58 #52 №1408620 
>>1408583
>mov [BX][SI], AL
То же самое что и MOV [BX+SI], AL
Базовая индексная адресация.
BX - база
SI - индекс
Аноним 29/05/19 Срд 16:10:16 #53 №1408745 
>>1408583
> Ну короче, зачем
Основная причина - попытка приблизить синтаксис к индексации массивов в сишке.
Аноним 30/05/19 Чтв 08:57:30 #54 №1409032 
Как думаете, печему не взлетел IA64? Какие, вообще, есть перспективы у новых наборов инструкций? Я правильно понимаю, что, в конечном итоге, будущее за RISC?
Аноним 30/05/19 Чтв 13:45:08 #55 №1409157 
>>1409032
> печему не взлетел IA64
Очень сложные компиляторы или отсутствие преимуществ, если компилятор хуевый.

> Какие, вообще, есть перспективы у новых наборов инструкций?
Рано или поздно мы к VLIW придем (вернемся).
Аноним 30/05/19 Чтв 15:41:37 #56 №1409251 
>>1409032
Ты и сейчас на риск сидишь, долбоеб.
Аноним 30/05/19 Чтв 15:50:53 #57 №1409259 
>>1409251
Кто не сидит на RISC, тот не любит шампанское.
Аноним 30/05/19 Чтв 19:58:28 #58 №1409422 
>>1409259
Сижу на бутылке шампанского, на риске сидят ваши мамки.
Аноним 31/05/19 Птн 00:45:37 #59 №1409602 
Как в ядре винда свой обработчик исключений зарегистрировать?
Аноним 31/05/19 Птн 03:12:38 #60 №1409643 
>>1409602
Без задней мысли берешь и регистрируешь.
Аноним 31/05/19 Птн 05:48:35 #61 №1409661 
shtampvsehuynyaperedelayivay.jpg
>>1406213 (OP)
ОП, я не понял. Почему в шапке нет книги Рендала Хайда? Какой, нафиг, Зубков? Лучший асм-учебник на русском - Юрова. Не лишним будет упомянуть Интел-талмуды. Где книги Агнера Фога? Можно ещё опус магнум по оптимизации Майкла Абраша привести (хоть и устарело).
Аноним 31/05/19 Птн 06:18:57 #62 №1409667 
>>1409157
>Рано или поздно мы к VLIW придем (вернемся).
Так ли уж нужен параллелизм на уровне инструкций? Это, ведь просто, способ избежать спекулятивного исполнения, не потеряв в производительности. Или я плохо улавливаю идею?
Что думаете про RISC-V?

>>1409251
Телепат в треде?
Аноним 31/05/19 Птн 19:47:39 #63 №1410054 
>>1409661
Ссылки давай, добавлю. А то болтать все горазды, а гидру и ту пришлось гуглить.
Аноним 31/05/19 Птн 22:17:40 #64 №1410094 
>>1409643
Так может подскажешь апи?
Аноним 01/06/19 Суб 00:03:59 #65 №1410117 
>>1409602
Добавить в начало SEH
Аноним 01/06/19 Суб 03:17:14 #66 №1410158 
>>1410054
Вот накидал. Сам выбери, что больше подходит.
http://booksdescr.org/item/index.php?md5=9C0F88DC623FCE96A4F5B901ADCE95D3
http://booksdescr.org/item/index.php?md5=73957AEFEADCB7F0C112DCAED165FEB6
https://software.intel.com/en-us/articles/intel-sdm
https://www.agner.org/optimize/
http://booksdescr.org/item/index.php?md5=4AA9BC0EB46F82759D5A88876072B52C
http://booksdescr.org/item/index.php?md5=5D0F6DBC1410E10BC489167AFE8192DF
sage[mailto:sage] Аноним 01/06/19 Суб 11:02:28 #67 №1410199 
>>1410158
> intel-sdm
Они уже есть в шапке.
Аноним 01/06/19 Суб 11:26:19 #68 №1410206 
ЧСНДИ.png
Как под все платформы сразу писать, будто ты на С пишешь?
Аноним 01/06/19 Суб 11:40:29 #69 №1410211 
>>1410206
Берёшь, такой, C и пишешь под все платформы, будто ты на С пишешь.
Аноним 01/06/19 Суб 11:43:14 #70 №1410212 
asm.jpg
>>1410199
Не заметил.
Вот ещё Абраш http://booksdescr.org/item/index.php?md5=ED318BFDC1D842E73E6615CE41F9417D
Может быть ещё что-нибудь добавлю, если вспомню.
Аноним 01/06/19 Суб 13:01:31 #71 №1410247 
Как на фасме написать такой макрос?

%define round(n, r) (((n+(r-1))/r)*r)
Аноним 01/06/19 Суб 15:16:16 #72 №1410342 
Я неопытен в фасме. Хочу написать модуль для логирования в файл. Соответственно, внутри объектника должны определяться переменные для дескриптора открытого файла, форматной строки и функция, приинимающая произвольные строки, которыезаписываются в файл. Мне это нужно для тщательного логирования того, что происходит внутри программы. Как можно создать такой модуль и подключить к программе?
Аноним 01/06/19 Суб 16:12:03 #73 №1410358 
В линуксовых shared object'ах extern переменные и функции в двух разных процессах будут иметь один и тот же виртуальный адрес, или могут (и должны) иметь одинаковые значения в младших битах адреса, но разные в старших из за какого нибудь ASLR? При этом для обоих процессов они имеют одинаковый физический адрес до первой записи?
sage[mailto:sage] Аноним 01/06/19 Суб 21:43:31 #74 №1410480 
>>1410247
К сожалению, в фасме макросы не могут возвращать значения. Можешь сделать так:
macro round n, r { rounded = (((n+(r-1))/r)*r) }
round 12,5
; и используешь:
mov eax,rounded
Аноним 01/06/19 Суб 23:08:17 #75 №1410521 
>>1410480
А как написать макрос, который бы получал value и align, но генерировал в результате директиву dd aligned_val?

То есть, чтобы можно было написать _align(filesize, 512), и получить код типа dd 512?
Аноним 01/06/19 Суб 23:10:14 #76 №1410523 
>>1410521
Только что проверил макрос. У меня filesize equ $ - $$ определено в конце исходника и компилятор ругается на то, что filesize не определена.
Аноним 02/06/19 Вск 08:01:36 #77 №1410579 
>>1410054
Может ещё добавите несколько полезных ссылок?

http://www.cs.cmu.edu/~ralf/files.html
http://www.sandpile.org/
https://en.wikipedia.org/wiki/X86_instruction_listings
https://www.felixcloutier.com/x86/index.html
http://ref.x86asm.net/index.html
https://pnx.tf/files/x86_opcode_structure_and_instruction_overview.png
http://www.jegerlehner.ch/intel/
Аноним 02/06/19 Вск 08:12:53 #78 №1410580 
Как условному Васяну получить EV сертификат для подписи дров? И нужен ли он вообще? Обычный не прокатит что-ли? Гуглить пробовал, там одни диваны, сами толком не знают.
sage[mailto:sage] Аноним 02/06/19 Вск 10:48:39 #79 №1410614 
>>1410523
> У меня filesize equ $ - $$ определено в конце исходника
Ты хотел сделать filesize = $ - $$. = обрабатывается на стадии ассемблирования, оно создает или изменяет настоящую переменную (ассемблера, а не генерируемой программы естественно), фасм умеет в forward references (ценой дополнительного прохода ассемблирования). А вот equ работает в препроцессоре, ничего про переменные не знает, это просто текстовая замена, работающая от equ и до конца файла (или до отмены equ c помощью restore). Даже если предположить, что твой equ сработал бы, как ты хотел, то $ в месте использования отличался бы от $ в месте, где ты создал equ.
Аноним 02/06/19 Вск 12:08:19 #80 №1410632 
О круто, тред про ассемблер. Я полный ноль в этом, но хочу вкатиться. Что надо скачать чтобы получить хоть какое-то начальное представление, а то в шапке дохуя написано. Посоветуйте одну книгу и одну прогу пока.
Аноним 02/06/19 Вск 12:34:52 #81 №1410645 
>>1410632
Пишешь на си, вставляешь в godbolt и смотришь код. Книга же beginners.re.
Аноним 02/06/19 Вск 12:53:59 #82 №1410652 
>>1410614
Что-то как-то стремно решается моя надуманная задача на фасме. Возьму, пожалуй, NASM. Я собираю минимальный PE-имидж по байтам и параллельно пишу лоадер. Хочу сделать имидж меньше 200 байт.
Аноним 02/06/19 Вск 12:59:28 #83 №1410654 
>>1410652
Если по байтам, бери fasmG. Что за лоадер?
Аноним 02/06/19 Вск 13:19:10 #84 №1410662 
>>1410654
PE Loader
Аноним 02/06/19 Вск 13:23:19 #85 №1410666 
>>1410652
Я собираю PE файл таким образом:

opthdr:
dw 0x10B ; Magic (PE32)
db 0 ; MajorLinkerVersion UNUSED
db 0 ; MinorLinkerVersion UNUSED
dd 0 ; SizeOfCode
dd 0 ; SizeOfInitializedData UNUSED
dd 0 ; SizeOfUninitializedData UNUSED
dd start ; AddressOfEntryPoint
dd code ; BaseOfCode UNUSED
dd 0 ; BaseOfData UNUSED
dd 0x400000 ; ImageBase
dd sectalign ; SectionAlignment
dd filealign ; FileAlignment
dw 0 ; MajorOperatingSystemVersion UNUSED
dw 0 ; MinorOperatingSystemVersion UNUSED
dw 0 ; MajorImageVersion UNUSED
dw 0 ; MinorImageVersion UNUSED
dw 4 ; MajorSubsystemVersion
dw 0 ; MinorSubsystemVersion
dd 0 ; Win32VersionValue UNUSED
dd 0 ; SizeOfImage
dd 0 ; SizeOfHeaders

Здесь SizeOfImage равно нулю, но я хочу записать туда размер дискового образа, выровненный на section aignment. Размер файла определяю так: filesize equ $ - $$
Как написать макрос, чтобы сделать dd выровненное значение размера файла?
В NASM та же самая проблема с макросами.
Аноним 02/06/19 Вск 13:32:27 #86 №1410674 
>>1410666
Что-то в фасме сложно делаются простые вещи. Мне нужно в файловом заголовке сохранить значение SizeOfOptionalHeader. Я делаю это так:

dw opthdrsize ; SizeOfOptionalHeader (including data directories)

Сразу после опционального заголовка, непосредственно после дата директорий я делаю объявление:

opthdrsize equ $ - opthdr

И фасм при формировании File Header не видит переменную opthdrsize, потому что она определена дальше. Как это исправить?
Аноним 02/06/19 Вск 14:07:03 #87 №1410691 
>>1410674
На всякий случай оставлю ссылку https://board.flatassembler.net/topic.php?t=17955
Аноним 02/06/19 Вск 14:10:51 #88 №1410696 
>>1410674
equ - текстовая замена. Для определения означиваемых переменных исползуй =
Аноним 02/06/19 Вск 14:30:42 #89 №1410714 
>>1410662
Что он должен делать? Загужать исполняемые образы для исполнения? Вместо системного загрузчика?
Аноним 02/06/19 Вск 14:59:58 #90 №1410735 
>>1410714
>Загужать исполняемые образы для исполнения? Вместо системного загрузчика?
Да. Еще хочу добавить к нему защиту от динамического анализа.
Что сейчас актуально? Видел детект VM Ware по GDT, защиту от рантайм анализа при помощи сообщений из других потоков, коды возврата недокументированных апи. Все это, вроде, устарело. Но кода я только начал этим заниматься, детект движения курсора лучше всего останавливал динамическую проверку.
Как работают эмуляторы? Они передают управление на точку входа и анализируют поведение программы, или действуют более тщательно, дизассемблируют каждую процедуру и трассируют ее? В последнем случае, наверное, можно было бы навставлять в процедуры ret и перепрыгивать их при выполнении. Это должно запутать дизассемблер, если он дизассемблирует от начала функции до ret. Но это, наверное, слишком наивный способ обойти дизассемблирование.
Аноним 02/06/19 Вск 15:31:32 #91 №1410764 
>>1410735
Я еще не могу для себя точно объяснить разницу между отладкой и трассировкой. Там, где я работал, слово трассировка вообще не употребляли. А в лоу лвл кодинге оно используется часто. Я нагуглил тред о различии отладки и трассировки, и там говорится, что отладка - это пошаговое выполнение, а трассировка это пакетный анализ поведения программы: запускаешь программу и смотришь журнал выполнения, по которому определяешь место проблемы, после чего начинаешь в этом месте отладку. То есть и принтф, и логи в консоль, и журнал в файле, и MessageBox'ы с ошибками можно назвать трассировкой. Я прав?
sage[mailto:sage] Аноним 02/06/19 Вск 16:20:09 #92 №1410787 
>>1410652
> Что-то как-то стремно решается моя надуманная задача на фасме
На насме будет еще хуже, фасм в плане ебли байтов гораздо мощнее.

>>1410666
> я хочу записать туда размер дискового образа, выровненный на section alignment
Ну я же тебе написал, как сделать.
dd (SizeOfImage + sectalign - 1) and not (sectalign - 1)
...
; В конце файла:
SizeOfImage = $ - $$ ; тут возможны варианты, в зависимости от того, хочешь ли ты ебаться в org в секциях.
Что сложного-то?
Аноним 02/06/19 Вск 17:09:06 #93 №1410832 
>>1410579
Конечно. Правда ссылка на вики это моветон, если реверсер её не найдёт, то он и в ИДЕ не разберётся, и компутер не включит.
>>1410580
Зарегистрировать компанию, только им и выдают. Можно попросится подписать у пары компаний, которые подписывают дрова с открытым кодом, но там, ВНЕЗАПНО, нужен открытый исходный кот, твои затрояненные бинари отошлют тебе обратно.
>>1410632
>а то в шапке дохуя написано
Я тебя разочарую, но в книгах по асму написано ещё больше, чем в шапке. Если ты шапку ниосилил, то и асми не осилишь.
Аноним 03/06/19 Пнд 08:12:40 #94 №1411144 
>>1410832
Почему малварь-то сразу? Те кто создают малварь подобного уровня, спонсируются и достать такой серт им не составит труда. А мне Васяну где и как его взять? Я может хочу свой антивирус бабушкина с блэкджэком и куртизанками запилить. Но думаю начать с мини-тулз, типа sysinternals. Есть конечно вариант опенсурса, гит прокачаю, портфолио так сказать, но думаю шанс, что меня кто-то заметит и озолотит мизерный..
Аноним 03/06/19 Пнд 14:26:38 #95 №1411260 
Есть здесь, вообще, специалисты/ценители демосцены? Скажите, как научиться далать демки? Что можно почитать? Как практиковаться?
Аноним 03/06/19 Пнд 14:49:53 #96 №1411266 
репост из сишного треда

Что для gcc значит contstraint "c" в записи
asm volatile("clflush 0(%0)\n"
:
: "c"(addr)
: "rax");

не могу найти описание именно для "с"
Аноним 03/06/19 Пнд 15:29:54 #97 №1411281 
>>1411260
Оно тебя сожрет. Здесь уже был один безработный бывший демосценер
Аноним 03/06/19 Пнд 18:13:03 #98 №1411346 
>>1410211
А на FASM?
Аноним 03/06/19 Пнд 20:03:04 #99 №1411372 
>>1411346
Ты ебанутый? Только честно отвечай.
Аноним 03/06/19 Пнд 21:47:04 #100 №1411414 
>>1411372
естественно, но это не имеет отношения к делу.
Аноним 04/06/19 Втр 00:51:14 #101 №1411497 
>>1411414
Это Дела Отношения имеет тебя.
Аноним 04/06/19 Втр 05:43:02 #102 №1411529 
>>1411497
ты поехавший?
Аноним 04/06/19 Втр 08:17:56 #103 №1411550 
>>1407719
И чем GNU as не устроил?
Аноним 04/06/19 Втр 08:24:42 #104 №1411555 
>>1409661
Interrupt list Ральфа Брауна on-line:
http://www.delorie.com/djgpp/doc/rbinter/ix/
Аноним 04/06/19 Втр 08:26:42 #105 №1411557 
>>1410054
Michael Abrash's Graphics Programming Black Book Special Edition

http://www.phatcode.net/res/224/files/html/index.html
Аноним 04/06/19 Втр 08:44:29 #106 №1411563 
>>1410632
Питер Абель. Ассемблер и программирование для IBM PC

http://www.lib.ru/CTOTOR/IBMPC/abel.txt
Аноним 04/06/19 Втр 08:58:52 #107 №1411567 
>>1411260
https://www.youtube.com/watch?v=51BOp5Pi4mU
Аноним 04/06/19 Втр 13:01:04 #108 №1411669 
>>1411563
Ты бы еще Нортона притащил.
Аноним 04/06/19 Втр 13:19:05 #109 №1411676 
поясните мне пж за следующий аспект кэш памяти процессоров.
вот есть у меня программа, которой нужно прочесть N байт по адресу 0xAAAABBBB. процессор может закешировать эти данные, и они будут от L1 до L3. вот процессор начинает выполнять команду типа
add %(0xAAAABBBB), %eax,
он такой возьмёт VA, получит с него PhA, с PhA хеш получит какой нибудь 0xABCD, но! как он знает, что сейчас в кеше для данного адреса под индексом 0xABCD лежит чанк именно для текущего процесса и именно для нужного VA, а не из какого нибудь другого процесса, что выполнялся до последнего прерывания, и если одному блоку данных в кеше могут соответствовать несколько физических адресов, в которых могут находиться данные того же самого процесса?
Аноним 04/06/19 Втр 13:27:47 #110 №1411683 
>>1411676
Смотрел недавно лекцию на данную тему, но проебал ссылку. Короче все сводится к тому, что... нихуя толком не говорится как это работает, ПРОСТО работает и все.
Аноним 04/06/19 Втр 16:06:43 #111 №1411763 
>>1411676
> именно для текущего процесса
Какие процессы, если речь идет о физических адресах? Вот в TLB есть всякие PCID/ASID.

> если одному блоку данных в кеше могут соответствовать несколько физических адресов
Рядом с данными хранится индекс кэшлайна.
Аноним 04/06/19 Втр 18:55:29 #112 №1411845 
>>1411669
Очень доступное изложение информации. Нортона не читал. Твои какие предложения?
Аноним 04/06/19 Втр 21:08:10 #113 №1411923 
https://m.habr.com/ru/company/jetinfosystems/blog/454576/
Почему ты еще не сделал свою малварь на два миллиарда баксов?
Аноним 04/06/19 Втр 21:38:32 #114 №1411960 
>>1411923
тому что я не очень умный
Аноним 05/06/19 Срд 00:21:00 #115 №1412005 
>>1411923
Спалятся потом где-нибудь, как malware-tech и сядут на бутылку. Даже если не спалятся, то за такие бабки их фбр где угодно найдут.

Вы мне лучше скажите, как сломать F5 в иде, дабы подпортить жизнь школоте? Видел много раз в комерческом софте такие функции. Это из серии виртуализации?
Аноним 05/06/19 Срд 00:45:21 #116 №1412007 
>>1412005
> как сломать F5 в иде
Если против школоты, то просто сломай стек в функции.
Аноним 05/06/19 Срд 01:35:38 #117 №1412010 
>>1412005
Стандартные антидизасмы на иде работают.
Заспагеть там все, джампай в середину инструкции, или, как выше сказали, стек ломай.
Аноним 05/06/19 Срд 11:59:52 #118 №1412154 
>>1412010
>джампай в середину инструкции
Как это на деле реализуется? Вот джампну я на байт ModRM или SIB. Что дальше делать, чтобы процессора не выдал исключение?
Аноним 05/06/19 Срд 12:00:38 #119 №1412155 
>>1412010
>стек ломай
А это как?
Алсо, здесь есть знатоки стекового полиморфизма? Что это такое?
Аноним 05/06/19 Срд 12:20:53 #120 №1412160 
>>1412154
>Как это на деле реализуется?
>>1412155
>А это как?
Берешь и без задней мысли гуглишь "защита от дизассемблера".
Аноним 05/06/19 Срд 12:29:50 #121 №1412167 
>>1411567
А есть какие-нибудь базы с исходниками демок?
Мне бы какие-нибудь обучающие материалы. Или что-то, что можно использовать для обучения.

>>1411281
Почему так?
Аноним 05/06/19 Срд 13:01:04 #122 №1412198 
>>1412167
>А есть какие-нибудь базы с исходниками демок?
http://www.pouet.net/search.php?what=source&type=prod
Аноним 05/06/19 Срд 19:19:20 #123 №1412364 
Ну что у вас тут? Код то мало-мальский написали хоть, или может реверснули чёнить?
Ксорить то хоть умеете?
Аноним 05/06/19 Срд 19:24:01 #124 №1412365 
>>1412364
Перефразирую: Когда уже ассемблер будет работать на вас, а не наоборот?
Аноним 05/06/19 Срд 19:35:00 #125 №1412373 
>>1412364
Дворды в уме ксорим, в мокток стучим.
Аноним 05/06/19 Срд 20:30:08 #126 №1412401 
>>1412365
Никогда. Заведомо играем с нулевой суммой. Вся суть байтоёбли.
Аноним 05/06/19 Срд 20:37:47 #127 №1412406 
>>1412010
>Заспагеть там все, джампай в середину инструкции
Ида вроде бы справляется с этим. JMPOUT пишет.

>>1412007
Что значит сломать стек?

>>1412160
>Берешь и без задней мысли гуглишь "защита от дизассемблера".
Там одни баяны и нулевых, под x64 вообще 0 информации.
Аноним 06/06/19 Чтв 00:07:49 #128 №1412650 
>>1412406
> Что значит сломать стек?
Разбалансировать. Например, чтобы в одной из веток был ret при оставшихся в стеке локальных переменных. Или вызов функции, которая за собой подчищает стека больше, чем ей передали параметров. Реально передавать управление в эти ветки вовсе не обязательно, лишь бы они были. HexRays очень чувствителен к такому, но исправляется оно элементарно, поэтому помогает только от школоты.
Аноним 06/06/19 Чтв 10:06:42 #129 №1412736 
>>1406465
Разобрался. Теперь следующий вопрос: как убрать инлайн хук в рантайме? На диске нет данных, предварительных данных тоже нет.
Потыкал всякие антируткиты, они каким-то магическим образом имеют предыдущие байтики и спокойно убирают хук.
Аноним 06/06/19 Чтв 11:28:34 #130 №1412757 
>>1412650
не знаю, насколько это реально и вообще полезно в боевых условиях, но я как то раз в образовательных целях на элементарной х86 программе в хэдерах пидорасил ОЕР, заведомо указывая его в ебеня, а потом в TLS коллбэке опционально восстанавливал, прибавляя захардкоженную дельту к одному месту в памяти. не помню точно как это работало, но то ли на +-0х1000 байт от EBP то ли еще где неподалеку лежал не то VA с уже прибавленной дельтой релоков, не то RVA OEP, куда должно выполнение перейти после TLS. ну и в итоге ОЕР восстанавливалась, а ида смотрела на неправильный ОЕР со всеми вытекающими.
Аноним 06/06/19 Чтв 12:06:05 #131 №1412771 
>>1412373
Арви Хрюкер?
Аноним 06/06/19 Чтв 17:36:03 #132 №1412915 
>>1412771
Причём тут хохлы?
Аноним 06/06/19 Чтв 18:37:24 #133 №1412941 
Сап,кто знает можно ли получить триал вирустотал интележенс?мне буквально пару сэмплов скачать нужно
раньше давали триалы всем подряд,а теперь не выходит(вроде как только фирмам типа ав и студентам(и то не всем)
если у кого-то есть,то буду очень благодарен если поможете
Аноним 06/06/19 Чтв 19:12:59 #134 №1412965 
Анонче, как подпрограммы строить на ассемблере?

Можно пример программы с подпрограммой?
А то я в методичке смотрел, а там какая-то хуйня запутанная.

У меня такой вариант задачи, но это так ради понимания уровня задачи. Не нужно слишком сложное.
Разработать подпрограмму, которая разбивает заданную строку на две части: первое слово строки (до первого пробела) и оста-ток строки (пробелы после первого слова отбрасываются). Разработать программу, которая вводит с клавиатуры строку и выводит каждое слово с новой строки.
Сложна, сложна, нипанятна.
Аноним 06/06/19 Чтв 20:38:07 #135 №1413013 
>>1412155
в vx журналах почитай
Аноним 06/06/19 Чтв 21:09:12 #136 №1413031 
Заранее извиняюсь за то, что насру здесь.
Я хочу вкатиться взламывать разный софт и писать под него патчи/кейгены, но я полный ноль.
Мне посоветовали:
а) Сначала подучить лёгкий язык вроде питона и обмазаться курсами по CS, а потом уже начинать медленно бросать взгляд в сторону ASM
б) Сразу учить Ассемблер, стоически переносить сложности, попутно читая те же курсы по CS и в целом про особенности различного железа
На какой стул себя посадить, а на какой не стоит? Важно ваше мнение, анончики.
Аноним 06/06/19 Чтв 21:24:30 #137 №1413045 
>>1413013
В 29A такое можно найти?
Аноним 06/06/19 Чтв 21:44:54 #138 №1413057 
>>1413031
Идея хуйня. Современный CS это такая хуйня для неосиляторов и мочеглотов, способных только языком чесать. Язык какой-то учить? Ну разве что всякие кресты/си, на которых системы/АПИшки для железа написаны да шеллчики. Интересно сидеть инструкции дрочить? => Сиди дрочи насм дальше, и нахуя тебе этот пайтон сдался тогда? Советую тебе учебников по информатике закупить для 1-3 курсов для начала.
Аноним 07/06/19 Птн 00:16:26 #139 №1413102 
>>1413057
> нахуя тебе этот пайтон сдался тогда
Да без питона сейчас никуда. Анализ же. capstone, frida всякая, скрипты в IDA.
Аноним 07/06/19 Птн 11:23:08 #140 №1413202 
>>1412941
Есть куча других бесплатных ресурсов откуда можно скачать свежие сэмплы. Кто-то даже вт зеркалит.
Аноним 07/06/19 Птн 11:31:56 #141 №1413208 
>>1413102
К питону возвращаться можно и нужно, только когда ты уже успешный c/c++ боярин, ресерчер, сеньер-байтоеб и знаешь что тебе нужно. А так это довольно бесполезный яп.

>>1413031
Учи ассемблер, изучай архитектуру ос, учись пользоваться тулзами: ida pro, windbg.
Аноним 07/06/19 Птн 11:32:30 #142 №1413209 
>>1413202
например?на стандартных типа апп ани ран и вируссигн ничего нету
Аноним 07/06/19 Птн 14:18:36 #143 №1413282 
>>1413208
>windbg
Ну ты и посоветовал. Ладно бы он сплоенты изучал. Ему же просто обычным крякером хочется стать.
Тут лучше ollydbg/x64dbg ничего не придумали.
К ним и туторов масса, и плагины на любой вкус и цвет, и скрипты под плагины, и кодериперы для кейгенов.
Аноним 07/06/19 Птн 15:06:12 #144 №1413292 
DennisYurichev.jpg
>beginners.re - "Reverse Engineering для начинающих"- бесплатная современная книга на русском языке. К прочтению вкатывающимся и прочим ньюфагам обязательна!
>Чтобы не палить свой адрес почты, вот прямая ссылка https://beginners.re/f572d396fae9206628714fb2ce00f72e94f2258f/
Что-то ссылка поломалась, как и новорегнутые на самом beginners.re((
Желающие натянуть латексное белье с затычкой - велкам на гитхаб, собирать книгу сами:
https://github.com/DennisYurichev/RE-for-beginners
Для нежелающих ссылка на собранную сегодняшнюю RU/EN копию:
https://dropmefiles.com/ESdEP
Наверное хватит переждать, пока господин Юричев починит свою хитрую систему сбора адресов.
Аноним 07/06/19 Птн 15:22:52 #145 №1413298 
>>1413282
Считаю что нужно сразу самые лучшие и мощные инструменты изучать, крупную рыбу олей не подебажишь. Для старта x64dbg подойдет, ты прав.
Аноним 07/06/19 Птн 15:31:44 #146 №1413303 
Предлагаю шапку обновить, ибо протухла. Нужны ссылки на свежие, активные блоги. Книги/гайды по современному ассемблеру.
Раз скрины из ядрер ОС, то следует и добавить блоги/гайды/любой другой ресерч по осям.
Аноним 07/06/19 Птн 15:35:03 #147 №1413304 DELETED
>>1406213 (OP)
ЗДАРОВ АНОН
смотрю тут асму пишите
а ччистаай синятину?

подмагите пожалуйста
.........

задача
есть датчиг время опроса его некритично
но точности желаеца
погромачиг
я страдаю
я беру карочи
и немогу понять
почему 48
Аноним 07/06/19 Птн 15:36:13 #148 №1413305 DELETED
все хотят чтобы просто написать 1=2
Аноним 07/06/19 Птн 15:47:47 #149 №1413310 DELETED
и можно пойти в армию
метеорологом
меня научили
да да пограмистинешы
самоек главноке понимать
процесс ф
именоо и именооно...
матиматика
это вообще ...
вот почему уобного код работает 8 минут
а у второго просто глазом виднол
https://www.youtube.com/watch?v=6CF4wUFnp3M
1 4 7 0 3 5 7 9 2
Аноним 07/06/19 Птн 15:55:25 #150 №1413314 DELETED
вот бы придумать не зависящий от времени
Аноним 07/06/19 Птн 16:29:36 #151 №1413338 
Хочу написать простой драйвер под винду. Какой SDK качать, чтобы можно было кодить в студии?
Когда я в первые хотел этим заняться, помню, что пришлось поебать себе мозги тем, какие библиотеки скачать. Я нагуглил статьи для ньюфагов и пошел на сайт МС за либами, а там оказалось, что того пакета либ уже не существует и надо качать что-то другое.
Аноним 07/06/19 Птн 16:40:51 #152 №1413341 DELETED
https://youtu.be/DG2TRdz6oUg?t=1189
эта масть лиждлябогов рожеа
я тебек с наги в лицо
они говоряитаною
Аноним 07/06/19 Птн 16:52:58 #153 №1413349 DELETED
>>1413338
ты мой трашнай
разрешаю
необходимо
Аноним 07/06/19 Птн 17:25:27 #154 №1413363 
>>1413338
WDK установи и все. Create new project -> Windows Drivers -> и тут выбираешь что тебе нужно. Начать наверное лучше будет с легаси либо wdf драйверов. Спрашивай если будут вопросы.
Аноним 07/06/19 Птн 18:02:25 #155 №1413380 DELETED
>>1413314
>\t
>вот бы придумать не зависящий от врем
именно гже
есть блоки котораи более эфективно вып\олняют
эт мех дейсчтвия
я мервый
ветер я
https://youtu.be/DG2TRdz6oUg?t=1800
Аноним 07/06/19 Птн 20:51:05 #156 №1413406 
>>1413303
Давай ссылки, обновлю.
Аноним 07/06/19 Птн 21:47:55 #157 №1413431 
>>1413310
ты че отсидел уже?
Аноним 07/06/19 Птн 22:20:38 #158 №1413440 
>>1413406
Ой, ну это уже думать надо. Windows Internals книгу в шапку нужно запихать точно, в нескольких тредах упоминали её.
http://undocumented.ntinternals.net - описание недокументированных апи в шапке только структуры
https://vimalshekar.github.io/blog/ - основы для вкатывальщиков, за пару вечеров можно осилить.
Книгу - Modern X86 Assembly Language Programming: 32-bit, 64-bit, SSE, and AVX 1st edition.
Книгу по Идочке.


Кстати, спасибо анону, который залил Rootkits and Bootkits книжку, читаю потихоньку




Аноним 07/06/19 Птн 23:46:13 #159 №1413483 
>>1413363
>Начать наверное лучше будет с легаси либо wdf драйверов.
Это какой тип проектов в VS Studio 2019 Preview?
Аноним 08/06/19 Суб 04:53:25 #160 №1413526 
>>1413440
>Modern X86 Assembly Language Programming...
http://booksdescr.org/item/index.php?md5=3DFB070C1742F50B500F07A63A30C86A
Аноним 08/06/19 Суб 05:31:46 #161 №1413529 
>>1413526
Это второе издание, посвещённое x86-64, AVX, AVX2, AVX-512. Оно не заменяет первое (x86-32, x87, MMX, SSE, а также x86-64 и AVX). Оно частично с ним пересекается. Но в основном его дополняет. Поэтому, нужны оба.
http://booksdescr.org/item/index.php?md5=A6F924CE6277FB3D4AFA71E35F538558
Аноним 08/06/19 Суб 11:58:14 #162 №1413567 
>>1413363
Поставил WDK, создал в студии проект типа KMDF Driver, начал писать код, но #include <ntddk.h> не может найти хедер. Где искать этот хедер и wdf.h?
Аноним 08/06/19 Суб 13:37:45 #163 №1413603 
Хочу обмазаться этими статьями: https://vxlab.info/wasm/article.php-article=drvw2k01.htm

Автор использует масм и советует скопировать библиотечные файлы из DDK в каталог \masm32\lib\w2k. Но у меня win10 и стоит WDF. Как использовать то, что у меня имеется, для изучения этих статей?
Аноним 08/06/19 Суб 13:38:06 #164 №1413604 
>>1413603
>WDF
WDK
Аноним 08/06/19 Суб 17:03:40 #165 №1413697 
>>1413567
Там же где и все остальные инклуды.
C:\Program Files (x86)\Windows Kits\10\Include\

Подключать там же, в настройках проекта, принципиальных различий в использовании ide нет.
Аноним 09/06/19 Вск 11:54:13 #166 №1413988 
Что будет если поделить на ноль на асме?
Аноним 09/06/19 Вск 12:41:06 #167 №1414002 
>>1413988
Прерывание.
Аноним 09/06/19 Вск 14:18:13 #168 №1414048 
>>1414002
Неинтересно
Аноним 09/06/19 Вск 15:26:06 #169 №1414065 
>>1413988
divide by zero exception
Аноним 09/06/19 Вск 17:19:55 #170 №1414126 
>>1413988
>>1414002
>>1414065
Это смотря чем поделить. Кроме div/idiv есть еще инструкции в FPU/SSE.
Аноним 09/06/19 Вск 17:57:56 #171 №1414142 
>>1413526
Как скачать?
Аноним 09/06/19 Вск 19:02:06 #172 №1414179 
i.jpg
q.PNG
>>1414142
https://b-ok.cc/book/3640076/d00285/?_ir=1
Аноним 09/06/19 Вск 21:09:25 #173 №1414233 
>>1414179
Спасибо, анончик.
Аноним 10/06/19 Пнд 11:35:30 #174 №1414406 
>>1413045
Мне что-то попадалось на тему полиморфизма в стеке. Может z0mbie что-то писал на эту тему.
Аноним 10/06/19 Пнд 16:19:20 #175 №1414531 
Допустим, у меня есть адрес возврата некоторой функции, как мне определить какой конкретно функции принадлежит данный адрес? Нашел только LdrFindEntryForAddress, с помощью данного апи получаю имя модуля, в котором находится нужная функция. Куда дальше копать? Не самому же сканить с дизасмом?
Аноним 10/06/19 Пнд 21:19:40 #176 №1414645 
>>1414531
https://docs.microsoft.com/en-us/windows/desktop/api/winnt/nf-winnt-rtllookupfunctionentry
Аноним 12/06/19 Срд 23:27:35 #177 №1415527 
Что такое SMM ring -2 ? Еще более менее могу себе представить гипервизоры. Но куда ниже то?
Аноним 13/06/19 Чтв 00:41:24 #178 №1415555 
>>1415527
Отдельный режим процессора, который включается при подергивании соответствующей ноги процессора, который в отдельной области памяти выполняет код, практически незаметно (не считая потраченного процессорного времени) и не спрашивая разрешения у гипервизоа и выше.

> Но куда ниже то?
Ну как это куда?! Отдельный чип, который рулит всей системой.
Аноним 13/06/19 Чтв 03:05:21 #179 №1415585 
>>1415555
Если у ОС нет доступа к SMM, то выходит, попасть в него без физического контакта с машиной не выйдет?
Аноним 13/06/19 Чтв 13:44:20 #180 №1415786 
посоветуйте пж годных статей по структурам дампов ОС. типа вот если сдампить процесс винды, то у него будет структура РЕ, в ней там хэдеры, секции, тоси боси, у линуксов ELF с его структурами, а с ОС что? все запросы в гугле переводят на конкретные инструменты типа lime, volatility, а я хотел бы предварительно просто пробежаться по теоретический части структур дампов популярных ОС типа чё в них есть, что в них может быть, чего в них не может быть, как это в теории должно быть выложено, и т.д.
Аноним 13/06/19 Чтв 14:21:53 #181 №1415794 
>>1415786
Что ты имеешь ввиду под структурами дампов ОС? Читай книги по архитектуре интересующей тебя ОС. Структуры, функции, таблицы и прочее вычленяются с помощью отладочных символов и WinDbg.
Аноним 13/06/19 Чтв 14:34:54 #182 №1415798 
>>1415786
>если сдампить процесс винды, то у него будет структура РЕ
Чего?
Аноним 15/06/19 Суб 17:10:37 #183 №1416872 
Читаю про аппаратно-программные руткиты, которые в прошлом веке располагались в святая святых BIOS материнки и сетевухи. Насколько это актуально сейчас, когда в материнках UEFI? Дело в том, что мои компы побывали в органах. Данные на дисках затер нулями.
Аноним 15/06/19 Суб 19:38:57 #184 №1416937 
>>1416872
То что на это способны наши органы, я сомневаюсь. Естественно сбросить и переустановить прошивку нужно на всякий случай. Более вероятно что тебя будут просто прослушивать. Меняй провайдера, шифрую трафик, сиди с вайфая соседа.
Аноним 15/06/19 Суб 22:13:32 #185 №1416982 
Как лучше заимплементить PE-загрузчик на фасме, если перед загрузкой происходит парсинг заголовков, а после него мапинг?
Определить все структуры, реализовать структуру контекста, в которую напихать все структуры (или наиболее значимые поля) и в процессе парсинга заполнять контекст, а во время отображения дискового образа на память пользоваться этим контекстом?
Аноним 15/06/19 Суб 22:20:40 #186 №1416984 
Поясните по факту, почему какой-нибудь линукс не может заебашить себе читалку и выполнялку для екзешников, чтобы все работало без эмуляторов?
Аноним 15/06/19 Суб 22:46:28 #187 №1416993 
>>1416984
Wine Is Not Emulator
Аноним 16/06/19 Вск 00:24:22 #188 №1417023 
>>1416982
Но ведь виндовый загрузчик уже делает самое правильное, что можно сделать: мапит заголовки, валидирует заголовки, мапит секции, занимается инициализацей и динамическим связыванием. Зачем тебе контекст с отдельной копией заголовков, если тебе их все равно грузить?

>>1416984
binfmt_pe.c написать несложно (и не один раз его уже реализовали), но вот окружение само по себе не появится.
Аноним 16/06/19 Вск 01:00:51 #189 №1417027 
>>1417023
Че такое окружение?
Аноним 16/06/19 Вск 01:57:14 #190 №1417036 
>>1417027
> окружение
Среда, в которой выполняется код - все, что он видит вокруг себя. Системные вызовы, системные данные в памяти (тот же PEB), библиотеки, структура файловой системы. Все это предоставляет вайн. Можно было бы, как сделала Microsoft для WSL, эмулировать только системные вызовы, пользуясь родными библиотеками, но в винде слишком много всего прибито гвоздями к ядру.
Аноним 16/06/19 Вск 02:56:54 #191 №1417045 
>>1417036
>Можно было бы, как сделала Microsoft для WSL, эмулировать только системные вызовы, пользуясь родными библиотеками
Нельзя, проприетарная лицензия-с.
>но в винде слишком много всего прибито гвоздями к ядру.
На самом деле к драйверам. Win подсистема ютится в win32k.sys, и ядру NT она нафиг не нужна, оно может работать и без неё.
Только эмулировать ядро до степени работоспособности драйверов ещё сложнее, чем по внешним интерфейсам. Перед последней задачей даже МС спасовали, в новых версиях WSL они будут запускать едро люнупса в виртуалке.
Аноним 16/06/19 Вск 03:03:26 #192 №1417047 
>>1417045
> лицензия
Нельзя пользоваться либами, но это проблемы юзеров. Так часто при реверсинге игр делают: движок опенсорс, данные родные, и лицензию, даже если она что-то подобное запрещает, нарушает пользователь, а код ни в чем не виноват.

> оно может работать и без неё
Ну ты же понимаешь, что фактически это часть ядра, а все эти "может работать" равносильны заявлениям, что софт может работать без ОС (да, может, но такое пишут крайне редко).

> в новых версиях WSL они будут запускать едро люнупса в виртуалке
Ну вот, теперь в десяточке нет абсолютно ничего хорошего.
Аноним 16/06/19 Вск 11:06:11 #193 №1417119 
>>1417023
Пишу упаковщик с лоадером.
Но если не пихать заголовки в контекст, все равно ведь придется делать два прохода по заголовкам: первый раз, чтобы прочитать ImageBase, а второй раз - выделить память по этому адресу и развернуть там образ.
Алсо, как работает лоадер на сисколлах? https://github.com/luis140219/luismark-loader/blob/master/luisldr.asm
В чем плюсы, минусы? Как вообще загрузка образа сводится к вызову ZwCreateSection? Что делает эта функа?
Аноним 16/06/19 Вск 12:02:11 #194 №1417129 
Насколько кэширование процессором кода может помешать выполнению кода при довольно интенсивном его изменении находу? Можно ли как-нибудь избежать отрицательных эффектов? Отключить кэширование кода для приложения/треда?
Аноним 16/06/19 Вск 14:45:32 #195 №1417221 
>>1417047
>Нельзя пользоваться либами, но это проблемы юзеров.
В общем то да, и сейчас можно подсунуть вайну родные либы. Но видимо уровни программ разные, и что можно реверсеру с гитхаба с 3 звёздочками, то запрещено проекту с тысячей контрибуторов.
>Ну ты же понимаешь, что фактически это часть ядра
Не а. Оно, как драйвер, работает в адресном пространстве ядра, пользуется его сервисами, ядро пользуется сервисами этого драйвера, но неотъемлемой частью оно не является.
>Ну вот, теперь в десяточке нет абсолютно ничего хорошего
Ну не знаю. Как по уровню интеграции Wine в сравнении с WSL?
>>1417129
Кеширование не мешает изменяемому коду, оно помогает неизменяемому, притом существенно.
Решение только одно - не использовать полиморфный код. Отключить кеширование можно для отдельных страниц, обладая правами админа, но будь готов к производительности уровня первых атомов.
Аноним 16/06/19 Вск 16:29:32 #196 №1417260 
>>1417221
>Решение только одно - не использовать полиморфный код.
Хотелось-бы наоборот. Есть ли необходимость для этого флагировать страницу как PAGE_NOCACHE? Это что-нибудь даст?
Аноним 16/06/19 Вск 16:34:41 #197 №1417261 
4BDC36D5-9F2E-41F0-99DA-3E20D145D9F3.jpeg
Если я рассматриваю программирование как хобби и процесс>результат, те могу писать условный хеллоуворлд годами, то ассемблер мой выбор?
Веб мне не нравится, хотя для такого гуманитария как я он лучший выбор, но не хочу и все тут.
[mailto:Sage] Аноним 16/06/19 Вск 16:40:54 #198 №1417264 
>>1417261
Для начала стоит хотя бы понять о чем говоришь. Веб это не только разметку рисовать и конфигами жонглировать. АСМ явно не твой выбор, ибо с текущим уровнем дискурса ты себе даже задачу не сможешь поставить.
Аноним 16/06/19 Вск 19:41:53 #199 №1417376 
>>1417260
Ничего не даст, дело не только в кэше, но еще и в конвейере. Изменение страницы, инструкции из которой уже выбраны и декодированы/декодируются = сброс конвейера. Постоянные сбросы конвейера = никакая производительность.

>>1417221
> Не а. Оно, как драйвер, работает в адресном пространстве ядра
Это все понятно, но это все детали. Но мы ведь об эмуляции винды говорим? И если рассматривать картину с этой стороны, то win32k и другие дрова вполне можно считать частью ядра. Выбрось их, и это уже будет не винда.
Аноним 16/06/19 Вск 19:57:20 #200 №1417379 
>>1417264
>>1417261
> АСМ явно не твой выбор, ибо с текущим уровнем дискурса ты себе даже задачу не сможешь поставить.

Так он за задачей и пришел

Пускай идёт пиликать МК
По моему лучшей альтернативе аутизма от мира cs - нет
Аноним 16/06/19 Вск 20:19:02 #201 №1417390 
>>1417379
>По моему лучшей альтернативе аутизма от мира cs - нет
Можно на FPGA создавать асики для пиликания.
Аноним 16/06/19 Вск 21:59:00 #202 №1417429 
>>1417119
Ты видимо вообще нюфаня, раз такие вопросы задаешь и не знаешь, как загрузчик винды работает. Куда собрался то свой писать?
Мы тут уже обсуждали защиту софта, лодеры и прочее, в итоге порешали, что все это херня и единственный рабочий метод - виртуализация кода.

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

Про апи винды на msdn читай. Исходный код ReactOS в помощь.
Аноним 16/06/19 Вск 23:33:38 #203 №1417451 
>>1417429
>Ты видимо вообще нюфаня, раз такие вопросы задаешь и не знаешь, как загрузчик винды работает.
В статьях пишут про такой алгоритм:
1) Парсинг хедеров
2) Разбор таблицы секций
3) Проецирование
4) Обработка импорта
5) Рекурсивная загрузка длл
6) Переход на точку входа

А как он работает на самом деле? Знаю, что можно почитать сорцы вин 2000, но их надо снова выкачивать и копаться к них.
Аноним 16/06/19 Вск 23:40:58 #204 №1417454 
>>1417451
Ну еще редактирование PEB. Но моя задача проще. Я хочу просто запамить PE-файл и запустить его.
Аноним 16/06/19 Вск 23:47:57 #205 №1417456 
>>1417451
Похоже, что половина процесса загрузки вообще происходит с дисковым имиджем: https://wiki.osdev.org/PE

To load a PE file is quite simple;

1. Extract from the header the entry point, heap and stack sizes.

2. Iterate through each section and copy it from the file into virtual memory (although not required, it is good to clear the difference between the section size in memory and in the file to 0).

3. Find the address of the entry point by finding the correct entry in the symbol table.

4. Create a new thread at that address and begin executing!
Аноним 16/06/19 Вск 23:53:40 #206 №1417459 
>>1417129
возможно, тебе может помочь CLFLUSH m8
Аноним 16/06/19 Вск 23:59:54 #207 №1417460 
Я правильно понимаю, что в unix-like системах все процессы создаются методом вызовов fork(); exec();, и начинается всё с самого первого процесса init после старта системы?
Аноним 17/06/19 Пнд 00:17:34 #208 №1417465 
>>1417451
>Исходный код ReactOS в помощь.
Там полноценный загрузчик реализован, практически 1 в 1 как у винды. Ничего качать не надо, через браузер смотреть можно.
На худой конец открой ntdll и ntoskrnl в иде, загрузи .pdb символы и изучай.

>>1417454
Куда замапить? Где запустить? В каком контексте? Какой PE-file? Ты недоговариваешь. Просто загрузить длл - LdrLoadDll. Ты эту функцию хочешь реализовать?
Аноним 17/06/19 Пнд 10:31:03 #209 №1417568 
>>1417465
>Куда замапить?
В адресное пространство пакера.

>Где запустить?
В АП пакера.

>В каком контексте?
В контексте пакера

>Какой PE-file?
exe, dll

>Ты эту функцию хочешь реализовать?
Хочу реализовать красивую загрузку exe для начала. Раньше по статьям какого-то системного программиста я написал свой вариант лоадера, который не только мапит exe, но еще и рекурсивно загружает дллки и прописывает их в PEB, но сейчас я хочу написать простой лоадер для узкой задачи на фасме. И мне не хватает идей, как сделать это правильно.

В предыдущем своем лоадере я делал контекст, который содержал указатели на структуры типа PIMAGE_DOS_HEADER и накладывал их на результат MapViewOfFile, а потом копировал заголовки и секции в другое место (по адресу ImageBase). А если по адресу ImageBase же что-то было (например, например, сам лоадер), то вызывал там UnmapViewOfFile. Но чтобы такого не было, ImageBase лоадера я сделал ниже, чем ImageBase загружаемого файла.

Почему вообщн загрузка может сводиться к вызовам ZwCreateSection? Как это работает?
Аноним 17/06/19 Пнд 19:39:08 #210 №1417934 
>>1417568
Правильный переносимый способ это использование документированных апи, а не копание во внутренних структурах. Есть шанс, что они их изменят, тогда твой лоадер придется переписывать.
>Почему вообщн загрузка может сводиться к вызовам ZwCreateSection? Как это работает?
Чтобы отобразить секцию, сначала нужно создать объект/получить дескриптор этого объекта секции.
MapViewOfFile читай как ZwMapViewOfSection.
Аноним 22/06/19 Суб 16:16:09 #211 №1420434 
image.png
Как посмотреть место, где находится __imp_CoInitializeEx?
Аноним 22/06/19 Суб 16:36:51 #212 №1420447 
>>1420434
Гуглишь на MS Docs функцию CoInitializeEx. Внизу страницы видишь, что, линковать надо с библиотекой Ole32.lib.
Проверить, что символ __imp_CoInitializeEx экспортируется из этой либы можно утилитой dumpbin (наряду с другими и компоновщиком link прилагается к MSVS).

C:\...\Microsoft_Visual_Studio\2019\Preview\VC\Tools\MSVC\14.22.27706\bin\Hostx64\x64\dumpbin /linkermember /out:Ole32.exports "C:\Program Files (x86)\Windows Kits\10\Lib\10.0.18362.0\um\x64\Ole32.Lib"

Находишь нужный символ в извлечённом файле Ole32.exports.
Аноним 22/06/19 Суб 19:41:29 #213 №1420502 
>>1420447
> C:\...\Microsoft_Visual_Studio\2019\Preview\VC\Tools\MSVC\14.22.27706\bin\Hostx64\x64\dumpbin
Проиграл. Все для людей. Вот в 2005 студии такой хуйни не было. На самом деле пердолиться в библиотеки импорта совершенно незачем, есть http://www.dependencywalker.com/

>>1420434
> место, где находится
Зависит от того, что ты понимаешь под словом "место". Жмешь Enter на символе, в статусной строке видишь позицию в файле и виртуальный адрес. Скроллишь вверх, видишь имя длл (или ищешь во View->Imports в более удобном для восприятия виде).
Аноним 22/06/19 Суб 20:14:11 #214 №1420519 
>>1420502
>http://www.dependencywalker.com/
Это чтобы (рекурсивно) просматривать импорт, если у тебя есть исполняемый файл. Я забыл, что все вы тут дофига реверсеры (свои программы не пишем - чужие ковыряем). А если нет файла? А если только исходник (да и тот не весь)?
Аноним 23/06/19 Вск 01:30:47 #215 №1420687 
image.png
>>1420447
>>1420502
Я поэтому и спросил потому что нифига там нет. В api-ms-... пусто, нет реализации. А саму реализацию в combase.dll нашел. Что за бред?
Аноним 23/06/19 Вск 01:52:08 #216 №1420694 
>>1420687
А, я, в свою очередь, забыл, что в этих ваших десяточках теперь импорты исключительно через жопу. Вот это посмотри, например: https://github.com/lucasg/Dependencies
Аноним 23/06/19 Вск 05:58:53 #217 №1420732 
>>1420694
Вот за это спасибо, давно хотеть альтернативу dependencywalker, который не умеет в новомодные перенаправления.
Мимо ОП
Аноним 23/06/19 Вск 18:47:08 #218 №1421011 
Сап, реверсач
Хочу вкатиться в разработку драйверов на Линукс
С чего начать? Сишкой и плюсами владею на достаточно высоком уровне, умею в структуры данных, знаю основы ОС
Есть топовая книга/курс для начинающих в этом деле?
Аноним 23/06/19 Вск 21:27:40 #219 №1421185 
>>1420694
Благодарю. Зачем они этих врапперов налепили? Какое у них предназначение?
Аноним 24/06/19 Пнд 00:44:47 #220 №1421306 
>>1421185
Для переносимости (читай: чтобы добить нативный софт) и версионирования (как будто нам SxS мало было), теперь API логично сгруппированы по функциональности, а не по подсистемам и абстрагированы от этих самых подсистем. В общем, максимально нинужная фича, как и все остальные фичи восьмерочки и десяточки, которая просочилась обратно в 7 и даже в XP.
Аноним 24/06/19 Пнд 01:07:28 #221 №1421312 
>>1421306
>чтобы добить нативный софт
Я так и подумал.

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

Не понимаю, для кого они апдейты каждые несколько месяцев выкатывают. Дедлайнов никаких нет, конкуренты не жмут, закройтесь, сука, в подвалах на годик-два и запилите норм ОС... Но нет...

да нибамбит у меня
Аноним 24/06/19 Пнд 01:57:41 #222 №1421315 
>>1421185
Теоретически производители встраиваемых систем могут собрать свои версии системных библиотек безо всякой хуиты. MinWin называется. Но всем как всегда похуй, и это лишь добавило ещё один нахуй не нужный слой абстракции.
>>1421312
>Не понимаю, для кого они апдейты каждые несколько месяцев выкатывают.
Чтобы не обосраться как с вислой.
IDA Pro v7.2.181105 with Hex-Rays x64 Аноним 24/06/19 Пнд 10:46:42 #223 №1421399 
https://mega.nz/#!W7Y1lSzC!dESOPpPtUcSC7rQW4WCYiqmbdd-XAb3ecv3AE0KTVAQ
Нашел у Спорова, кто слил информации нет.
Аноним 24/06/19 Пнд 14:17:13 #224 №1421505 
>>1421399
Я так понимаю сбрутили пароль для утекшей версии.
На меге содержимое потерли, но сам архив уже лежит на рутрекере.
Аноним 24/06/19 Пнд 15:39:50 #225 №1421556 
>>1421505
Не могу найти, кинь ссыль, пожалуйста.
Аноним 24/06/19 Пнд 16:42:47 #226 №1421587 
>>1421556
https://rutracker.org/forum/viewtopic.php?t=5748289
или сразу магнит, правда доска наверное покоцает:
magnet:?xt=urn:btih:89C510068D46F2EC48D6589B6FAE6ECC0B4CC3CB&tr=http%3A%2F%2Fbt4.t-ru.org%2Fann%3Fmagnet&dn=IDA%20Pro%207.2.181105%20WIN%20x86%2Fx64%20%2B%20Hex-Rays%20Decompilers%20(x64)%20%5B2019%2C%20ENG%5D
>Не могу найти
Как же ты искал?
Аноним 24/06/19 Пнд 18:56:14 #227 №1421637 
>>1421587
Благодарю, анончик. Жалко x86 hex-rays там нет...
Аноним 25/06/19 Втр 03:07:26 #228 №1421817 
Потестили новый хекс-рейсик? Как вам? Мне понравился, много всего декомпилить начал, чего раньше не мог.
Аноним 25/06/19 Втр 20:20:47 #229 №1422191 
Снимок.PNG
Есть какой-нибудь эмулятор куда это можно скопипастить и посмотреть на результат? Там иногда переполнения случаются поэтому самому писать долго будет.
Аноним 26/06/19 Срд 00:28:14 #230 №1422282 
>>1422191
А ты в Debuggers посмотри, там для выполнения кусков кода специально есть адаптер для Bochs, ничего копипастить не нужно (Bochs, разумеется, нужно поставить).

>>1421817
Если там 32-битного x86 и ARM нет, то не нужен.
Аноним 26/06/19 Срд 01:56:11 #231 №1422291 
>>1422282
x86 там нет, но он и не нужен, разве что малварь разглядывать.
Аноним 28/06/19 Птн 11:00:35 #232 №1423804 
Аноны, не могу осилить архитектуру устройства памяти в шиндоувс. Почему так сложно? Есть какой-нибудь огромный чертеж/рисунок охватывающий сразу всю иерархию, чтобы можно было примерно посмотреть как это все между собой взаимодействует?
Аноним 28/06/19 Птн 18:27:59 #233 №1424071 
>>1423804
Windows internals не помог?
Аноним 29/06/19 Суб 04:38:23 #234 №1424316 
>>1424071
Не помог. Я конечно теперь понимаю, что такое VAD, MDL, но не более. В windbg потыкал, все равно остаются вопросы, как это все между собой связанно, а как на физическую память транслируется? Какой-то пиздец, физиком надо быть что-ли чтобы понять?
Аноним 30/06/19 Вск 21:28:01 #235 №1425122 
>>1424316
>а как на физическую память транслируется
Ну пиздец. Что ты творишь? Теперь и я думаю, что что-то не понимаю.
Аноним 30/06/19 Вск 23:23:25 #236 №1425211 
d240bc8df69c5a3f472e994892575696.png.jpeg
Кто-нибудь может поделиться этой книгой?
Аноним 30/06/19 Вск 23:52:59 #237 №1425226 
>>1424316
https://en.wikipedia.org/wiki/Memory_management_unit#x86-64
Аноним 01/07/19 Пнд 00:23:59 #238 №1425232 
>>1425211
http://gen.lib.rus.ec/search.php?req=rootkits+and+bootkits&lg_topic=libgen&open=0&view=simple&res=25&phrase=1&column=def
Аноним 01/07/19 Пнд 00:32:55 #239 №1425235 
>>1425232
Спасибо
Аноним 01/07/19 Пнд 00:45:38 #240 №1425238 
IMG3008.JPG
>>1417379
>>1417264
Вообще-хочу писать демо под Z80.
Ну и пиликать STM32.
Аноним 01/07/19 Пнд 00:52:13 #241 №1425240 
>>1425238
>хочу писать демо под Z80
Мультиколор?
Аноним 01/07/19 Пнд 09:28:46 #242 №1425297 
>>1425211
Кидали выше вроде. Хорошая книга, но практической информации мало. Весь код протух лет 5 назад.
Аноним 01/07/19 Пнд 10:37:13 #243 №1425338 
>>1425297
>Кидали выше вроде.
В прошлом треде была ссылка, но протухла.
Аноним 02/07/19 Втр 14:34:31 #244 №1426191 
image.png
image.png
Асмач, существует ли аналог книг "Windows Internals" и "Linux Inside", но про макось?
Аноним 02/07/19 Втр 20:30:55 #245 №1426495 
image.png
>>1426191
дыа
Аноним 02/07/19 Втр 20:44:18 #246 №1426514 
Думаю вкатиться в низкоуровневое программирование. Чет я заебался, когда пишешь как по мануалу, а оно не работает. Компилится, но не работает. А я не могу ничего сделать: не я же писал. Сложно ли?
Аноним 02/07/19 Втр 20:49:41 #247 №1426523 
>>1426191
Эти книги мне кажутся несравнимыми. С разных углов на ось смотрят. Это из-за того что винда более монолитна и там можна гораздо больше компонентов назвать стандартными и изучить. И в линуксе изучается только ядро и то не достаточно подробно. В 100 страниц едва можно вписать процедуру создания нового процесса в линуксе. Это заняло бы пол книги. И даже этого там нет. Книга про ядро, это не все внутренности линукса.
Аноним 02/07/19 Втр 21:30:59 #248 №1426586 
>>1426514
>Компилится, но не работает
Ты написал идеальную программу.
Используй отладчик.
Аноним 02/07/19 Втр 22:20:51 #249 №1426672 
>>1426586
Вроде все функции вызываются, но не делают что нужно
Аноним 02/07/19 Втр 22:52:16 #250 №1426704 
51F51POFp5L.jpg
611R87sxyDL.jpg
51-ghSeG1-L.jpg
>>1426495
>(Mac|i)OS Internals
Вот так неожиданность)
Блин, даже стыдно стало за свое гугл-фу, спасибо большое.
>>1426523
ИМХО, просто эти две книги первыми приходят в голову, если возникает вопрос, что там у соответствующей ОСи под капотом.
Если ты подскажешь другие варианты, буду только благодарен за толковое чтиво по тематике.
Аноним 02/07/19 Втр 23:28:54 #251 №1426738 
>>1426704
>Если ты подскажешь другие варианты, буду только благодарен за толковое чтиво по тематике.
Я бы сам почитал аналог windows internals про линукс, но кажется его нет.
Аноним 03/07/19 Срд 12:37:02 #252 №1426959 
>>1426495
Двачую. Алсо, вангую в макось перспективно вкатываться в плане ресерча и поиска уязвимостей. У них же под откос все идет, сейчас пойдут сокращения в компании, дорогих разработчиков набреют и как всегда сэкономят на безопасности. Надо вкатываться, аноны.
Аноним 03/07/19 Срд 13:12:16 #253 №1426972 
RH-Mockup-cover-e27041b0214268ad47f11898f0231d6e.jpg
А эту книгу где украсть кто-нибудь знает?
Аноним 03/07/19 Срд 18:15:16 #254 №1427188 
>>1426972
Не надо. Редакторы все похерили
Аноним 03/07/19 Срд 18:28:15 #255 №1427192 
>>1427188
Можно я своё мнение сам составлю?
Аноним 03/07/19 Срд 19:57:36 #256 №1427262 
>>1427192
Нельзя.
Аноним 03/07/19 Срд 23:06:08 #257 №1427447 
>>1427262
Ну и ладно, все равно книга говно.
Аноним 03/07/19 Срд 23:09:11 #258 №1427451 
>>1427447
Рад, что тебе удалось ознакомиться. Поделишься с нами?
Аноним 03/07/19 Срд 23:33:57 #259 №1427479 
>>1426514
Как насчёт break and step?
Как бы топик.

мимокрокодил
Аноним 03/07/19 Срд 23:40:44 #260 №1427487 
>>1427479
Главный мой вопрос это: сложно ли вкатываться в асм, какие подводные?
Аноним 03/07/19 Срд 23:57:42 #261 №1427499 
>>1427487
Да хер его знает.
Мне не сложно, но я РЕ занимаюсь по большей части.
Книжек не читал, функциональные патчи (читай: не только кряки) публиковал.
Я хоббиист и практик — с меня мало толку в советах.
Жди унылых компенсирующих профессиональных кукаретиков теоретиков.

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

Стандартный совет: потыкай палочкой и задайся, в первую очередь, вопросом, в кайф ли тебе всё это.

Жду гнева теоретиков.

всё ещё крокодил
Аноним 04/07/19 Чтв 00:24:52 #262 №1427508 
>>1427487
Асм - самый простой язык, потому что процессор делает только то, что ты скажешь, только так, как ты скажешь, и ничего больше по крайней мере, все должно так выглядеть. Подводные в основном в том, что даже в пределах архитектуры есть зоопарк ассемблеров с частично несовместимым синтаксисом.

>>1427499
> Из подводных камней состоит чуть более чем полностью
Примеры будут?
Аноним 04/07/19 Чтв 00:46:26 #263 №1427519 
Просто ссу в рот всем формошлепам. Ебучая помойка. Все работает через 3 пизды, если вообще работает. Если не работает, то соси хуй, ибо сам мало что изменишь. То ли дело всякие приближенные к железу и математике штуки. Все точно, как часы.
Мне нужно было выговориться
sage[mailto:sage] Аноним 04/07/19 Чтв 01:51:22 #264 №1427543 
>>1427519
> Если не работает, то соси хуй, ибо сам мало что изменишь
> То ли дело всякие приближенные к железу
DRAM, например, с его роухаммером. Или те же процессоры, у который кроме распиаренных уязвимостей еще дохуя багов в errata. Тут ты хуй сосать не будешь, прикупишь себе фабрику и зделоешь правильно.
Аноним 04/07/19 Чтв 02:50:04 #265 №1427583 
>>1426972
Ну кто-нибудь. Ну пожалуйста. Ну дайте книжечку.
Аноним 04/07/19 Чтв 13:48:25 #266 №1427827 
image.png
Гайд от очень известного и крутого дядьки, как стать топовым реверсачером. Без такого графика ты будешь лох-чмо с 30к зп в ООО НИИ ЛАХТА - Рога и Копыта. Что думаете?
Аноним 04/07/19 Чтв 13:49:02 #267 №1427829 
Кто нибудь в треде пользуется kaitai struct? Как можно с помощью него описать поле флагов, чтобы в визуализаторе я все это видел в человекочитаемом виде?
Аноним 04/07/19 Чтв 14:09:24 #268 №1427842 
Краем глаза заметил, как антивирус быстро сканирует объекты и стало интересно. Написал на Си небольшую программу, сканирующую память процесса на поиск сигнатуры и потерпел фиаско, скорость желает ожидать лучшего. Как они это делают так быстро?
Аноним 04/07/19 Чтв 15:27:32 #269 №1427934 
index.jpeg
>>1427842
Не знаю. Но у меня на случай таких вопрос давно скачана и ещё не прочитана эта книга. Может тебе пригодится.
Аноним 04/07/19 Чтв 16:21:41 #270 №1427964 
>>1406213 (OP)
Забыл как формировать битмаски. http://ideone.com/UFArrz

Почему в op вместо 0x31 записывается 0x49? В чем я ошибся при формировании маски? В макрос я передаю 0b00110001, а получается 0b1001001
Аноним 04/07/19 Чтв 16:55:38 #271 №1427977 
Подскажите пожалуйста, как написать следующее в синтаксисе at&t:

Mess_ins equ [bp+4] ;сообщение внутри рамки
Attr_ins equ [bp+2] ;атрибуты сообщения внутри рамки
Other equ [bp] ;иная конфигурация окна
Аноним 04/07/19 Чтв 17:00:33 #272 №1427978 
>>1427842
Дай угадаю, тебя даже на kmp не хватило, какие уж там рабинкарпы с корасиками?
Аноним 04/07/19 Чтв 17:00:41 #273 №1427980 
>>1427964
http://ideone.com/WsMn1N
Все работает
Аноним 04/07/19 Чтв 17:14:34 #274 №1427982 
>>1427978
Что за kmp и карасики?
Аноним 04/07/19 Чтв 17:17:06 #275 №1427983 
>>1427982
Уверен что гуглиться элементарно, а ты даже не пробовал. Первое не ебу, а второе алгоритм поиска Ахо-Корасика
Аноним 04/07/19 Чтв 17:17:30 #276 №1427984 
>>1427982
Ну кмп очевидно он про линейную оптимизацию поиска с помощью автоматов, которая вряд ли была реализована в простенькой программе на си. А 2 других слова не знаю.
Аноним 04/07/19 Чтв 17:23:21 #277 №1427987 
>>1427982
Карасик.
Carasique;
Аноним 04/07/19 Чтв 17:36:00 #278 №1427994 
>>1427983
>>1427984
Да тут дело не в алгоритмах. Я один процесс сканировал секунду, а антивирус за эту же секунду всю память обошел. Черная магия.
Я так понял не написать мне йоба-антивирус без магистратуры мат. фака? Но я все же уверен, что тут дело в каких-то скрытых фишках винды.
Аноним 04/07/19 Чтв 18:00:56 #279 №1428000 
>>1427994
> Да тут дело не в алгоритмах.
А в чем тогда?
Аноним 04/07/19 Чтв 19:23:30 #280 №1428036 
>>1427827
Не хватает интенсивности.
Аноним 04/07/19 Чтв 19:37:31 #281 №1428039 
>>1427829
Бамп.

А вообще тут есть аноны, разбирающие бинарные форматы?
Чем пользуютесь? Нашел synalize it(под винду то же самое называется hexinator) - hex редактор с возможностью полудекларативно писать грамматики и интерактивно с подсветочкой парсить файл и смотреть определенные блоки. Потом нашел то же самое только лучше - kaitai struct и их webide. Но в обоих случаях не могу(или не понял как) нормально отображать битовые области с флагами.
Аноним 04/07/19 Чтв 20:13:50 #282 №1428058 
>>1428039
> А вообще тут есть аноны, разбирающие бинарные форматы?
Есть. Использую HxD и глаза, параллельно пишу парсеры на питоне или сишке. Считаю эти ваши кайтаи и 010 неюзабельным говном, в лучшем случае пригодным, чтобы .bmp распарсить, но не сложные форматы.
Аноним 04/07/19 Чтв 20:16:13 #283 №1428060 
>>1427994
> Я один процесс сканировал секунду, а антивирус за эту же секунду всю память обошел
Ты можешь, например, пропускать регионы, которые не помечены, как исполняемые.
Аноним 04/07/19 Чтв 20:50:10 #284 №1428094 
>>1428060
Я только rwx, wcx и читал.
Аноним 04/07/19 Чтв 21:34:09 #285 №1428118 
>>1427827
Как научиться интенсивно веселиться?
Аноним 04/07/19 Чтв 21:45:33 #286 №1428129 
>>1428118
Это еще ладно. Например не просто лежать и ворониных смотреть, а гулять с корешами и шутить так, чтобы задыхаться. А вот как интенсивно СЕМЬИТСЯ??? или ДОМИТЬСЯ?
Аноним 04/07/19 Чтв 22:26:38 #287 №1428146 
Есть еще reg-reg инструкции кроме очевидных xor, or, and, add, sub?
Аноним 04/07/19 Чтв 23:03:54 #288 №1428166 
>>1428129
>ДОМИТЬСЯ
Сычевать, очевидно же!
Аноним 05/07/19 Птн 00:19:47 #289 №1428209 
>>1426704
>>1426495
>#MOXiI
Есть у кого сабж свежих версий?
Или может кто из нищебродов типа меня готов скинуться на трехтомник 225$ ?
Аноним 05/07/19 Птн 01:10:58 #290 №1428225 
Где почитать про базовые адреса, буфера сиськи гыгы и тд, нужное для работы с памятью другого процесса. Интересуюсь для использования Memoryapi на c++. Я прям ноль в этом.
Аноним 05/07/19 Птн 01:34:48 #291 №1428240 
>>1428146
mov и lea считаются?
Аноним 05/07/19 Птн 01:39:08 #292 №1428241 
>>1428225
На msdn.
Аноним 05/07/19 Птн 01:58:17 #293 №1428246 
Есть что почитать про устройство антивирусов и HIPS?
Аноним 05/07/19 Птн 02:18:16 #294 №1428249 
>>1428246
я бы кстати тоже чего-нибудь почитал
Аноним 05/07/19 Птн 14:02:03 #295 №1428405 
Randomized base Addres меняет базовый адрес единожды? То есть узнав его однажды, я могу каждый раз обращаться по этому адресу и это всегда будет искомый адрес?
Аноним 05/07/19 Птн 14:07:41 #296 №1428407 
>>1428405
И как мне быть уверенным, что тоь адрес который я нашел в exe верен. Вдруг я недоглядел
Аноним 05/07/19 Птн 14:50:20 #297 №1428416 
>>1428405
>>1428407
Зайди на вики или msdn и почитай про ASLR. Получить базовый адрес - GetModuleHandle(NULL).
Аноним 05/07/19 Птн 14:56:35 #298 №1428419 
>>1427934
Благодарю, почитаю.

>>1428246
>>1428249
Вон выше кидали же книгу.
Аноним 05/07/19 Птн 15:00:37 #299 №1428420 
>>1428419
Но этой книги мало будет. Она же не большая совсем по сравнению с темой.
Аноним 05/07/19 Птн 15:10:33 #300 №1428422 
>>1428420
Ну а дальше только шерстить MSDN и блоги всякие.
Грубо говоря антивирус работает следующим образом:
Регистрирует мини-фильтры/каллбэки на определенные события.
Например при запуске процесса, их каллбэк срабатывает до точки входа приложения, следовательно они могут провести некоторые проверки и изолировать процесс. Тут больше винду надо исследовать, на то какие она возможности предоставляет для всего этого.
Аноним 05/07/19 Птн 15:43:25 #301 №1428443 
>>1427842
Вспомнило как умельцы из ESET написали NOD32, который невероятно быстро на тот момент делал нихуяшеньки.
Аноним 05/07/19 Птн 16:06:34 #302 №1428455 
Как избавиться от того, что link.exe добавляет jump-стабы в .text секцию при импорте?
Аноним 05/07/19 Птн 16:16:08 #303 №1428457 
>>1428455
Что за link.exe? Раз у него специфика такая, то никак, лол. Восстанови оригинальные байты, либо отобрази новую секцию в обход патчей.
Аноним 05/07/19 Птн 16:20:45 #304 №1428460 
>>1428457
MS Link.exe.
>Восстанови оригинальные байты, либо отобрази новую секцию в обход патчей.
Чего? Какие байты? Мне надо, чтобы он секцию не загаживал при пересборке.
Аноним 05/07/19 Птн 17:56:58 #305 №1428489 
>>1428416
Ок. Прочту. Я правильно понял, что эта функция не работает для стороннего процесса? Если так, то она мне не подходит
Аноним 05/07/19 Птн 17:58:11 #306 №1428490 
http://www.blackstormsecurity.com/docs/DEFCON_CHINA_ALEXANDRE.pdf
Читали? Согласны? Мое мнение, DTrace - просто имба. Теперь я точно все лето просижу за компом ковыряясь в винде.
Алсо, запись данной конференции есть у кого? Не могу найти.
Аноним 05/07/19 Птн 18:07:22 #307 №1428495 
>>1428489
Тогда CreateToolhelp32Snapshot или EnumProcessModules или NtQueryInformationProcess.
Аноним 05/07/19 Птн 20:09:51 #308 №1428572 
>>1428455
> jump-стабы
Объявляй импортируемые функции с __declspec(dllimport).

Аноним 05/07/19 Птн 21:15:24 #309 №1428616 
>>1428490
> swapon
Звучит как страпон
Аноним 06/07/19 Суб 12:49:10 #310 №1428949 
>>1406213 (OP)
Какой принцип работы таких дизассемблеров? https://github.com/vxlabinfo/malware/blob/master/beetle2/beetle/ldasm.cpp

По какому принципу строится таблица? Где-то в ней размещается ОПкод, и по этому опкоду можно найти ModR/M или SIB что ли?
Аноним 06/07/19 Суб 14:05:39 #311 №1429009 
>>1428949
Опкод используется в качестве индекса в таблице, из таблицы читаются флаги для инструкции, указывающие, из чего она состоит (офсеты, модрм). Если опкод хочет модрм, читается модрм, если модрм предполагает SIB, читается SIB. С помощью всего этого вычисляется, сколько байт после опкода нужно пропустить. Всё, что приводит к раздуванию таблицы (префиксы, альтернативные таблицы) обрабатывается явно.
Аноним 06/07/19 Суб 14:57:49 #312 №1429046 
>>1429009
А как такая таблица строится и почему формула построена именно как return packed_table[packed_table[code / 4] + (code % 4)];

Почему берется остаток от деления и неполное частное? Почему четверка? Как такую таблицу составить для декодирования инструкции mov eax, [0x00401000]?

unsigned char mov[] = "\x8B\x05\0x00\0x10\0x40\x00";

Хочу начать написание такой же штуки с простейшего случая. Ну или с декодирования NOP, но это неинтересно.
Аноним 06/07/19 Суб 15:05:25 #313 №1429053 
Как записать адрес функции в массив байтов?
memcpy(buffer, &function, 8) - какой-то мусор вместо адреса записывает.
Аноним 06/07/19 Суб 15:17:47 #314 №1429062 
>>1429053
>asm-тред
>memcpy
Туда ли ты защёл? C-тред - где-то там.
Аноним 06/07/19 Суб 15:34:47 #315 №1429072 
>>1429062
В С-треде даже не знают о существовании memcpy.
Аноним 06/07/19 Суб 15:49:28 #316 №1429086 
>>1428246
БАМП
Аноним 06/07/19 Суб 15:49:37 #317 №1429087 
MakabaEatsStars.png
>>1429053
>memcpy(buffer, &function, 8)
Судя по документации, ты копируешь 8 первых байт самой функции (тела) вместо её адреса.
Делай проще. Как-нибудь так:
*bufer = &function;
Аноним 06/07/19 Суб 16:19:20 #318 №1429119 
>>1429046
Я правильно понимаю, что выражение code%4 выделяет последние два бита типа d и w?
Аноним 06/07/19 Суб 17:02:26 #319 №1429133 
>>1429119
Почти. Просто хакиры. У многих инструкций форматы совпадают, поэтому можно не хранить флаги для всех 0x100 + 0x100 (однобайтовых и двубайтовых) опкодов отдельно, а вместо этого положить совпадающие флаги один раз, и на них ссылаться. В таблице фактически сначала индексы лежат, а потом флаги. Но индексы тоже занимают место, и ты вроде бы наоборот должен проиграть. Но как ты верно заметил, у многих инструкций есть d/w биты, и если флаги для группы инструкций положить последовательно, то ты можешь адресовать одним индексом всю такую группу. Так и сделано: code / 4 убирает младшие два бита (нормальный челове написал бы code >> 2), получает индекс группы и прибавляет к нему офсет в группе (code & 3), по получившемуся индексу читает флаги. Можешь это дело распаковать и посмотреть: http://ideone.com/WeETG5
Аноним 06/07/19 Суб 17:04:46 #320 №1429135 
>>1429053
#include <stdint.h>
∗(uintptr_t ∗)buffer = (uintptr_t)function;
и ты не ломаешься, когда тебя с -m32 соберут. Правда, здорово?
Аноним 06/07/19 Суб 17:08:46 #321 №1429136 
>>1429133
Приду домой после настолочек - поковыряю. Как такую таблицу сгенерить скриптом? Сначала положить все опкоды (это первые 6 бит любой инструкции без префикса), а остальные клетки заполнить флагами?

А насколько актуально морфить код, изменяя бит d в инструкциях типа xor ax, ax с одинаковыми операндами? Таких инструкций в любом коде мало. Я думаю, такой морфинг немного бесполезен. В инструкциях вида op reg, mem и op reg, imm тоже можно поиграть с битами, но я с этим еще не разобрался.
Аноним 06/07/19 Суб 17:11:02 #322 №1429137 
>>1429133
>У многих инструкций форматы совпадают, поэтому можно не хранить флаги для всех 0x100 + 0x100 (однобайтовых и двубайтовых) опкодов отдельно, а вместо этого положить совпадающие флаги один раз, и на них ссылаться
Да, форматы совпадают, но инструкции mov ax, ax и add ax, bx кодируются по-разному. Как отобразить обе эти инструкции на одну ячейку с флагами?
Аноним 06/07/19 Суб 18:17:16 #323 №1429175 
>>1429136
> Как такую таблицу сгенерить скриптом?
Обновил код по ссылке. Берешь мануалы интела, том 2, appendix A с табличками. Записываешь для каждой из двух таблиц (однобайтовые и двухбайтовые опкоды) нужные флаги (можешь и трехбайтовые поддержать, если хочешь), получаешь список из 512 (768) элементов. Ну а дальше жмешь. Это простейший словарный метод фактически - если последовательность из 4 байтов с флагами есть в таблице - записываешь индекс, если нет - кладешь ее туда и записываешь индекс. Все эти разговоры про d/w-биты интересны лишь для того, чтобы понять, почему именно для 4 байт оно жмется лучше всего.

>>1429137
> Как отобразить обе эти инструкции на одну ячейку с флагами?
Записать один и тот же индекс ячейки с флагами для обеих инструкций?
ADD - это "группа" 00-04 ((Eb, Gb), (Ev, Gv), (Gb, Eb), (Gv, Ev))
MOV - это "группа" 88-8с ((Eb, Gb), (Ev, Gv), (Gb, Eb), (Gv, Ev))
Т.е., да, у нас разные опкоды, похуй на опкоды - операнды-то кодируются одинаково (для 01 и 89 это Ev, Gv, для остальных пар тоже совпадают). Где-то в таблице (по индексам 80-84) лежат 4 байта с флагами, которые подходят и для ADD, и для MOV. Поэтому ты пишешь в индекс (01 >> 2) значение 80, в индекс (89 >> 2) значение 80, все.
Аноним 06/07/19 Суб 18:31:06 #324 №1429182 
>>1429135
Так делать безопасно?
Аноним 06/07/19 Суб 19:07:54 #325 №1429202 
>>1429182
По большей части (на реально существующих и распространенных платформах) - да. Вот если платформа требует выравнивания для чтения/записи указателей, а буфер не выровнен - может случиться что-нибудь нехорошее. Ну можешь сделать: uintptr_t funcadddr = func; memcpy(buffer, &funcaddr, sizeof(funcaddr)), если тебя это волнует.
Аноним 06/07/19 Суб 22:18:19 #326 №1429357 
>>1425211
Кто уже прочитал? Обсудим? Вам не кажется, что слишком мало посвящено современным технологиям? Сейчас нет смысла что-нибудь писать, что не работает в дэфолтной win10 x64 с uefi. И про обход проверки целостности в таких условиях там полторы страницы без описания PoC или разбора какой-нибудь малвари. Упомянули эксплоит в драйвере виртуалбокса всего в одном предложении, хотя эта тема заслуживает отдельной главы. При этом более древние техники с mbr на xp разобраны на 100 страниц.
Аноним 06/07/19 Суб 23:36:39 #327 №1429406 
>>1429357
Дочитал. Вот сижу https://www.youtube.com/watch?v=7p2uAgO9lBQ смотрю. Ну да, я тоже большего ожидал, на самом деле, каких-то практических знаний, а вышло по итогу, что я знаю что какие-то технологии / дыры там есть, но как их исследовать не знаю и остается только фантазировать. Короче углубляться надо самому.
Аноним 06/07/19 Суб 23:42:25 #328 №1429412 
>>1429357
На сколько я понял, удаленно уже ничего провернуть нельзя. Не зря за удаленное постоянство на уровне железа награда в 1-2 миллиона долларов у эпл и 1 лям у мс. Но атаки с физическим доступом более чем реальны. Погугли блог Dmytro Oleksiuk'a (Cr4sh).
Аноним 07/07/19 Вск 00:21:47 #329 №1429431 
>>1429412
>Cr4sh
Этого знаю. Речь не про удалёный jailbreak, а просто как установить драйвер в винду не имея подписи. Ну или не драйвер, а какой-нибудь другой буткит, но он должен работать на чём-то современном, а не пытаться лезть в мбр.
Аноним 07/07/19 Вск 00:48:53 #330 №1429457 
>>1427827
и зачем так жить то? если только работа да сон?
Аноним 07/07/19 Вск 11:25:27 #331 №1429619 
>>1429431
В таком случае не становятся ли актуальными полиморфные-метаморфные вирусы? Зачем ебаться с подписями, если можно жить в файлах?
Аноним 07/07/19 Вск 14:04:20 #332 №1429717 
Что почитать об оперативной памяти? Меня волнует это, потому что захотел написать свой недо cheat engine с функционалом 1/10000 от оригинала. Как я понял ReadProcessMemory читает всю память процесса (с кодом). А мне код нахуй не нужен. Данные же полюбому как то помечаются на исполняемые и неисполняемые.
Аноним 07/07/19 Вск 14:26:42 #333 №1429735 
>>1429133
>В таблице фактически сначала индексы лежат, а потом флаги. Но индексы тоже занимают место, и ты вроде бы наоборот должен проиграть. Но как ты верно заметил, у многих инструкций есть d/w биты, и если флаги для группы инструкций положить последовательно, то ты можешь адресовать одним индексом всю такую группу.
Примерно понял. Число code >> 2 это начало группы флагов, а число (code >> 2) + code & 3 непосредственно выбирает флаг. Но зачем так сделано? Разве mov ax, ax с d=1 отличается от mov ax, ax с d=0? Разве от флагов d, w, s зависит то, будет ли за первым байтом инструкции идти байт ModR/M или SIB? Может, лучше просто выбирать флаги по индексу code >> 2?
Аноним 07/07/19 Вск 15:24:26 #334 №1429767 
>>1429431
> а просто как установить драйвер в винду не имея подписи
На своем компьютере если, то просто отключаешь проверку подписи драйвера, включаешь режим отладки и грузишь драйвер. Также в биосе есть функции по отключению проверки подписи прошивки.
Удаленно установить прям именно драйвер никак нельзя. Можно разве что выполнить шеллкод в режиме ядра с помощью уязвимостей в компонентах ОС, либо через уязвимый легитимный драйвер но у тебя уже должны быть права админа. Буткит на тачке со всеми включенными функциями защиты то есть по дефолту ты никак не установишь. В теории конечно можно, но очень много где должны сойтись звезды.
Аноним 07/07/19 Вск 15:30:02 #335 №1429774 
>>1429619
И как ты себе это представляешь? При заражении файла сигнатура бьется, файл не считается легитимным. Также есть всякие ASLR, DEP, CFG и прочие механизмы, которые убили полиморфные вирусы уже очень давно.
Аноним 07/07/19 Вск 16:04:28 #336 №1429790 
>>1429774
>Также есть всякие ASLR
Как рандомизация базового адреса и защита стека убили вирусы, если вирус можно написать базонезависимым?
Аноним 07/07/19 Вск 16:49:39 #337 №1429826 
>>1429790
>убили полиморфные вирусы
Ты слова не пропускай то.
Аноним 07/07/19 Вск 17:03:29 #338 №1429837 
>>1429735
Я попытался тебе объяснить, почему именно группы по 4, а в итоге только запутал. Давай еще раз.

Похуй, какая там структура у инструкций, какие у нее там где d или w. У тебя есть массив из каких-то 512 байт, ты хочешь его сжать (не знаю, зачем, но ты, наверное, хакир). Ты можешь использовать RLE, LZW или еще какую-нибудь хуйню, и оно отлично все пожмет, но тогда ты не сможешь запросто взять элемент i из массива, тебе придется его распаковывать от индекса 0 до i. Это тебе не подходит, это медленно. Тут ты замечаешь, что в массиве по офсетам, кратным 4 часто начинаются совпадающие последовательности байтов длиной 4. И ты решаешь хранить каждую такую последовательность один раз и делаешь новый массив. Но индексы элементов пошли по пизде, они отличаются от старых. Поэтому тебе нужна табличка, которая преобразует индекс i в несжатом 512-байтовом массиве в новый j в сжатом. Но эта табличка, очевидно, займет как минимум 512 байтов, плюс еще сжатый массив. Но офсеты последовательностей у тебя были кратны 4! Значит, для каждого i+0, i+1, i+2, i+3 где i кратен 4, можно хранить один и тот же индекс j, а вот эти +0, +1, +2, +3 прибавлять уже потом. И тогда у тебя таблица трансляции i -> j из 512 байтов становится всего 512 / 4 = 128, плюс сжатый массив. И это уже выигрыш.

А вот ответ, почему в массиве больше всего одинаковых последовательностей оказалось по 4 байта и по адресам, кратным 4 - как раз в том, что опкоды не всегда присваивались как попало, а существуют вот эти самые d и w. Ты мог бы хранить последовательности по 2, и флаги сжались бы лучше, но ты бы проиграл на индексах. Ты мог бы хранить последовательности > 4, так ты бы выиграл на индексах, но флаги бы сжались гораздо хуже (наверное, я не проверял).

Алсо, если ты сам дизасм длин собрался писать, нахуй тебе в 2019 сжимать таблицу и вот в это все пердолиться? Храни как есть.

> Может, лучше просто выбирать флаги по индексу code >> 2?
Это сработало бы, если бы у всех инструкций были бы d и w. Но вот есть cbw (98), cwd (99), call far (9a). У 98 и 99 нет операндов, у 9a один и большой. Если ты сделаешь просто table[9a >> 2], ты получишь флаги для cbw и вычислишь неверную длину в результате.
Аноним 07/07/19 Вск 17:51:44 #339 №1429856 
>>1429837
Можно вопрос. Где эти знания могут пригодиться вообще? Зачем писать дизасемблер самому, если есть десятки аналогов? Пердолинг ради пердолинга?
Аноним 07/07/19 Вск 18:00:21 #340 №1429862 
>>1429856
Это кажется, что есть аналоги, а как до дела дойдет - то нельзя, это не работает, это только через ебаный костыль, вся либа ебаный костыль, пошло оно все в пизду, учу 1С. На самом деле дизассемблеров длин не так много, а если искать одновременно поддерживающий все современные инструкции и чтобы размером в одну-две страницы на Си, то их вообще ноль, наверное.
Аноним 07/07/19 Вск 20:01:27 #341 №1429935 
>>1429837
Принцип сжатия я понял. Мне интересно, на какие группы разбиваются все инструкции на x86. Вот у mov eax, [00401000] есть ModR/M и 4-байтный адрес. А у push eax (0x50) больше нет никаких байт, кроме этого опкода. add eax, [00401000] похож на mov выше. А еще есть инструкции с 8-битными, 16-битными и 32-битными операндами. Есть инструкции без операндов. Я предполагаю, что количество групп, на которые можно разделить все инструкции, совпадает с количеством 4--байтных последовательностей флагов. Хочу понять, что это за группы и сколько их.
Аноним 07/07/19 Вск 20:28:43 #342 №1429955 
>>1429935
> на какие группы разбиваются все инструкции на x86
Ну оно разве что когда-то давно разбивалось: https://gist.github.com/seanjensengrey/f971c20d05d4d0efc0781f2f3c0353da (да и то, например софтварный INT не просто так cd, а потому что в 8080 по cd CALL был). Потом, в процессе развития x86, инструкции уже просто тыкали везде, где оставалось свободное место (а с ним было очень напряжно, из-за чего, например, pop cs под двухбайтовые опкоды реюзнули). Поэтому не стоит искать структуру там, где ее уже давно нет. Даже в RISC форматы кодирования дробятся со временем.

> количество групп, на которые можно разделить все инструкции, совпадает с количеством 4--байтных последовательностей флагов
Нет. Например, "группы" для PUSH reg и POP reg состоит из 8 инструкций, расположенных последовательно. А вот в PUSH sreg (для es,cs,ss,ds) сегментный регистр указывается в середине инструкции, т.е., "группа" как бы существует, но получившиеся опкоды разбросаны по всей таблице.

Если реально интересно, возьми мануалы интела постарше (типа 486, а лучше 8086), там инструкции хоть и сгруппированы по применению, их структура наглядно нарисована, можешь спарсить оттуда данные и погруппировать.
Аноним 08/07/19 Пнд 17:45:09 #343 №1430397 
Кто нибудь находил какие либо технические детали по поводу Memory Integrity с использованием HVCI? Такими темпами винда убьет всю малварь сама и антивирусы станут не нужны, как в случае с макосью. Что думаете?
Аноним 08/07/19 Пнд 19:19:06 #344 №1430438 
>>1430397
А можно инфы по поводу макоси и ее расправы над малварями?
Аноним 08/07/19 Пнд 22:09:24 #345 №1430527 
>>1430397
> Такими темпами винда убьет всю малварь сама
Как это защитит от на коленке сделанного скрипта из десяти строк, который зашифрует Documents и попросит бетховенов?
Аноним 08/07/19 Пнд 23:05:30 #346 №1430554 
>>1430397
Винда начиная с 2000 убила всю малварь в прямых руках.
>>1430527
Одно слово - SRP.
sage[mailto:sage] Аноним 09/07/19 Втр 02:17:42 #347 №1430608 
>>1430554
> Одно слово - SRP.
Ну ты у себя настроишь. А кто будет пользователям объяснять, почему у них инсталлятор скачанной программы не запускается? А если запускается? А если в инсталляторе тот самый скрипт?
Аноним 09/07/19 Втр 17:03:47 #348 №1431068 
VEX.png
VEX считается RISC'ом, или как?
Аноним 10/07/19 Срд 00:00:35 #349 №1431329 
Как на десятке создать виртуальный флоппи диск с бутлоадером?
Аноним 10/07/19 Срд 00:44:33 #350 №1431372 
>>1430608
Пользователи не нужны.
Аноним 10/07/19 Срд 00:48:47 #351 №1431378 
Как переводится Second Fault Exception Handler?
Аноним 10/07/19 Срд 01:15:20 #352 №1431394 
ex.png
Есть такая няка. Как пропатчить эту программу, чтобы MessageBox отобразился два раза? Не примитивные способы типа копипаста.
Аноним 10/07/19 Срд 01:19:42 #353 №1431396 
>>1431394
Мириард вариантов.
Аноним 10/07/19 Срд 02:07:10 #354 №1431401 
>>1431378
Обработчик ошибок в обработчике ошибок.
Аноним 10/07/19 Срд 02:10:11 #355 №1431403 
>>1431394
– Вот как мне, интересно, файлы получше заражать, – размышлял Винни. – Если я положу в начале программы RET, а стек заставлю смотреть на адрес возврата…

– Кого заставишь смотреть? – испугался Пятачок, которому померещилось чего-то страшное.

– Стек, – сказал Винни Пух.

– Ага, – сказал Пятачок понимающе и отодвинулся от монитора подальше.

– Вот… Заставлю его смотреть на адрес возврата, то Пчелы, наверное, подумают, что это просто какая-то ошибочка и ничего не заметят. А если я поставлю вначале переход на вирус, как вызов процедуры, то Пчелы, наверное, подумают, что это маленькая подпрограммка и тоже ничего не заметят. По-моему так.

– Ага! – поддакнул Пятачок.

– Ну, чего будем ставить? – спросил Винни.

– Я? А… Его… Знаешь, Винни, – сказал Пятачок решительно. – Если там кто-то на кого-то будет смотреть, то это очень страшно. Давай лучше ма-а-аленькую парт… порт… прод-программочку, все равно Пчелы ни чего не заметят.

– Устами поросенка глаголет Истина, – сказал Пух важно, решительно опуская лапы на клавиатуру, и Пятачок заметно покраснел и стал выводить левым задним копытцем неопределенные круги.
Аноним 10/07/19 Срд 10:20:12 #356 №1431470 
>>1427583
>>1426972
если еще надо
https://anonfile.com/A6j1P9yen9/_pdf
Аноним 10/07/19 Срд 10:25:47 #357 №1431473 
Что с форумом exelab?
Аноним 10/07/19 Срд 12:35:38 #358 №1431515 
>>1431403
Как это сделать в hiew, чтобы не затирать байты, а добавить новые? В меню edit->asm только затирание
Аноним 10/07/19 Срд 14:43:00 #359 №1431582 
>>1431470
Спасибо
Аноним 10/07/19 Срд 14:46:51 #360 №1431583 
>>1431515
Ты хочешь в середину сегмента кода новые байты вставить? Тогда у тебя после них все ссылки поедут и ничего не будет работать.
Аноним 10/07/19 Срд 21:48:53 #361 №1431901 
>>1431470
В конце 27ой главы пропущены страницы
Аноним 11/07/19 Чтв 02:06:17 #362 №1432027 
>>1431901
отпиши @Slippery_Fox в телеграме,он слил
Аноним 11/07/19 Чтв 03:32:06 #363 №1432090 
>>1432027
Ок. Завтра напишу. Если не постесняюсь.

Обсудим теперь эту книгу? Помню алиса в твитере так пафосно прокомментировала книгу. "не буду утверждать, что всё написанное про меня правда". А оказалось, что про неё там 2 абзаца скопипащенных с форбса. И странно, что не упоминали диму краша из-за которого как раз и попала под санкции алиса. Хотя сама виновата, что понабрала школьников с античата в компанию. В gib например всех на полиграфе проверяют и каким бы талантливым он не был его бы туда не взяли.
Аноним 11/07/19 Чтв 04:11:56 #364 №1432095 
>>1432090
че за алиса?
Аноним 11/07/19 Чтв 04:16:04 #365 №1432096 
>>1432095
шевченко
Аноним 11/07/19 Чтв 04:24:48 #366 №1432097 
>>1432090
> В gib например всех на полиграфе проверяют
На предмет чего?
Аноним 11/07/19 Чтв 04:25:52 #367 №1432098 
>>1432097
криминал в прошлом ищут
Аноним 11/07/19 Чтв 04:29:34 #368 №1432099 
>>1432098
Ну и нахуй сразу кантору такую. А в жопу с фанариком они не лазают?
Аноним 11/07/19 Чтв 04:33:02 #369 №1432100 
>>1432099
там и платят мало. идти стоит или студентом, а потом валить или директором, а потом оставиться
Аноним 11/07/19 Чтв 10:15:59 #370 №1432238 
это что вообще?
Аноним 11/07/19 Чтв 12:33:47 #371 №1432313 
В нулевых был какой-то годный русскоязычный журнал, который каждый уважающий себя асемблятор выписывал, название было из двух слов, журнал точно был one of a kind, может тут кто-то вспомнит?
Аноним 11/07/19 Чтв 13:19:04 #372 №1432353 
Что можно почитать о багхантинге и ошибках сравения знаковых чисел с беззнаковыми (ja, jg)?
Аноним 11/07/19 Чтв 14:00:13 #373 №1432368 
>>1431583
Да, хочу, например, пропатчить адрес возврата и записать что-то типа mov dword ptr[esp+1], 401000h.
Что надо делать, чтобы все ссылки не поехали? Есть инструменты, которые автоматизируют такой патчинг?
Аноним 11/07/19 Чтв 14:03:02 #374 №1432371 
>>1432313
Системный администратор, любимый журнал Криса
Аноним 11/07/19 Чтв 14:13:20 #375 №1432376 
>>1432368
Как виннипух тебе написал. Вместо call MessageBoxA делаешь call куда-то в пустое место программы, а там делаешь что нужно. Пчелы подумают, что это маленькая подпрограммка и ничего не заметят.
Аноним 11/07/19 Чтв 15:06:57 #376 №1432460 
ex.png
>>1432376
Понял. У меня как-то не так встали адреса. В hiew я выбираю edit->Asm и ввожу push 0401000. Это адрес подпрограммки, которая выводит окно. Но в OllyDbg видно, что обращение происходит вообще не туда. Видимо, я не умею правильно записывать адреса в hiew. Как это делать?
Потом я хотел переместить вывод окна в пустую область нулей, но команда call MessageBoxA не ассемблировалась. Как ассемблировать вызовы импортов?
Аноним 11/07/19 Чтв 15:56:52 #377 №1432510 
>>1432460
> Но в OllyDbg видно, что обращение происходит вообще не туда
У exe-шника случайно релоков нет?

> hiew
Но зачем пердолиться в это говно мамонта, если ты можешь ассемблировать прямо в ольке?
Аноним 11/07/19 Чтв 19:49:24 #378 №1432609 
>>1432096
Алису Шевченко обоссали на форуме fuckav за барыжничество чьим-то криптором.
Аноним 11/07/19 Чтв 19:56:29 #379 №1432616 
>>1432609
Ясен пень, тян априори в лоу левел въехать не могут. Есть книга то в нормальном .pdf формате? А то скачал выше по ссылке, там фотками все.
Аноним 11/07/19 Чтв 20:00:15 #380 №1432621 
>>1432609
Можно скрин треда?Я просто хз вообще как на факаве регу пройти тк у меня из профилей на форумах только пустой профиль на экспе
Аноним 11/07/19 Чтв 20:37:18 #381 №1432638 
>>1432621
Где-то здесь было: https://fuckav.ru/forumdisplay.php?f=45
Проигрываю с названий тредов.
Аноним 11/07/19 Чтв 20:40:05 #382 №1432640 
>>1432638
Вроде, это https://fuckav.ru/showthread.php?t=32169
Суть такова. Там внезапно появилась тян, которая стала активно тусить на форуме и влезать в каждый тред, чтобы показать свою компетентность. Предлагала безвозмездную помощь. Тем не менее, все обращались к "ней" в мужском роде. Потом она там начала барыжить и ее поймали на барыжничестве чьим-то криптором.
Аноним 11/07/19 Чтв 20:43:12 #383 №1432645 
>>1432640
sweetmika7 это и есть алиса шевченко?
Аноним 11/07/19 Чтв 20:44:57 #384 №1432649 
>>1432645
Ну ту телку считали Алисой. Еще там в чате говорили, что Алиса раньше сидела на их форуме.
Аноним 11/07/19 Чтв 21:38:53 #385 №1432685 
>>1432640
Какая-то ересь полная. Заказчик там сам мягко говоря с программированием мало знаком, исполнитель - тоже. Я что-то передумал даже книгу читать, если там о таких товарищах пишется. Или годная все таки?
Аноним 11/07/19 Чтв 21:42:35 #386 №1432688 
>>1432685
>Я что-то передумал даже книгу читать, если там о таких товарищах пишется.
Это и есть настоящие хакеры. Люди, которые хуево знают программирование, но любят залезать в анусы операционных систем, чтобы поиметь с этого деньги. Такие товарищи носят в своих вирусах bat-файлы. А в книге еще рассказывается про барыгу оружием.
Аноним 11/07/19 Чтв 21:56:04 #387 №1432698 
>>1432688
Да уж. Из всей этой тусовки только персонаж Indy вызывает доверие. Олдфаг со стажем, помогает бесплатно, ресерчит даже что-то успешно. На забугорных форумах видел упоминания о нем и похвалы. Жалко конечно что у него своего блога нет, приходится в интернетах сообщения выискивать.

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

Тут по-моему единственный адекватный выбор - это идти малварь реверсить к какую-нибудь тир2-3 ав кантору.
Аноним 11/07/19 Чтв 23:42:23 #388 №1432792 
>>1432698
>Короче нафик этот хакинг, тот еще пердолинг
Ты этот хакинг сначала осиль, вайтишник ебаный.
sage[mailto:sage] Аноним 12/07/19 Птн 00:18:41 #389 №1432816 
>>1432792
Давай решим сначала, что такое хакинг. По ссылкам выше ребячество. Пару сотен строк кода с использованием документированного апи. Это хакинг разве? Такое даже в джава треде осилят.

Ты чего так загорелся-то? Я тебя задел что-ли? Ну если хочешь, давай проверим чье кунг-фу сильнее. Придумывай задание.
Аноним 12/07/19 Птн 00:41:12 #390 №1432832 
>>1432816
А это уже интересно.
мимо другой
Аноним 12/07/19 Птн 05:14:00 #391 №1432886 
>>1432616
>Ясен пень, тян априори в лоу левел въехать не могут
Боюсь мне придется хуй тебе по рылу размазать.
ничего личного, Северодвинск рулит
Аноним 12/07/19 Птн 05:15:57 #392 №1432887 
>>1432816
>Придумывай задание
На Росинке рут получи.
Аноним 12/07/19 Птн 05:21:31 #393 №1432888 
изображение.png
>>1432887
>Росинке
каво?
мимо
Аноним 12/07/19 Птн 13:48:42 #394 №1433196 
>>1432816
>Придумывай задание.
Реализуй аналог WinApi функции LoadLibrary, получающей указатель на буфер в памяти с содержимым DLL-ки вместо имени файла.
Аноним 12/07/19 Птн 14:07:54 #395 №1433206 
>>1433196
Скучно. Такое тут каждый первый писал.
другой анон
Аноним 12/07/19 Птн 14:09:14 #396 №1433207 
>>1433206
>Такое тут каждый первый писал.
Даже не сомневаюсь.
Аноним 12/07/19 Птн 14:10:47 #397 №1433210 
Хочу написать низкоуровневую программку, которая прочитает от юзера два сколь угодно длинных числа, сложит их и выведет результат на экран. Без аллокаторов памяти и прочего. Как это можно сделать?
Я хочу заюзать прерывания биос, но тогда, наверное, придется работать в реальном режиме. Прерывания ведь недоступны из ПМ?
Как еще можно решить задачу?
Аноним 12/07/19 Птн 14:13:28 #398 №1433212 
>>1433210
> Как еще можно решить задачу?
Никак. Защищенный режим на то и защищенный, чтобы не давать тебе доступ к железу в обход дров (мы же про ОС говорим, а не про код, который сам в защищенный режим переключается?). Алсо, вот как раз в реальном режиме ты можешь обойтись и без прерываний, выводя напрямую в видеопамять.
Аноним 12/07/19 Птн 15:50:44 #399 №1433262 
image.png
какие поля у структуры линуксового модуля могут быть интересны при разработке IDS? можете посоветовать какой нибудь современный цикл статей по фундаментальным структурам линукса типа процессы, сетевые соединения, модули и тд, чтобы читалось легко?
Аноним 12/07/19 Птн 16:55:33 #400 №1433320 
Как распаковать екзешник запокаванный enigma protector 4.xx ???
Аноним 12/07/19 Птн 17:32:04 #401 №1433350 
>>1433196
А я бы посмотрел на опенсор реализацию такой штуки
Аноним 12/07/19 Птн 17:34:18 #402 №1433352 
>>1433350
А блять хуйню спизданул. Забудьте
Аноним 12/07/19 Птн 18:39:13 #403 №1433416 
>>1433196
Издеваешься? Исходники на васме еще с 2000 года висят, куча современных аналогов на гитхабе. Реализаций отображения буфера в целевой процесс может быть несколько, также как и вызова мейн функции. Давай корректное задание с описанными деталями реализации и не то которое придется весь день писать.
Аноним 12/07/19 Птн 18:49:21 #404 №1433430 
>>1433416
>куча современных аналогов на гитхабе
Ну кинь сюда хоть один, лол.
Аноним 12/07/19 Птн 18:57:37 #405 №1433437 
>>1433430
https://github.com/Zer0Mem0ry/ManualMap/blob/master/ManualInjector/ManualInjector.cpp

Вот например. Самая обычная реализация с использованием высокоуровневого документированного апи. Выделяешь виртуальную память в целевом процессе, записываешь туда буфер, правишь его согласно правилам pe-формата, вызываешь мейн функцию по средствам создания нового потока. Никаких хаков.
Аноним 12/07/19 Птн 19:27:27 #406 №1433447 
>>1433437
Сойдет, хотя код жопошный, конечно.
Хоть бы RAII-врапперы понаписал для базовых вещей, и макрос для доступа в структуру с проверкой валидности смещения.
sage[mailto:sage] Аноним 12/07/19 Птн 20:05:36 #407 №1433462 
>>1433437
> с использованием высокоуровневого документированного апи
Давай заценим:
1) Формат не проверяется совсем, вообще, никак. Скормив этой фукции сломанную длл или неподдерживаемую длл (см., например, типы поправок, которые не проверяются тоже), можно уронить все нахуй. Да этой хуйней можно mp3 грузить!
2) Модуля нет в PEB_LDR_DATA, многие функции Windows API с этой "длл" работать не будут. Например, та же работа с ресурсами.
3) TLS не поддерживается.
4) Activation context-ы не поддерживаются, load configuration не поддерживается, 64 бита не поддерживаются, runtime function table, куча других сколько-нибудь современных вещей - нет. И это я еще молчу о тонкостях PE-формата.

Выводы сделаешь сам?
Аноним 12/07/19 Птн 20:21:13 #408 №1433471 
>>1433447
По хорошему надо PE-парсер туда имплантировать и разные врапперы/хелперы, а так да, нечитабельно.

>>1433462
Правильно, это POC скорее всего, а не полноценная реализация. Но хацкеры обычно инжектят голые длл или шеллкод, где нет никаких TLS, эксепшенов и прочей лабуды.
Грамотный парсер PE-формата фиксит все вышеперечисленные тобою проблемы. Кроме того, я уверяю тебя, что все это вообще не нужно, ибо весь функционал можно реализовать в рантайме.

А что там за тонкости PE-формата?
sage[mailto:sage] Аноним 12/07/19 Птн 21:15:47 #409 №1433520 
>>1433471
> А что там за тонкости PE-формата?
Ну я имел в виду всякие банальности типа VirtualSize = 0 у секций. Код не читал, только скроллил.

> инжектят голые длл или шеллкод
Там выше просили "аналог WinApi функции LoadLibrary", а не шелкоды-инжекты-хаки-спамы-куки. Шелкоду PE-лоадер без надобности.

> я уверяю тебя, что все это вообще не нужно
Это у тебя просто никогда MessageBox() не фэйлился из-за того, что лоадер SxS не умеет.
Аноним 12/07/19 Птн 22:06:58 #410 №1433546 
>>1433520
Тогда и смысла реализовывать это все руками нет, если не для хакинга. Некорректная задача. Реализовать все и не получится, потому что есть куча мест, куда нужно что-то впихнуть, где-то счетчик ссылок поправить забыл и у тебя все упадет.

>Это у тебя просто никогда MessageBox() не фэйлился из-за того, что лоадер SxS не умеет.
Приведи пример.
sage[mailto:sage] Аноним 12/07/19 Птн 23:21:54 #411 №1433604 
>>1433546
> Приведи пример.
Деталей уже не помню, много лет прошло. Примерно так: XP, comctl32 в импортах, отсутствие InitCommonControls. MessageBox возвращал 0 с валидными параметрами. Допилили SxS и заработало.

> если не для хакинга
Для моддинга. Грузилась игра, правились/подменялись импорты и код на лету. На WriteProcessMemory возбуждался антивирус, пользователи пугались, поэтому был запилен лоадер. Потом по-другому сделали, правда.
Аноним 14/07/19 Вск 07:50:10 #412 №1434588 
>>1432090
А неплохая все таки книженция. Интересные истории получились, кому-то повезло, кому-то совсем нет. Ну а про наше внутреннее устройство и так все знали, разве что навальнята вон пусть просвещаются.
Аноним 14/07/19 Вск 10:20:44 #413 №1434641 
>>1431901
>>1431470
https://телегран/freedom_fox/2030
версия без пальцев
Аноним 14/07/19 Вск 11:25:08 #414 №1434671 
>>1434641
Лол, только скачал, и уже забанили канал?
Туровский, ты не охуел там, часом?
Аноним 14/07/19 Вск 11:36:07 #415 №1434683 
изображение.png
>>1434671
чего?где забанил?
Аноним 14/07/19 Вск 11:38:12 #416 №1434685 
>>1434683
Channel with username @freedom_fox not found
Аноним 14/07/19 Вск 12:14:33 #417 №1434706 
>>1434685
Ты с айфона что ли сидишь?
Аноним 14/07/19 Вск 12:24:20 #418 №1434711 
>>1434706
Тарищ майор, хватит вынюхивать! У меня андроид.
Аноним 14/07/19 Вск 13:05:44 #419 №1434733 
>>1434711
Да это Туровский, я гарантирую это.
Аноним 14/07/19 Вск 14:44:39 #420 №1434867 
>>1434683
Залейте эту версию книги куда-нибудь еще.

мимо бдло без телерама
Аноним 14/07/19 Вск 15:40:16 #421 №1434938 
Пытаюсь расковырять в IDA Pro обычную программу (хэллоуворлд), скомпиленную в Visual Studio. Я долго искал main через _start, в итоге обнаружил, что он вызывает метод с двумя вложенными методами с двумя вложенными методами и так далее... Разок наткнулся на строку, которую программа выводит, а сам метод printf вызывается не в той подпрограмме, где значение кладется в стек, а через два слоя таких вот sub'ов! Анончик, почему все так дико?
Аноним 14/07/19 Вск 15:43:28 #422 №1434947 
>>1434938
Алсо, платформа - шиндовс, язык - С++.
Аноним 14/07/19 Вск 16:45:32 #423 №1435017 
>>1434947
Енджой ер вижуал сиплюсплюс и компилятор вс
Аноним 14/07/19 Вск 16:48:29 #424 №1435020 
>>1435017
А как мне виндовый софт реверсить-то, блджад?
sage[mailto:sage] Аноним 14/07/19 Вск 17:10:25 #425 №1435034 
>>1434938
Выложи, давай посмотрим.
Аноним 14/07/19 Вск 19:34:17 #426 №1435172 
>>1434867
https://dropmefiles.com/MGhyH

Открывать только на реальной машине. На виртуалке не сработает.
Аноним 14/07/19 Вск 19:52:30 #427 №1435183 
Студентоты полон тред. Кто нибудь здесь хоть раз операторы местами переставлял для того чтобы уменьшить время переключения пайплайна?
Аноним 14/07/19 Вск 20:07:02 #428 №1435205 
>>1435172
Посоны не качайте, там вишмастер, пишу с тостера.
sage[mailto:sage] Аноним 14/07/19 Вск 21:32:29 #429 №1435292 
>>1435172
Не скачивается.
Аноним 14/07/19 Вск 21:35:50 #430 №1435294 
>>1435172
судя по размеру тут первая версия с пальцами
>>1435292
держи няш
https://anonfile.com/f0wd6ez8n6/Turovskiy_Vtorjenie_pdf
Аноним 14/07/19 Вск 21:41:22 #431 №1435302 
немного оффтоп, но может кто нибудь знает.
есть произвольная линуксовая система, на которой запущен скрипт командой python3 scriptname.py от имени рута, но запускал не я, хоть и есть доступ к руту. ни в / ни в ~ рута скрипта scriptname.py нет, да и через find/locate по всей системе он тоже не находится. мне нужно узнать, что именно делает скрипт, в иделае вообще получить его сорсы. как это можно сделать?
Аноним 14/07/19 Вск 22:10:30 #432 №1435337 
>>1435302
Через /proc/<pid>/fd
Надеюсь, ты не ленивый студент, хотя все на это указывает.
Аноним 14/07/19 Вск 22:17:00 #433 №1435340 
image.png
>>1435337
я ленивый студент и иду по https://gist.github.com/simonw/8aa492e59265c1a021f5c5618f9e6b12 вот этому гайду.
почитал про /proc/pid/fd на so. в моём случае выдаёт пикрилейтед. что это может значить?
Аноним 14/07/19 Вск 22:21:31 #434 №1435353 
>>1435340
Это значит, что ты пидор не умеешь учиться, и ждешь, что кто-то решит за тебя задачу. С таким подходом в ИБ делать нечего.
В качестве общего подхода, могу посоветовать тебе смоделировать ситуацию, и смотреть там, что и как.
Аноним 14/07/19 Вск 22:24:22 #435 №1435359 
>>1435353
ух ты блять какой. ну и ладно, придется тратить время и гуглить, я пришёл сюда за помощью с нетривиальной проблемой, потому что вроде как для этого форумы и нужны, но если тут только нахуй посылают с вопросами, то чё делать, пойду искать решение сам.
sage[mailto:sage] Аноним 15/07/19 Пнд 00:04:14 #436 №1435402 
>>1435340
Это значит, что питон не держит файл со скриптом открытым, а скрипт, скорее всего, себя уже удолил, раз find не находит. Хотя ты в /proc/<pid>/cwd смотрел? сдампи память процесса
Аноним 15/07/19 Пнд 01:09:53 #437 №1435415 
>>1435294
>судя по размеру тут первая версия с пальцами
Там сжато. не хотел 60 мегабайт по сети загружать
Аноним 15/07/19 Пнд 23:12:19 #438 №1436416 
>>1432090
>Обсудим теперь эту книгу?
Хунта из под коня.
Серьезно, кроме пары интервью вообще ничего нового/интересного.
О каких-нибудь технических деталях я уже вообще молчу.
Аноним 16/07/19 Втр 00:49:53 #439 №1436491 
Такой вопрос. Я тут статью на хабре прочитал, там парень рассказывал, как занимался реверс инжинирингом контроллера лифта в подъезде.
Насколько нужно быть профессионалом, чтобы провернуть такое?
Вот допустим я чисто поприколу хочу влезть в лифт в падике и кнопки перемешать (теоретическая ситуация).
Сколько мне нужно будет обучаться, чтобы смочь такое?
Аноним 16/07/19 Втр 01:07:36 #440 №1436495 
>>1436491
Профессионалом тут быть не нужно. Только анус разработать не забудь.
sage[mailto:sage] Аноним 16/07/19 Втр 01:11:25 #441 №1436496 
https://movaxbx.ru/2019/06/06/debug-uefi-code-by-single-stepping-your-coffee-lake-s-hardware-cpu/

Под амд аналоги есть?
Аноним 16/07/19 Втр 12:13:31 #442 №1436637 
>>1406213 (OP)
дело было вечером, делать было нечего, забэкапил на гит/гитбук с wasm.in перевод "Введение в реверсинг с нуля, используя IDA PRO" от Яши. Из плюсов гитбука - полнтекстовый поиск.
Есть еще чем там заняться, но это уже по времени/возможности. Или если кто то сам поправит и пулреквест пришлет

https://yutewiyof.gitbook.io/intro-rev-ida-pro
Аноним 16/07/19 Втр 12:14:45 #443 №1436638 
>>1436491
это как вырезать гланды через жопу. Залезаешь в падк, снимаешь панель, тасуешь кнопки. профит.
а в статье описано то что делалось овердохуя жопачасов
Аноним 16/07/19 Втр 14:00:51 #444 №1436695 
>>1436495
>анус разработать
Да я же незаметно. Ночью залезу и сделаю всё.
А если серьезно, интересен просто сам вопрос, сколько времени нужно изучать материал, чтобы смочь сделать такую вещь.
Или, вот адекватный пример. Есть у меня например кофемашина. И я пару кнопок не использую (ну там где пенка и тд). Я хочу сам залезть и перепрограммировать так, чтобы на эти две кнопки делалось другое (кофе с выбранными параметрами). Чтобы не крутить вертушки и не настраивать, а просто кнопку нажать.

Так вот, насколько это сложно для человека, который никогда платами не занимался и реверс инжинирингом тоже? Сколько потребуется времени, чтобы научиться?

>>1436638
Так не интересно. Да и это решения уровня, стереть вообще цифры у кнопок.
Тут же вопрос скорее общий и теоретический.
Аноним 16/07/19 Втр 14:29:24 #445 №1436721 
>>1436695
чтобы ты смог взять чип с кофеварки,написать свою прошивку на асме проца этой платы и все прошить?Или что ты имеешь ввиду?Найми спецов лучше
Аноним 16/07/19 Втр 14:42:56 #446 №1436744 
>>1436695
>Тут же вопрос скорее общий и теоретический.
к каждой цели надо идти разумными средствами/способами.
Аноним 16/07/19 Втр 14:50:01 #447 №1436755 
>>1436721
А обязательно свою прошивку писать? Нельзя ли просто немного изменить ту, что уже есть? Может и тупой вопрос, я просто никогда этим не занимался.
Аноним 16/07/19 Втр 15:03:37 #448 №1436766 
>>1436755
зависит от целей и размаха. начни для начала прогать, и смотри на результат. Заодно разбирай все что пишешь. У Юрича все хорошо написано.

В шапке :
beginners.re - "Reverse Engineering для начинающих"- бесплатная современная книга на русском языке. К прочтению вкатывающимся и прочим ньюфагам обязательна!
Аноним 16/07/19 Втр 15:04:47 #449 №1436770 
>>1436755
ЗЫ. если прогать сложно будет, то в реверс лесть тем более. Там многое завязано на багаж опыта.
Аноним 16/07/19 Втр 18:48:23 #450 №1436978 
>>1436637
А вот за это большое благодарочка, анон. В шапку можно будет добавить. Алсо, куда Яшечка в итоге ушел? С васма то его выгнали, к сожалению.
Аноним 16/07/19 Втр 19:51:39 #451 №1437025 
>>1436637
ОП добавь в шапку!
оп
Аноним 16/07/19 Втр 20:46:13 #452 №1437067 
>>1436978
не выгнали, он по прежнему там, но обида и тд. что как дальше будет - хз.
Аноним 16/07/19 Втр 21:05:19 #453 №1437095 
>>1437067
А Володий общак вернул?
Аноним 16/07/19 Втр 21:20:07 #454 №1437109 
>>1437067
Так забанили же его вроде? Или уже разбанили?
Аноним 16/07/19 Втр 21:41:50 #455 №1437127 
>>1437095
не вкурси я мимо крокодил
>>1437109
может ридонли? в личку всё норм а на форуме не видать
Аноним 17/07/19 Срд 10:40:37 #456 №1437416 
Володуа, верни общак
Аноним 17/07/19 Срд 12:00:46 #457 №1437468 
аноны, помогите, как работать с режимами процессора в асме? я знаю его не очень, но просто интересно для себя покапаться в защищёных и прочих режимах проца, чтобы понять разобраться и получить базовые скилы.
Аноним 17/07/19 Срд 12:16:22 #458 №1437483 
Извиняюсь за небольшой оффтоп
Кто может сказать где сейчас 29A,z0mbie и прочие крутые вирмейкеры из начала нулевых?Когда они все это творили я только родился,так что не застал.Интересна их судьба
Аноним 17/07/19 Срд 16:55:50 #459 №1437664 
>>1410579
Добавлю. Вот перевод мануала для fasmg:
https://conspectuses.blogspot.com/2019/03/fasmg.html
Аноним 17/07/19 Срд 17:19:19 #460 №1437673 
image.png
>>1437468
Наврено самое доступное и более менее актуальное:
Аблязов Руслан Зуфярович - Программирование на ассемблере на платформе x86-64
Аноним 17/07/19 Срд 17:20:15 #461 №1437674 
>>1437664
а что случилось что он теперь fasmg? вроде раньше же всегда был просто fasm
Аноним 17/07/19 Срд 21:22:17 #462 №1437865 
15603542212290.png
Кроссплатформенный Ассемблер!

https://gamedev.ru/code/forum/?id=244813

Совершенно случайно наткнулся на такую тему, вопрос в том: КАК?
Аноним 17/07/19 Срд 23:02:53 #463 №1437949 
>>1437674
Ничего не случилось, fasm остался. fasmg - это fasm2 движок для написания ассемблеров с помощью допиленных макросов fasm.

>>1437865
Ну начинается...
Аноним 17/07/19 Срд 23:06:39 #464 №1437955 
>>1437483
На бутылке скорее всего. Без шуток.
Аноним 17/07/19 Срд 23:08:07 #465 №1437958 
>>1437865
Опять ты. Еще и анимешник. Понятно все с тобой.
Аноним 17/07/19 Срд 23:49:07 #466 №1437999 
C.jpg
>>1437865
>Совершенно случайно наткнулся на такую тему, вопрос в том: КАК?
Кроссплатформенный Ассемблер это С, без шуток.
Аноним 17/07/19 Срд 23:56:28 #467 №1438001 
Inori-Aizawatransformation.jpg
>>1437999
почему си постоянно рисуют взрослотянкой а не нердодевочкой -_-
Аноним 18/07/19 Чтв 00:00:51 #468 №1438003 
>>1438001
>год появления 1970
Потому что ему (ей) больше, чем большинству посетителей этой (и любой другой) борды.
Хотя уже яваскрипту с пыхой больше 18, теперь даже с ними не зазорно трахаться.
Аноним 18/07/19 Чтв 00:04:35 #469 №1438006 
>>1438003
>Хотя уже яваскрипту с пыхой больше 18, теперь даже с ними не зазорно трахаться
Я бы не стал. Велики шансы подцепить рак глаз или даже мозга.
Аноним 18/07/19 Чтв 00:11:36 #470 №1438009 
1562409396016.png
>>1438003
ну и что
алсо на картинке откуда она взята руби моложе джавы хотя должна быть старше
и самая милая там - лол визуал бейсик
Аноним 18/07/19 Чтв 07:15:23 #471 №1438070 
>>1437999
Без шуток, ассемблер это классический бейсик, буквально. Портянка инструкций с адресами, джампы, джампы с возвратом.
Аноним 18/07/19 Чтв 08:33:41 #472 №1438081 
>>1437949
но эти же охуянные макросы и тогда были)
Аноним 18/07/19 Чтв 11:03:46 #473 №1438116 
>>1436637
>>1406213 (OP)

https://backoftut.gitbook.io/intro-cracking-with-ollydbg/

Аналогичный бэкап курса Нарвахи по азам но уже на примере Ольки КМК, тут основы лучше рассказаны чем в курсе с идой, там их по верхам. И вообще базу все же лучше отдельно, а материал по инструментам отдельно. Но как есть
Аноним 18/07/19 Чтв 11:30:45 #474 №1438120 
>>1406213 (OP)
ТЫ, КТО СМЕЕТ ЭТО ВАШЕ ДЕРЬМО ПОГАНОЕ ЗДЕСЬ ХЕРАЧИТЬ, ЭТО ТЫ, ТАК НАЗЫВАЕМЫЙ БАЙТОСЛЕСАРЬ, ТЫ ГЕЙСКАЯ МРАЗЬ ПОГАНАЯ, ТЫ МУДАК СРАНЫЙ, ВОНЮЧИЙ ТЫ УРОД, ПОДОНОК, ЧТОБ ТЫ В НИИ ЗА 30К В МЕСЯЦ ГНИЛ, ТВАРЬ, ГНИДА ПОГАНАЯ! Я ТОЛЬКО НАТУРАЛ АБСОЛЮТНЫЙ, ЧИСТЕЙШИЙ ГЕТЕРО ПОЛНОСТЬЮ, НАВСЕГДА ТОЛЬКО НАТУРАЛ Я - ТОЛЬКО ДЕВУШЕК ОДНИХ ЛЮБЛЮ, ТОЛЬКО ДЕВУШЕК КРАСАВИЦ И ВСЁ!! ТОЛЬКО С ДЕВУШКАМИ ВСТРЕЧАЮСЬ, ТРАХАЮСЬ С ДЕВУШКАМИ СПЛЮ ТОЛЬКО! И ПРОГРАММИСТ Я ТОЛЬКО И ВСЁ!
Аноним 18/07/19 Чтв 13:18:04 #475 №1438151 
>>1437955
Да уже же 20 лет прошло с тех событий.все сроки давно прошли
Аноним 18/07/19 Чтв 16:55:10 #476 №1438308 
>>1438120
Код не пишешь, хуй не сосешь - зачем вообще ты на свете живешь?
Аноним 18/07/19 Чтв 17:16:11 #477 №1438319 
>>1438120
>ЧТОБ ТЫ В НИИ ЗА 30К В МЕСЯЦ ГНИЛ
Ну я и так как бы. Что сказать-то хотел?
Аноним 18/07/19 Чтв 20:24:26 #478 №1438447 
>>1438081
Нет, макросы fasmg гораздо мощнее и позволяют делать вещи, невозможные или требующие костылей в fasm1 (хотя кое-что Томаш бэкпортировал уже).
Аноним 18/07/19 Чтв 21:37:22 #479 №1438491 
>>1438447
Хорошо. Спасибо. Поищу почитаю.
научился ли fasm Делать дебаг инфу в ехешниках?
Аноним 18/07/19 Чтв 22:39:04 #480 №1438528 
>>1437958
В смысле, опять я ещё и анимешник?
Аноним 18/07/19 Чтв 23:06:35 #481 №1438548 
>>1438120
>В НИИ ЗА 30К В МЕСЯЦ
А где там зарплаты? Последнее предложение, что я видел, было 12. А я и в частной программистом на битриксе 30 умудряюсь получать.
Аноним 19/07/19 Птн 00:37:03 #482 №1438572 
>>1438548
В ДСах аж до 100к доходит белая зп в НИИ.
Аноним 19/07/19 Птн 00:52:30 #483 №1438581 
>>1406213 (OP)
Аноны, вопрос не совсем по теме, но спрошу - какие книги есть по машинному обучению в RE? Машоб-тред - помойка, там спрашивать бессмысленно.
Аноним 19/07/19 Птн 00:57:59 #484 №1438582 
>>1438581
даташиты в рдф от производителя

канкретный камень канкретные инструкции
Аноним 19/07/19 Птн 01:03:45 #485 №1438583 
01.JPG
прошу проверить
дано
одно прерывание приходит каждые 13.57см
необходима скорость в кмч
это инт
могу на индекаторе отображать только 4 знака
тое 1234
точку естествеенно буду ставить в ручную
тое 45.5кмч это 455

на пике код

пожалуйста проверьте эту константу
Аноним 19/07/19 Птн 01:15:52 #486 №1438587 
04м.JPG
а именно 37980
последний нуль смущает
нелюблю нули
оказываеца
тхл и тхх
карочи
это таймера и прерывания
к примеру
есть таймер
у него 2 регистра по байту
тх и тл
как только тл 256 тое =0 0хфф
он клацает камнем
тое нельзя сделать так
нижний регитр +2 кагда он 254
верхний не щелница нихуя

че забред? задаст вопрос зумер
ога этот бред начинаеца кагда ты начинаеш развадить второе прерывание по первому таймеру
притом это второе прерывание очень долгое
и можето и 1 раз за перва тайиер и один раз за 200 таймеров

а можите и меня обассат
Аноним 19/07/19 Птн 01:23:16 #487 №1438588 
>>1437865
не тупи маняме
....
после кросплатформы у твай няфы вместо ушей хуи вместо глаз залупа...
один хуй все перещитывать в ручную
я эту константу шитал 10 часов в течении полугода
и та мине не нравица
потомучто физики дахуя
тое внешних условий сверх быстрых просто ниебическое количество


Аноним 19/07/19 Птн 01:52:48 #488 №1438597 
>>1438491
Ну вот с fasmg ты можешь генерировать дебагинфу в любом формате, для которого только сможешь написать макросы (азаза. А в обычном фасме у тебя есть .fas и конвертеры какие-то вроде были для него, но сразу CodeView (PDB) он тебе не сделает.
Аноним 19/07/19 Птн 03:00:45 #489 №1438604 
blob
>>1438597
не трахай мозг мальчик
поверь мне
достаточно всеголиш знать канкретные точки и количество времени
да оно будет плавать +- 0.0001
но ты ахренееш от физики больше
вот сматри
к примеру
я тут недавно пытался решить мазгом анона канкретную задачку
проще оказалось взять ручку и написать все на бумаге я серьезно.
а задачка достаточно проста
есть прерывание оно происходит каждые 13.57 см
тое стоит датчик и каждый оборот диска равен этой величине
есть таймер один тик которого пол микросекунды
этот таймер задающий и трогать его тое перезапускать нельзя
он как начал со сваих 0хе100 так и ебашит до переполнения
вся его работа занимает 3.98милисекунды

ну а теперь задача надо вычислить километры в час

я об том что никакой фасм тасм хуясм не сделает твою работу по приведению физ виличин к требуемому порядку
один хуй все считать надо в ручную и выводить константы

невериш?
тагда тебе очередной пример
печка шизика
неповериш я 3 месяца трахался с этой хуйней
смысл вот в чем
на печке в качестве ключа стоит семистр
его вольт амперная...
карочи
я могу дергать им только на включение на полу волне
тое подал импульс и он включился
все просто?
да когда у тебя либо включить либо выключить либо 50 процентов

а что если необходимо 37 процентов?
и тут я начал знатно обсераца - осозновая что оказываеца полуволна это синусоида
тое .....
карочи я пришел сюда с этой проблемой и гдето неделю формулировал анону задачу
он мне дал решение
ты не повериш я его прогнал и оно оказалось верным
не без косяковканешн но анон и не говарил что идеально
жопа началась чуть позже
кагда я решил загнать эту формулу в исполняемый код
не повериш эта вся залупа выполнялась чтото около секунды и занимала в коде ниебучее количество места
........
и лиш включив мазги
просчитав туда сюда подумав и прочее я написал пик
анону спасибо
печка уже 4 год греет маю запойную задницу
и пряма сейчас сушит 30кг яблок

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

карочи
один совет
везде где есть возможность считайте все в ручную
да да на маленьких машинах это не такуж и сложно
угу не сложно я эти 37к считал помоему все лето..
а других вариантов ну просто нет
канечно можно пользоваться функциями
библиотеками и прочей так любимой стмщиками залупами
но говарю сразу все это платно и глючит да ГЛЮЧИТ- не верите?
гуглим как тормазнули штрихи все маниты в рфии под новый год
какраз там переходили...
че говарить не одни они понадеялись на функции и библиотеки
многие если не все заводы обосрались ...
это шаз они в курсе
а тогда камуто на граблях прыгать приходилось
и кстати досих пор не все научились
канечно с приходом атмеги и почих стм контроллеры шагнули и притом порядочно так одна андурина чего стоит - если раньше мне чтобы мигать ногой контроллера необходимо было иметь погромматор стоящий под 20-30кр, высшее образование чистого программера, понимание всей этой ебучей структуры, читание даташитов и прочих особеностей ядра
то сейчас любой школьниг может дергать ногой контроллера
а у меня в свое время при наличии оборудования и знаний ушло если недаст бог спиздеть чтото около полу года чтобы начать мигать...
канечно никто не отменяет загадку шизика про обычную шариковую мышку
но блядж байтоебство это уже сравни шаманству
и я даже за12(ДВЕНАДЦАТЬ) лет все в сраном 8 битном камне все не знаю, не говоря уже о переходных 16 битных и современных 32битных стмах
да умоом то я понимаю что все то оно в принципе тоже самое
но нет предела совершенству и каждый раз агда смотриш на прерывание есть желание прогнать его в 100500раз и сократить ну хоть сцука на пол операции на четвертиночку хотябы на осьмушку...
https://youtu.be/98LyQvwV1y4

Аноним 19/07/19 Птн 05:43:59 #490 №1438614 
>>1406213 (OP)
ОП, ты ведь добавишь в шапку восстановленный бэкап старого ВАСМа?
Аноним 19/07/19 Птн 05:44:34 #491 №1438615 
>>1438614
отклеилась
https://vxlab.info/wasm/index.php.htm
Аноним 19/07/19 Птн 06:44:38 #492 №1438617 
>>1438548
>>1438572
не в ДСах тоже может если образование соответсвующие - кандидатская есть, идешь на пол ставки туда на пол ставки сюда, и полявляешься по 2-3 часа в неделю. А получаешь как за полные ставки)
Аноним 19/07/19 Птн 06:47:55 #493 №1438618 
>>1438597
> но сразу CodeView (PDB) он тебе не сделает
единственный минус с другими :(
>>1438614
еще на рутрекере есть бэкап в CHM https://rutracker.org/forum/viewtopic.php?t=407571
Аноним 19/07/19 Птн 06:53:05 #494 №1438620 
>>1438604
>и тут я начал знатно обсераца - осозновая что оказываеца полуволна это синусоида
тое .....
>карочи я пришел сюда с этой проблемой и гдето неделю >формулировал анону задачу
>он мне дал решение

блэт. еще один сказочни пропустил школьную математику.
Аноним 19/07/19 Птн 06:57:45 #495 №1438622 
>>1438604
>а у меня в свое время при наличии оборудования и знаний ушло если недаст бог спиздеть чтото около полу года чтобы начать мигать...
еба, ты чо тут чешешь, птушник что ле?
>так одна андурина чего стоит - если раньше мне чтобы мигать ногой контроллера необходимо было иметь погромматор стоящий под 20-30кр, высшее образование чистого программера, понимание всей этой ебучей структуры, читание даташитов и прочих особеностей ядра

еще и ардуины восхваляет %) хоспади. более кривущего и монструозного SDK я пожалуй не видел. атмеги хорошо, ардуина детсадовское поделие из говна и палок.

>и я даже за12(ДВЕНАДЦАТЬ) лет все в сраном 8 битном камне все не знаю, не говоря уже о переходных 16 битных и современных 32битных стмах
это всего лишь твои 12 лет которые ты нахуй проебал вместо того чтоб что то изучать. методом тыка и изобретением велосипедов занимался
Аноним 19/07/19 Птн 06:57:53 #496 №1438623 
>>1438604
Дед, ты чего это в нотпаде код пишешь?
Аноним 19/07/19 Птн 13:27:37 #497 №1438723 
Вы чё уебки? Да благодаря ардуино даже самый отсталый птушный электрик без опыта проги может закодить игровой автомат и каждого пиздюка в округе на десятку наебать. У меня все. рты ваши ебал, дети, выросшие на журнале хакер
Аноним 19/07/19 Птн 13:34:07 #498 №1438726 
Подкиньте, где есть подробное описание флагов секций pe-файла и какие они могут принимать значения (или в теории там можно выставить любые комбинации, и файл останется валидным?)
Аноним 19/07/19 Птн 16:23:56 #499 №1438899 DELETED
>>1438620
хорошо мой сладенький сформулирую для тебя более точно ту задачу
есть семисторкак он работает пояснять стоит?
ок поясню без учета тонкостей смысл в следующем это ключ своего рода релюха кстати буржуины и некоторые другие источники его так и позиционируют как твердотельное реле
тое его примущество в том что он в отличии от транзистора или тиристора может пропускать ток в обоих направлениях - технически это 2 тиристора включенных встречно парралельно.ю
тое если приложить напряжение к истоку и затвору то на истоке можно снять ток тое он откроеца, но кака вся в том что пока не поменяется полярность приложенного напряжения он хуй закроеца( есть канечно запираемые семисторы точнее тиристоры но это разработки еще 70-80 а потом настал пиздец совку и о них забыли...
карочи опустим здесь еблю с разводкой и прочей чистолипиздроникой сделаем шаг ближе к програмингу
тое управление происходит примерно так
по прерыванию детектица момент перехода фазы из +0... в -0...
СМ. ПИК
там этот момент зиленой стрелкой
тое мы берем стартовую точку для таймера его запускаем и считаем надо 100 процентов мошности? подаем управление с самого начала , надо 50 процентов мощей? хорошо период синусоиды нам известен тое время за которое волна от нуля до нуля сделает это ебучее перемещение его можно тупо поделить на 2 хорошо
но жопа начинается кагда необходимо ну к примеру 27 процентов мощности тое мощность линейна - человеку проще линейно осознавать понимаеш?
но потомучто это синусоида там нихуя нету линейности
почему? вольт амперная
тое сматри на пике волна имеет 220вольт ток строго один нагрузка печка шизика - спираль 2х киловатная от промышленной плиты - пиздюкам на таких в школах и садиках хавчик готовят поварихи которых я ебу в обоих смыслах кого на мешке с картошкой кого за мешок с картошкой - кушать прикались тоже хочеца...
карочи неудивительно что выделяемое количество мощности в виде теплоты нихуя ни разу не зависит линейно от времени включения семистора
тое на начале волны напряжение меньше следственно и ток меньше карочи ебаная синусоида
я об этом пару тредов создавал на радиаче моча их терла потомучто я там устраивал филлиал /б
а подругому я не могу
карочи там мне школьнеги рассказывали что надо тупо клацать семистором и считать полу волны типа шим
вот тут и началось обсерание мачи радиачевской - канечно эта пидораска не хотела считать всю эту залупу
а с семисторами знакома была лиш из книжек, а я на тот момент уже чинил цеха начиная от кондитерки молочки и заканчивая...
карочи в очередной раз как меня там побанили я засел за умные книжки=интернеты онял что необходимо эту залупу считать через площадь синусоиды ты правильно сказал в школе я алгебру курил( посему пришлось после пары безуспешных тредов в /б задать вопрос тут и не повериш спустя 2 дня задача была решена так изящно что наверно досихпор является этолоном по применению семисторов.

Аноним 19/07/19 Птн 16:28:19 #500 №1438904 DELETED
>>1438622
>еще и ардуины восхваляет %)
ты реально тупой?
или просто не шибко умнай?
или выдернул из контекста фразу и ею наслаждаешся = тролиш?
насколько я помню я реально в 25 лет серьезно потрахался именно на этапе зашить точнее написал дернуть порт - увидел осцилографом что порт дернулся
плюс андурины в том что пиздюк СМОЖЕТ
а дальше...
себя вспомни епта
Аноним 19/07/19 Птн 16:37:10 #501 №1438912 DELETED
>>1438622
>и изобретением велосипедов занимался
иногда манЯ проще тупо этот велосипед взять и изобрести
нука давайка мне сходу за пол часа ок сутки
связь по и2с с 24с256 и (или) 24с512
для 89с52 камня
отсчет времени пошел
небудет ты пиздабол пидор гной и гусик тебя отвечаю выебет во сне
или ты думаеш я 12 лет занимался лиш написанием кода???
а на море баб ебать? а деньги зарабатывать? а тупо бухать рыб ловить и сабирать туже точить на токарке матарошку???
отдыхать на клопятне...
та ибать тебе как тупой голодной псине кинули кость ты в нее вцепился как последний школьниг аутист максималист и теперь думаеш меня тральнуть?
иди нахуй чемто ты мне мачу с радиача напоминаеш
тоже всех обсерает уебок а сам нихуя ниче толком не сделал
лиш анона обсерает пользуясь безнаказанностью мочераторских прав

Аноним 19/07/19 Птн 16:38:15 #502 №1438913 DELETED
>>1438726
о чем ты сейчас?
об определении портов?
Аноним 19/07/19 Птн 16:42:21 #503 №1438920 DELETED
кстати для всех остальных ушлепков из радиача я нашол вашу лежку дада тот самый шизик ...
загадка про шариковую мышку не отменяется
>>1438622
>это всего лишь твои 12 лет которые ты нахуй проебал
а ты элементарное решить не можеш уже 5 год
дада та самая загадка про инкремент и декремент на обычной шариковой мышке
или зумерку рассказать что такое мышка с шариком?
Аноним 19/07/19 Птн 16:49:58 #504 №1438935 
>>1438913
У исполняемого файла есть секции, у секций есть набор характеристик - по-моему, dword. Где можно прочитать подробно про значения, которые туда могут устанавливаться?
Аноним 19/07/19 Птн 17:00:14 #505 №1438940 DELETED
>>1438935
про екзешниг чтоли?
это зависит от ОСи под которую компилиш
здесь ломать бесмысленно
любой кастрат путем подсчета контрольки тебя ебанет на первом же ветвлении
даже я тебе на этот ответ ничего не скажу
пойми одно основная программа обязана работать
иначе тибя сдиванонят
карочи используй ихнее барахло против них же самих
теже сдвиги никто не отменял
а саседу интернеты повесить проще со шприца электралита многократно впрыснуть в витую пару и пиздец
движения должны быть ну карочи ты понял несколько 5-7 хватает
можеш дома потринероваца
Аноним 19/07/19 Птн 17:05:57 #506 №1438945 
>>1438588
ты бухой или што?
Аноним 19/07/19 Птн 17:07:20 #507 №1438946 DELETED
>>1438935
https://ru.wikipedia.org/wiki/.EXE
почему зумеры такие тупые?
вы и бузову навегна смотрите?
Аноним 19/07/19 Птн 17:08:01 #508 №1438948 DELETED
>>1438945
ну да седня менту воду развел 3 день бухаю
Аноним 19/07/19 Птн 17:17:08 #509 №1438958 DELETED
>>1438935
пойми одну простую штуку
кагда ты зашиваеш ты даеш фактически ось контроллеру
тое ось пишеш ты
а кагда кампилиш екзешниг ты работаеш не на железо
ты пишеш под ось
прикались и в железе хуева гора дыр
и тупо повесить - перегреть локально ...
в конце нулевых было модно упарывать винты путем циклической записи чтения в один и тоже сектор
позже это изменили но один хуй народ находит дыры

пойми одно
мы не деструкторы
пойми мы железячниги мы созидатели
мы можем
но не видим в этом смысла
самочки поверь не стоят
мы канечно можем
кагда на самочек там нехватает
дернуть систему
но какправило это оканчиваеца не ...
карочи все это хуйня
Аноним 19/07/19 Птн 17:21:36 #510 №1438962 
>>1438958
Очень смешно, какой-то уебок нажрался и врубил вот эту в стиле "пойми, мальчик".
А ты ведь очень тупой и тебя не накрыли хуями только потому что через твою орфографию лень продираться.
Аноним 19/07/19 Птн 17:35:35 #511 №1438975 DELETED
иди нахуй
https://youtu.be/T4sbdfTqEK4

Аноним 19/07/19 Птн 17:39:15 #512 №1438983 DELETED
или ты досихпор вериш мальчиг что мне человеку 82 года рождения
позволяли врать?
много вас таких
начинющих ложить шпалы
а потом паравозы сходят с рельс
почему?
а вот на этот вопрос ты мне и ответиш
Аноним 19/07/19 Птн 19:18:28 #513 №1439048 
>>1438962
Ты ахуел на старикана выебываться? Внемли мудрости или съеби.
Аноним 19/07/19 Птн 19:54:36 #514 №1439068 
>>1439048
что этот старый пердун сделал чтоб его слушать. пока по его роскозням он страдает хуетой)
Аноним 19/07/19 Птн 20:15:06 #515 №1439081 
>>1438618
> единственный минус с другими :(
Запили, все только рады будут.

>>1438935
https://docs.microsoft.com/en-us/windows/win32/debug/pe-format
Аноним 19/07/19 Птн 20:15:17 #516 №1439082 
>>1438958
перудн пездуй отсюдава, тема не про асм и кодинг, а про реверс. ты на старости лет ошибся малость
Аноним 19/07/19 Птн 20:17:34 #517 №1439085 
>>1439081
за столько лет, никаких подвижек, ничего не изменилось, значит никому не нужно это) и ты предлагаешь ему запилить?)))
опенсорс такой опенсорс.
Аноним 19/07/19 Птн 20:29:52 #518 №1439100 
>>1438904
>себя вспомни епта

себя и вспоминаю. сел почитал повторил. как конструктор же. у ардуины плюс что прям по USB Шьешь и всё, но такое сейчас и в нормальных stm-ках есть которые на развес, да и атмеги такие имеются.
Ардуина изначально неверное понятие у ребенка складывает о теме программирования железок в принципе.
Аноним 19/07/19 Птн 20:34:22 #519 №1439101 
>>1439082
>тема не про асм и кодинг
Ты название треда давно читал?
Аноним 19/07/19 Птн 20:39:14 #520 №1439105 DELETED
>>1439068
хм
утром позванили менты и уй он канечно раньше позванил
но его проблему я отмел на телефоне
и стал дожидаца званка от ментов
ближек к обеду мент раздуплился и мне позванили за 15 менут менты сказали сабирайся
замно1й ехала машина
там мент маер таксист на своей машине
я приехал ме дали новый станок паяльниг и я 3 часа просто в кайф с бутылочкой крепкого ледокола запилиил ментам проход через кирпич попял уголки там
это такой кайф чпок бах и все на месте и ровняй.....
канечно я минут 15 сидел и тупил как этот проход через кирпич селать красиво
чтобы мент ссался кипятком и др ментам рассказал что ...
жизнь обязанна быть разнообразной
Аноним 19/07/19 Птн 20:53:44 #521 №1439114 DELETED
к примеру
вот над решить какую задачу
тотжи ебучий датчиг
но зато я онял
что оптика в этом случае не лучший вариант
да допустима
но не стоит
хотя коегде дает карочи
пик
скорость мне успешно решили маи мазги кусок бумажки и ручка..
теперь нуда решать более заебную задачу
из тогоже прерывания

Аноним 19/07/19 Птн 21:30:05 #522 №1439131 DELETED
хорошо скорость мы посчитали пускай и некоторыми потерями
но то хуйня не думаю
вполне возможно потом учитывать да и похуй
ктото там не знает что такое пределы ?
ну хорошо поясню на палцах.
первое я незнаю когда отработает прерывание вполне вероятног ссработает в это время другое
но я знаю что в моем камне очень ахуительно реализованна именно скорость ... атмелы пошли по пути масштабирования
и ввелидлинную очередь прерываний это механика ели что
и кстьати ани обосрались
на 16 архитектуре
но смысл был нев этом
кагда есть задача от них то поверь ты ее решаеш
вот и у них была задача запилить стм 32
да перспектива
да выебоны
да я могу продать мидведю
и надо всетаки както дергать уметь в одном камне этим ебучим управляемым вектором тяги
да и чмошниг автоблядок не откажица от красивенькой музычки в 10 динамиках ога?
да они пытались
да это возможно
и 32 архитектура при нынешних

а драйвера...
чет дахуя длинным получилось лирическае отстумпление да
адача
анону теперь блядь се как кретину разжовывай
все тоже ебаное прерывание
мы прошли 13.57 см
теперь нам надо сохранить это огаа
ну для этого зимой была к камню припаяна флешка
и запиленна функция
тупо срущая по адресам
так
срать байт(первый байт адреса, второй байт адреса, значение, срать или читать?)
воот
типерь мине надооооооо
чтобы тама сохранялось
а что я хочу видеть?
ну технически я могу каждое прерывание но флешка то не бесканечная по операциям ридврит
да напаяю я там еще пару кмикрафорад танталу
тое надо ну нехочеца жке тоже терять ога?
и здесь совки придумали перваи на планете такую хуйню
как свертка информации
решение спорное канечно но необходимое
да и флеша медленная память
нада кстати по верклочить
он и 33мхз схавает
а под танталом ух
бля
карочи надо както теперь срать пробег на флешку
я в принципе предварительно думал у меня индекатор может только 4на4
и вхдные на еего функцию инты
но резанные
тое только 4 знака
тое 9999или0001
тое карочи опять байтоебство как ономеня заебало
ячейку необходимо заполнять
и использовать более эфективно
ну допустим у меня матарошка каждую сотню осмотр
каждую тышу то
...
5к км значит нормально а потом я пойму
...
а мжет я туплю?
Аноним 19/07/19 Птн 21:34:42 #523 №1439136 
>>1439085
Ему нужно, видимо. Я вот не пилю, потому что не понимаю, что может добавить отладочная инфа в изначально ассемблерный код, который тобой же и написан. А вообще, решения разной степени костыльности уже запилили, просто прямой генерации .pdb нет.
Аноним 19/07/19 Птн 23:46:45 #524 №1439191 DELETED
>>1439136
не соглашусь пожалуй
вот сматри
есть прерывание
а три пять таймеров тиктачат
и встает вопрос величин
может не дергать этот таймер три раза пускай посчитает?
а может его стоит сократить и сделать чаще?
и дергать вообще раз в 10 его прерываний? а одинадцатый отсчет в котором ты смотрел списать на погрешность?
Аноним 19/07/19 Птн 23:55:07 #525 №1439198 DELETED
всегда придеца бороца с погрешностями
ктото считает на бумажке код ктото расчитывает его в мазгах
не суть важно
отладочная информачия для того и отладочная чтобы ты мог оценить ту или иную степень правильности принятого решения

>>1439136
поверь это как на токарке
ты 3 часа настраиваеш станок серьезно от 20минут до порой недели если нужна ниебучая точность и серийность...
а потом крутиш станок 2-3 минуты

просто мы старые пердуны в своем абсолютизьме настолько планку уже задрали...
это как туже маск ифекты на 6 левле сложности ...
а планка поверь мне настолько высока ччто...
но ты еще мал и глуп
прально нах тебе отладочная информация...
Аноним 20/07/19 Суб 00:14:41 #526 №1439207 
>>1439198
в какой жопе у тебя абсолютизм то лол.
заебал тему без причин апать.
Аноним 20/07/19 Суб 01:05:47 #527 №1439222 DELETED
>>1439207
тред перекатывать пора а моче похуй
так почемубы не посрать?
Аноним 20/07/19 Суб 17:34:45 #528 №1439541 
>>1439222
>моче похуй
Причём здесь моча, даун? Тред я перекатываю, я тут не живу. Вы тут срёте со скоростью 1024 поста в секунду, и ещё чему-то удивляетесь.
Аноним 20/07/19 Суб 17:55:28 #529 №1439557 
Ну в общем
Трипл-перекат
>>1439555 (OP)
>>1439555 (OP)
>>1439555 (OP)
>>1439555 (OP)
>>1439555 (OP)
Трипл-перекат
>>1439555 (OP)
>>1439555 (OP)
>>1439555 (OP)
>>1439555 (OP)
>>1439555 (OP)

Если бы моча убрала сраную рекапчу, запостил бы быстрее. Иногда думаю, что перерубание нахуй всего зарубежного интернета пойдёт рунету на пользу - хоть рекапчи не будет!!!
comments powered by Disqus

Отзывы и предложения