Что такое реверсивный инжиниринг

Реверсинг и обфускация, как это работает

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Многие в детстве разбирали свои игрушки в надежде понять, как они устроены, т.е. задатки реверс-инженера есть у каждого второго. Однако, у кого-то это с возрастом прошло, в то время как другие, наоборот, отточили свои умения и достигли в этом определенного мастерства.

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Кому нужен реверс-инжиниринг программного обеспечения?

Если отбросить промышленный шпионаж, реверс-инжиниринг широко используется аналитиками для препарирования вирусов и создания средств защиты. В то же время, аналогичный подход применяется для анализа ПО с закрытым исходным кодом, поиска уязвимостей и создания вирусов. Также энтузиастами проводится анализ драйверов и некоторых других полезных утилит с закрытым исходным кодом для того, чтобы создавать аналоги для Linux с открытым кодом. Хотите поиграть бесплатно? Генераторы ключей для платного ПО, пиратские серверы онлайн-игр также создаются с помощью реверс-инжиниринга. Однако, взлом софта и обратная разработка это, в большинстве случаев, разные вещи, для взлома, как правило, достаточно разобрать процесс проверки ключа лицензии, а во втором случае придется потратить намного больше времени и сил.

Как бороться с реверсингом?

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

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

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

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

Как бороться с защитой от реверсинга?

А тем, кто хочет стать программистом, рекомендуем профессию «Веб-разработчик».

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Многие в детстве разбирали свои игрушки в надежде понять, как они устроены, т.е. задатки реверс-инженера есть у каждого второго. Однако, у кого-то это с возрастом прошло, в то время как другие, наоборот, отточили свои умения и достигли в этом определенного мастерства.

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Кому нужен реверс-инжиниринг программного обеспечения?

Если отбросить промышленный шпионаж, реверс-инжиниринг широко используется аналитиками для препарирования вирусов и создания средств защиты. В то же время, аналогичный подход применяется для анализа ПО с закрытым исходным кодом, поиска уязвимостей и создания вирусов. Также энтузиастами проводится анализ драйверов и некоторых других полезных утилит с закрытым исходным кодом для того, чтобы создавать аналоги для Linux с открытым кодом. Хотите поиграть бесплатно? Генераторы ключей для платного ПО, пиратские серверы онлайн-игр также создаются с помощью реверс-инжиниринга. Однако, взлом софта и обратная разработка это, в большинстве случаев, разные вещи, для взлома, как правило, достаточно разобрать процесс проверки ключа лицензии, а во втором случае придется потратить намного больше времени и сил.

Как бороться с реверсингом?

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

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

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

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

Как бороться с защитой от реверсинга?

А тем, кто хочет стать программистом, рекомендуем профессию «Веб-разработчик».

Источник

Реверс-инженер: кто это, обязанности, зарплаты и как им стать в 2021 году. Обзор профессии.

Кто такой реверс-инженер?

Реверс-инженер (reverse engineer) — это специалист по обратной разработке, который исследует готовое устройство/программу и документацию для того, чтобы понять принцип работы или найти уязвимости, а в последующем сделать изменение или воспроизвести устройство, программу или иной продукт с такими же функциями, но без прямого копирования.

Что делают реверс-инженеры и чем занимаются?

Обязанности на примере одной из вакансий:

Что должен знать и уметь реверс-инженер?

Требования к реверс-инженерам:

Востребованность и зарплаты реверс-инженеров

На сайте поиска работы в данный момент открыто 197 вакансий, с каждым месяцем спрос на реверс-инженеров растет.

Количество вакансий с указанной зарплатой реверс-инженера по всей России:

Вакансий с указанным уровнем дохода по Москве:

Вакансий с указанным уровнем дохода по Санкт-Петербургу:

Как стать реверс-инженером и где учиться?

Варианты обучения для реверс-инженера с нуля:

Ниже сделали обзор 3 лучших онлайн-курсов.

3 лучших курсов для обучения реверс-инженера: подробный обзор

1 место. Курс «Reverse-Engineering» — OTUS

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Вы освоите на практике важнейшие приемы реверс-инжиниринга: статический и динамический анализ. Познакомитесь с низкоуровневым и системным программированием, подробно разберете аспекты внутреннего устройства Windows. Вам предстоит изучить и классифицировать вредоносное ПО на примерах реальных malware, выловленных в сети.

