Task List
2024.08~
I'm currently working on a COFF parser and an ELF parser, which will be combined with a PE parser.
(I will be adding ELF code obfuscation first, followed by ELF packer, then COFF code obfuscation.)
ELF 0. SRC File
data:image/s3,"s3://crabby-images/1b4a0/1b4a0f2b59e1cf135b734f849aef7cb15c44df0c" alt=""
ELF 1. Added Segments
data:image/s3,"s3://crabby-images/0eb08/0eb08fd5bf6c454518646a9cbffb95de124531d6" alt=""
ELF 2. Added Sections
data:image/s3,"s3://crabby-images/6eb2a/6eb2a37d97d3f5f013928663a93c93bc7395231c" alt=""
ELF 3. Check Segment and Sections(; image dump sections)
data:image/s3,"s3://crabby-images/56534/5653402a5bde4fa21b0e64cbbdb795294280e75e" alt=""
ELF 4. Check Section Data
data:image/s3,"s3://crabby-images/63626/63626081966facdaade48bcd3294967b494ff5a3" alt=""
[2024.09.22.update]
I added a disassembler for elf-format, and now I can compute the function to be obfuscated via SDK or symbols.
Now, i'm started porting the code obfuscation tools.
---
ELF 5. Disassemble `main` func
data:image/s3,"s3://crabby-images/a92c6/a92c6e17313043593511a13e50ddea6d7f47f61c" alt=""
ELF 6. Simple Obfuscation `main` func
data:image/s3,"s3://crabby-images/6f24b/6f24b581706895ba5675ec12bc1a2739db4cbc9e" alt=""
data:image/s3,"s3://crabby-images/c4d2e/c4d2ee4670174edc8caf1ebf4ace7f8f2c2eebe0" alt=""
data:image/s3,"s3://crabby-images/d2d85/d2d850199c22e0c37ffdc0a1a7fd8fde6606812b" alt=""
[2024.09.30.update]
VxLang can now easily manipulate ELF relocation data.
ELF 6. Before the patch
data:image/s3,"s3://crabby-images/4a4a3/4a4a3754a772525f117f56922ca9591f62148b14" alt=""
data:image/s3,"s3://crabby-images/8511a/8511adda281a7e5e70c3053a340dea5b9d72a1fb" alt=""
ELF 7. Patching ELF Relocation Data
data:image/s3,"s3://crabby-images/cd66d/cd66dad21b7411b046c9f8672fc9eaac312a44f9" alt=""
data:image/s3,"s3://crabby-images/b4777/b47771166e065bed1e9f411a91b5779b90b4b2b8" alt=""
data:image/s3,"s3://crabby-images/739cc/739cc2f0d4bb4fde95895437f3a7ee7d4b04e9df" alt=""
ELF 8. `main` func flattening
data:image/s3,"s3://crabby-images/2afcc/2afcc00d7e0ddeec50a7d71868d8d148e348d7c7" alt=""
data:image/s3,"s3://crabby-images/1a1f9/1a1f95bf8c3fa80bae3645faaf7fa38b457c9085" alt=""
data:image/s3,"s3://crabby-images/f22d3/f22d3a6d528f6f4911865268164275cf24f2ba23" alt=""
data:image/s3,"s3://crabby-images/27699/27699979bcdde84e5129e114a5e1125b5f900c0b" alt=""
(I will be adding ELF code obfuscation first, followed by ELF packer, then COFF code obfuscation.)
ELF 0. SRC File
data:image/s3,"s3://crabby-images/1b4a0/1b4a0f2b59e1cf135b734f849aef7cb15c44df0c" alt=""
ELF 1. Added Segments
data:image/s3,"s3://crabby-images/0eb08/0eb08fd5bf6c454518646a9cbffb95de124531d6" alt=""
ELF 2. Added Sections
data:image/s3,"s3://crabby-images/6eb2a/6eb2a37d97d3f5f013928663a93c93bc7395231c" alt=""
ELF 3. Check Segment and Sections(; image dump sections)
data:image/s3,"s3://crabby-images/56534/5653402a5bde4fa21b0e64cbbdb795294280e75e" alt=""
ELF 4. Check Section Data
data:image/s3,"s3://crabby-images/63626/63626081966facdaade48bcd3294967b494ff5a3" alt=""
[2024.09.22.update]
I added a disassembler for elf-format, and now I can compute the function to be obfuscated via SDK or symbols.
Now, i'm started porting the code obfuscation tools.
---
ELF 5. Disassemble `main` func
data:image/s3,"s3://crabby-images/a92c6/a92c6e17313043593511a13e50ddea6d7f47f61c" alt=""
ELF 6. Simple Obfuscation `main` func
data:image/s3,"s3://crabby-images/6f24b/6f24b581706895ba5675ec12bc1a2739db4cbc9e" alt=""
data:image/s3,"s3://crabby-images/c4d2e/c4d2ee4670174edc8caf1ebf4ace7f8f2c2eebe0" alt=""
data:image/s3,"s3://crabby-images/d2d85/d2d850199c22e0c37ffdc0a1a7fd8fde6606812b" alt=""
[2024.09.30.update]
VxLang can now easily manipulate ELF relocation data.
ELF 6. Before the patch
data:image/s3,"s3://crabby-images/4a4a3/4a4a3754a772525f117f56922ca9591f62148b14" alt=""
data:image/s3,"s3://crabby-images/8511a/8511adda281a7e5e70c3053a340dea5b9d72a1fb" alt=""
ELF 7. Patching ELF Relocation Data
data:image/s3,"s3://crabby-images/cd66d/cd66dad21b7411b046c9f8672fc9eaac312a44f9" alt=""
data:image/s3,"s3://crabby-images/b4777/b47771166e065bed1e9f411a91b5779b90b4b2b8" alt=""
data:image/s3,"s3://crabby-images/739cc/739cc2f0d4bb4fde95895437f3a7ee7d4b04e9df" alt=""
ELF 8. `main` func flattening
data:image/s3,"s3://crabby-images/2afcc/2afcc00d7e0ddeec50a7d71868d8d148e348d7c7" alt=""
data:image/s3,"s3://crabby-images/1a1f9/1a1f95bf8c3fa80bae3645faaf7fa38b457c9085" alt=""
data:image/s3,"s3://crabby-images/f22d3/f22d3a6d528f6f4911865268164275cf24f2ba23" alt=""
data:image/s3,"s3://crabby-images/27699/27699979bcdde84e5129e114a5e1125b5f900c0b" alt=""
News
1.7.4.0
- Windows Version Patch
- Fixed a bug that prevented SEH processing during function unit obfuscation.
- Fixed all obfuscation entry points to be virtualized.
1.7.3.0
- Windows Version Patch
- PDB/MAP related bug fixes
- Fixed bug with virtualize/obfuscate specification
- Fixed bug with nested obfuscation
1.7.2.0
- Windows Version Patch
- Added support for `Tail Call Optimization (TCO)`
- Fixed VM compilation bug for `SDK call-link`
- Fixed Packer bug
-
If SDK-End is a `jump-link`, returns.
-
SDK flag issues, clang/gcc/rust/etc.
-
Resource table issues
1.7.1.0
- Windows Version Patch
- Fixed a bug where enabling the `reflection` option caused a conflict with `vxlang-link-event`.
- Fixed to allow loading of extension modules even if their section alignment value is not 0x10000.
-
In such cases, testing and updates are planned to exception handling and TLS settings for extension modules.
1.7.0.0
Added beta code for the ELF file format.
- The beta version only supports general code flattening.
- Beta features require users to specify target code.
- VxLang recommends using the `-fno-pic` option in ELF 32bit binary builds.
- The beta version only supports general code flattening.
- Beta features require users to specify target code.
- VxLang recommends using the `-fno-pic` option in ELF 32bit binary builds.
A sample usage is shown below:
data:image/s3,"s3://crabby-images/89888/89888a0ef620913f0f83b73455a9f813b05af26d" alt=""
1.6.9.0
Fixed extension module load timing, now loads faster than before.
Fixed Critical bug.
From now on, the general obfuscation/flattening technique will also have handlers added to specific commands.
1.6.8.0
A new CFG has been added to the code flattening process.
I was able to add this method because the branch table setting is now available in the VxLang internal x86-64 assembler.
This method is randomized with the existing method.
Binary expiration is extended to the end of October.
data:image/s3,"s3://crabby-images/d2cb5/d2cb524ead1ef9e04b6512556386901b2af0b412" alt=""
data:image/s3,"s3://crabby-images/d2cb5/d2cb524ead1ef9e04b6512556386901b2af0b412" alt=""
From now on, the general obfuscation/flattening technique will also have handlers added to specific commands.
1.6.7.0
Fixed bug where obfuscation patterns were not applied randomly.
Updated License-File.