0

Spotting Patterns in C Disassembly

Adafruit 3097

@MindTribe – Spotting Patterns in C Disassembly.

I’m grateful to Github for many things, but especially for making source control usage “normal” behavior. Perhaps Github’s popularity correlated with, rather than caused this trend, but I’m going to give them this one. Since Github’s advent, I’ve not needed to remind clients and new hires to put code into source control–it has become second nature. As a result, I have not had to patch a binary for quite some time now.

There was once a time when the phrase, “I’ll send you the source code,” found me in a cold sweat, hitting “check mail” in Outlook until the promised zip arrived. I’d be crushed to discover that the zip contained my worst fear: a binary executable, and nothing more. Invariably, I’d receive the, “oh, that’s all I have,” response to my grasping follow-up–hoping they might scrape together some crusty scraps of actual source out of old emails or off of that forgotten shared folder.

After several of these experiences, I decided that it might be worth trying (or at least fun to try) to treat the binary as the source code that everyone seemed to think it was. I invested in a personal license of IDA Pro, honed up on assembly, and dove into the wonderful, crazy world of binary reverse-engineering and patching. It was dull, slow, and painful at first, but as I practiced, I discovered that I could see patterns that sped up my work. Before long, I could actually make useful modifications to binary executables–changing behaviors and adding small features. I also found myself developing a much deeper and intuitive sense for memory maps, pointer math, and data structures that translated to the work I did in C. Seeing how my machines work at a low-level was helping me instruct them at a higher level.

Very cool, read more.


Stop breadboarding and soldering – start making immediately! Adafruit’s Circuit Playground is jam-packed with LEDs, sensors, buttons, alligator clip pads and more. Build projects with Circuit Playground in a few minutes with the drag-and-drop MakeCode programming site, learn computer science using the CS Discoveries class on code.org, jump into CircuitPython to learn Python and hardware together, or even use Arduino IDE. Circuit Playground Express is the newest and best Circuit Playground board, with support for MakeCode, CircuitPython, and Arduino. It has a powerful processor, 10 NeoPixels, mini speaker, InfraRed receive and transmit, two buttons, a switch, 14 alligator clip pads, and lots of sensors: capacitive touch, IR proximity, temperature, light, motion and sound. A whole wide world of electronics and coding is waiting for you, and it fits in the palm of your hand.

Join 12,000+ makers on Adafruit’s Discord channels and be part of the community! http://adafru.it/discord

CircuitPython 2019!

Have an amazing project to share? The Electronics Show and Tell with Google Hangouts On-Air is every Wednesday at 7:30pm ET! To join, head over to YouTube and check out the show’s live chat – we’ll post the link there.

Join us every Wednesday night at 8pm ET for Ask an Engineer!

Follow Adafruit on Instagram for top secret new products, behinds the scenes and more https://www.instagram.com/adafruit/


Maker Business — SiFive is a startup to pay attention to. RISC-5 is here to stay.

Wearables — Swatch it up

Electronics — Code like everyone’s watching

Biohacking — Stroboscopic Visual Training

Python for Microcontrollers — CircuitPython takes flight! All aboard with datum, Bluefruit CPX, and more! #Python #Adafruit #CircuitPython #PythonHardware @circuitpython @micropython @ThePSF @Adafruit

Get the only spam-free daily newsletter about wearables, running a "maker business", electronic tips and more! Subscribe at AdafruitDaily.com !



No Comments

No comments yet.

Sorry, the comment form is closed at this time.