Реверс-инжиниринг кода (обратная разработка кода) — это процесс анализа машинного кода программы, который ставит своей целью понять принцип работы, восстановить алгоритм, обнаружить недокументированные возможности программы, и т.п. Основные методы реверс-инжиниринга — это статический или динамический анализ кода. При статическом анализе исследователь дизассемблирует код программы, используя специальное ПО, и далее анализирует ассемблерный код. При динамическом анализе исследователь запускает код в изолированной среде (песочнице) или отладчике и анализирует код в динамике.

Для кого этот курс?

Как проходит практика?

Студенты заранее получают стенды и разворачивают их у себя локально до начала занятия. Практику вы будете выполнять у себя на виртуальной машине во время вебинара под руководством преподавателя. На курсе вас ждет:

Программа обучения:

Модуль 1. Низкоуровневое программирование наассемблер под x8086/x64.

Модуль 2. Низкоуровневое программирование наассемблер под MIPS.

Модуль 3. Защищённый режим процессора

Модуль 4. Внутреннее устройство Windows

Модуль 5. Системное программирование

Модуль 6. Обратная разработка программ

Модуль 7. Проектный модуль

Выпускной проект:
Вместе с участниками группы по ходу курса мы «разревёрсим» несколько реальных вредоносных программ, определим их функционал и в качестве выпускного проекта напишем программу для лечения.

После обучения вы

Источник

Что такое реверс-инжиниринг?

Реверс-инжинирингом называют процесс, при котором физический объект разбирают на части и измеряют. Таким образом можно понять, как он был изготовлен, из каких компонентов состоит и как работает. Объектом может быть примерно всё: от огромного авианосца или инженерного сооружения вплоть до крошечных элементов часового механизма.

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Введение

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

Целью реверс-инжиниринга обычно является создание 3D-модели, которую можно использовать в CAD-приложениях. При правильном подходе реверс-инжиниринг дает возможность применять полученную информацию о конструкции объекта для решения целого ряда задач:

Как получить данные для реверс-инжиниринга

3D-сканирование снятого с производства поворотного круга с помощью Artec Eva. Впоследствии 3D-сканы экспортировали в программу для реверс-инжиниринга Geomagic Design X и перевели их в цельную модель, которую затем использовали для производства аналогичной детали.

Хотя время от времени, чтобы получить данные для реверс-инжиниринга, используются другие методы (как аналоговые, так и цифровые), всё же самыми популярными на сегодняшний день являются 3D-сканеры, координатно-измерительные машины и КТ-сканирование. В зависимости от сферы применения у каждого метода есть свои плюсы и минусы. Многое определяется бюджетом, опытом работы с выбранной технологией и временем, выделенным на реализацию проекта.

Полигональная 3D-модель поворотного круга, созданная на основе сканов Artec Eva

Готовая к реверс-инжинирингу CAD-модель поворотного круга

КТ-сканирование

КТ-сканирование — это эффективный способ провести измерение как внешней, так и внутренней поверхности объекта. КТ считается популярным инструментом медицинской диагностики. Однако этот метод также может быть подходящим решением для реверс-инжиниринга (в определенных ситуациях и для определенных сфер применения). Компьютерный томограф собирает информацию о форме объекта с помощью рентгеновского излучения. Поскольку рентгеновские лучи проходят сквозь объект, можно не беспокоиться о том, как лучше его расположить. Рентген может «увидеть» все внутренние, закрытые участки, например, поры и другие полости. Излучение в виде конусов (либо срезов) проходит сквозь объект; собираемые данные формируются в слои и собираются в цельную 3D-модель.

Промышленный компьютерный томограф EasyTom. Изображение предоставлено компанией CyberOptics Corporation

Однако у томографов тоже есть недостатки. Поскольку для анализа детали они используют радиацию, сканируемый объект должен помещаться внутри специальной камеры томографа (чтобы рентгеновские лучи не могли проникнуть наружу и навредить оператору, эта камера полностью герметичная). Это ограничение не позволяет оцифровывать большинство объектов среднего и крупного размера.

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

Кроме того, что цена на надежный томограф может достигать 250 000 долларов США и даже больше, а также что для работы с ним требуются специально обученные операторы, полученные таким образом сканы металлических объектов и даже деталей с металлическими компонентами могут содержать большое количество шума. Это связано с тем, что металл поглощает и рассеивает рентгеновские лучи, что значительно снижает точность сканов. Металлы с низкой плотностью (например, алюминий) сканировать намного проще, чем, например, сталь.

