Jump to content
YOUR-AD-HERE
HOSTING
TOOLS
992Proxy

Locked SGN - Encoder ported into go with several improvements


itsMe

Recommended Posts

This is the hidden content, please

SGN is a polymorphic binary encoder for offensive security purposes such as generating statically undetecable binary payloads. It uses a additive feedback loop to encode given binary instructions similar to LSFR. This project is the reimplementation of the original Shikata ga nai in golang with many improvements.

How? & Why?

For offensive security community, the original implementation of shikata ga nai encoder is considered to be the best shellcode encoder(until now). But over the years security researchers found several pitfalls for statically detecing the encoder(related work FireEye article). The main motive for this project was to create a better encoder that encodes the given binary to the point it is identical with totally random data and not possible to detect the presence of a decoder. With the help of keystone assembler library following improvments are implemented.

  •     64 bit support. Finally properly encoded x64 shellcodes !
  •     New smaller decoder stub. LFSR key reduced to 1 byte
  •     Encoded stub with pseudo random schema. Decoder stub is also encoded with a psudo random schema
  •     No visible loop condition Stub decodes itself WITHOUT using any loop conditions !!
  •     Decoder stub obfuscation. Random garbage instruction generator added with keystone
  •     Safe register option. Non of the registers are clobbered (optional preable, may reduce polimorphism)

This is the hidden content, please

Link to comment
Share on other sites

Guest
This topic is now closed to further replies.
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.