В идеале объект должен быть небольшого размера, состоять из пластика или из металла низкой плотности. В противном случае КТ-сканирование может потребовать несколько дополнительных часов на обработку сканов, только чтобы удалить артефакты и попытаться восстановить точные размеры объекта. Есть вероятность, что вы вообще не сможете оцифровать деталь, если она имеет неподходящий размер или плотность материала.

Контактное измерение (координатно-измерительные машины)

Координатно-измерительные машины (КИМ) отличаются исключительной точностью полученных данных и подходят как для контроля качества, так и для реверс-инжиниринга. Они используют заранее запрограммированные или контролируемые оператором датчики, которые записывают серию XYZ-координат массива точек на поверхности объекта, а затем шаг за шагом реконструируют его видимую геометрию.

Два инженера проверяют компонент производственной установки с помощью КИМ

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

Большинство КИМ представляют собой очень тяжелые устройства, которые обычно устанавливаются в одном помещении, откуда их очень сложно (а иногда даже невозможно) транспортировать в другой цех или компанию, если вдруг возникает такая необходимость. Из-за этого КИМ невозможно отвезти к клиенту, чтобы отсканировать объект там, где ему удобно, или же отправиться с такой машиной в другую страну (конечно, если необходимое качество данных не может обеспечить портативная КИМ). Кроме того, для работы с таким оборудованием требуются специально обученные операторы, а для настройки и перепрограммирования необходимо довольно много времени. Помимо этого, КИМ нужно тщательно оберегать от случайных ударов, толчков и вибраций, которые могут полностью сорвать проект, если останутся незамеченными.

Контакт с поверхностью гарантирует исключительную точность 3D-данных, собираемых датчиком КИМ. Однако есть и недостатки: данные собираются с низкой скоростью, машина не способна анализировать участки поверхности, до которых не может добраться датчик, существует риск серьезно повредить некоторые хрупкие объекты и т. п.

Поскольку самые распространенные типы датчиков КИМ непрерывно соприкасаются с поверхностью измеряемого объекта, стоит упомянуть и потенциальный риск повреждений и неточностей. Существует очень много материалов, которые могут повреждаться из-за воздействия датчика: на их поверхности могут появляться царапины, потертости или шероховатости. Риск деформации абсолютно недопустим при работе с очень дорогими или бесценными объектами, включая музейные экспонаты, раритеты из частных коллекций и др.

Если говорить о точности, то при контакте с такими мягкими поверхностями, как резина или силикон, датчик может легко деформировать объект, что в лучшем случае приведет к получению неточных данных, а в худшем — к необратимому повреждению. И даже это еще не всё. Если измеряемый объект имеет углубления или труднодоступные участки, а датчик КИМ не может до них добраться, то все эти элементы придется воссоздавать вручную в программе САПР, а значит, будут отклонения от оригинала.

3D-сканирование

Для сотен тысяч пользователей во всем мире профессиональные 3D-сканеры всех типов (настольные, портативные и устанавливаемые на штатив) являются надежным решением для реверс-инжиниринга и других задач. В то время как томографы и КИМ имеют высокую цену, практически лишены мобильности и требуют солидного опыта работы, лучшие 3D-сканеры отличаются противоположными качествами.

Сканирование с помощью структурированной подсветки

3D-сканеры на основе технологии структурированной подсветки снимают объект путем направления на его поверхность пучка света с определенным паттерном. Когда свет возвращается к датчикам сканера, устройство анализирует искажения паттерна, возникшие при контакте с поверхностью, и преобразует их в точные цифровые копии объекта в программе этого сканера. Такая цифровая копия в формате полигональной 3D-сетки может затем использоваться для создания CAD-модели, используемой для реверс-инжиниринга этого объекта.

3D-сканирование днища Volvo XC90 с помощью Artec Leo для реверс-инжиниринга выхлопной системы кроссовера

Одним из главных преимуществ использования 3D-сканеров на базе технологии структурированной подсветки является высокая скорость съемки. В отличие от КИМ или фотограмметрии, новейшие профессиональные 3D-сканеры со структурированной подсветкой могут за считанные минуты оцифровывать даже крупные объекты, причем с субмиллиметровой точностью и без контакта с поверхностью. В зависимости от модели сканера, луч света, который вы направляете на объект в процессе оцифровки, будет снимать от 1 миллиона до 3 миллионов точек в секунду.

Обработка скана ходовой части Volvo XC90 в Artec Studio

При работе с 3D-сканером на базе технологии структурированной подсветки вы сразу видите результаты съемки на экране ноутбука или сканера и можете рассмотреть каждый оцифрованный участок или область. Если что-то пропустили, то можно просто сделать еще одно-два движения сканером, чтобы заполнить прогалы.

Наконец, 3D-сканеры со структурированной подсветкой совершенно безопасны в использовании: они не вредят ни оператору, ни тем, кого он снимает. Это одна из главных причин, по которой такие 3D-сканеры широко используются в сфере здравоохранения.

Лазерные сканеры для крупных объектов и панорам

Устанавливаемые на штатив лазерные 3D-сканеры (лидары) можно разделить на две категории: времяпролетные и фазовые. Первые направляют лазерный луч на объект или площадку, на которой находятся несколько объектов, а затем высчитывают точное расстояние до него, фиксируя время, за которое свет вернулся к датчику сканера. Датчик также анализирует интенсивность излучения.

Фазовые лидары направляют равномерный луч лазера в нескольких разных фазах. Когда луч возвращается обратно к датчику сканера, изменения света анализируются специальными алгоритмами обработки и используются для определения точного расстояния между сканером и снимаемым объектом и/или площадкой.

Подготовка устанавливаемого на штатив устройства Artec Ray для 3D-сканирования палубы плавучей платформы

На основе полученных данных создается цифровое изображение объекта или панорамы в виде облака точек с высоким разрешением. Затем эти облака точек можно перевести в полигональные сетки с помощью программы для сканирования. 3D-сетки можно использовать в самых разных целях, включая создание CAD-моделей для реверс-инжиниринга, виртуальные транспарентные модели, поэтажные планы зданий и т. п.

Лазерные 3D-сканеры с увеличенным рабочим расстоянием могут легко оцифровывать крупные и даже огромные объекты и панорамы, причем делают это с невероятной точностью. Лучшие сканеры этого типа имеют рабочее расстояние от одного до 100+ метров. Они используются для создания метрологически точных 3D-моделей автомобилей, реактивных самолетов, суперъяхт и даже целых заводских цехов.

Благодаря надежному ПО для 3D-сканирования данные с лазерных сканеров с увеличенным радиусом действия можно легко объединить со сканами портативных 3D-устройств, чтобы создать цельную 3D-модель, в которой не будет пропущен ни один важный элемент объекта или панорамы. Хорошим примером может послужить реверс-инжиниринг современного пассажирского самолета с помощью лазерного сканера, который отснял конструкцию воздушного судна, и портативного 3D-сканера, который оцифровал приборную панель и сложные детали в кабине пилотов и салоне.

Простота использования, непревзойденные возможности сканирования

Настольные, портативные 3D-сканеры со структурированной подсветкой и лазерные устройства с увеличенным рабочим расстоянием настолько просты в использовании, что даже студенты всего за несколько часов могут научиться оцифровывать и крупные, и мелкие объекты. Именно благодаря портативности их можно использовать в помещении, на улице и вообще там, где это удобно клиенту (как бы далеко ни пришлось везти сканер).

По сравнению с томографам и КИМ, использование которых подразумевает значительные временные затраты, настольные и портативные 3D-сканеры могут оцифровать те же объекты в разы быстрее, что существенно снижает нагрузку на оператора и повышает продуктивность. Устанавливаемые на штатив лазерные сканеры еще более удобны в использовании: вы просто ставите штатив в нужное место и запускаете сканирование.

3D-сканеры являются незаменимыми инструментами для большинства задач, связанных с реверс-инжинирингом. Лучшие сканеры отличаются высокой скоростью работы, безопасностью и простотой использования. Они способны с субмиллиметровой точностью оцифровывать самые разные объекты (от мелких до крупных).

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

Итак, профессиональные 3D-сканеры (настольные, портативные и лазерные с увеличенным радиусом действия) являются надежным решением для реверс-инжиниринга объектов самого разного плана: от кольца с бриллиантом вплоть до таких объектов, как тяжелая техника, самолеты и здания.

Источник

Реверс-инжиниринг для начинающих: основные концепции программирования

Авторизуйтесь

Реверс-инжиниринг для начинающих: основные концепции программирования

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

В этой статье мы заглянем под капот программного обеспечения. Новички в реверс-инжиниринге получат общее представление о самом процессе исследования ПО, общих принципах построения программного кода и о том, как читать ассемблерный код.

Примечание Программный код для этой статьи компилируется с помощью Microsoft Visual Studio 2015, так что некоторые функции в новых версиях могут использоваться по-другому. В качестве дизассемблера используется IDA Pro.

Инициализация переменных

Переменные — одна из основных составляющих программирования. Они делятся на несколько видов, вот некоторые из них:

Примечание в С++ строка — не примитивная переменная, но важно понять, как она будет выглядеть в машинном коде.

Давайте посмотрим на ассемблерный код:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Здесь можно увидеть как IDA показывает распределение пространства для переменных. Сначала под каждую переменную выделяется пространство, а потом уже она инициализируется.

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

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

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Инициализация строковой переменной в C++

Для инициализации строки требуется вызов встроенной функции.

Стандартная функция вывода

Примечание Здесь речь пойдёт о том, что переменные помещаются в стек и затем используются в качестве параметров для функции вывода. Концепт функции с параметрами будет рассмотрен позднее.

13–15 декабря, Онлайн, Беcплатно

Теперь посмотрим на машинный код. Сначала строковый литерал:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Вывод строкового литерала

Теперь посмотрим на вывод одной из переменных:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Математические операции

Сейчас мы поговорим о следующих математических операциях:

Переведём каждую операцию в ассемблерный код:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Для сложения мы используем инструкцию add :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

При вычитании используется инструкция sub :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

При умножении — imul :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

При поразрядной конъюнкции используется инструкция and :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

При поразрядной дизъюнкции — or :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

При поразрядном исключающем ИЛИ — xor :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Поразрядное исключающее ИЛИ

При поразрядном отрицании — not :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

При битовом сдвиге вправо — sar :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Битовый сдвиг вправо

При битовом сдвиге влево — shl :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Битовый сдвиг влево

Вызов функций

Мы рассмотрим три вида функций:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Вызов функций без параметров

Функция newfunc() просто выводит сообщение «Hello! I’m a new function!»:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Вызов такой функции выглядит следующим образом:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Вызов функции с параметрами

Посмотрим на код функции:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Циклы

Теперь, когда мы изучили вызов функции, вывод, переменные и математику, перейдём к контролю порядка выполнения кода (flow control). Сначала мы изучим цикл for:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Графический обзор цикла for

Прежде чем разбить ассемблерный код на более мелкие части, посмотрим на общий вариант. Как вы можете видеть, когда цикл for запускается, у него есть 2 варианта:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Теперь давайте взглянем на цикл while :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

В этом цикле генерируется случайное число от 0 до 20. Если число больше 10, то произойдёт выход из цикла со словами «I’m out!», в противном случае продолжится работа в цикле.

Условный оператор

Теперь поговорим об условных операторах. Для начала посмотрим код:

Посмотрим на ассемблерный граф:

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Ассемблерный граф для условного оператора

Оператор выбора

Оператор выбора очень похож на оператор условия, только в операторе выбора одна переменная или выражение сравнивается с несколькими «случаями» (возможными эквивалентностями). Посмотрим код:

Оператор выбора не следует правилу «Если X, то Y, иначе Z» в отличии от условного оператора. Вместо этого программа сравнивает входное значение с существующими случаями и выполняет только тот случай, который соответствует входному значению. Рассмотрим два первых блока подробней.

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Два первых блока оператора выбора

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Если var_D0 (A) равно 5, то код перейдёт в секцию, которая показана выше, выведет «5» и затем перейдёт в секцию возврата.

Пользовательский ввод

В этом разделе мы рассмотрим ввод пользователя с помощью потока сin из C++. Во-первых, посмотрим на код:

Разберём это в машинном коде. Во-первых, функция cin :

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Функция C++ cin детальнее

Что такое реверсивный инжиниринг. Смотреть фото Что такое реверсивный инжиниринг. Смотреть картинку Что такое реверсивный инжиниринг. Картинка про Что такое реверсивный инжиниринг. Фото Что такое реверсивный инжиниринг

Мы рассмотрели лишь основные принципы работы программного обеспечения на низком уровне. Без этих основ невозможно понимать работу ПО и, соответственно, заниматься его исследованием.

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *