TheWover / donut

Generates x86, x64, or AMD64+x86 position-independent shellcode that loads .NET Assemblies, PE files, and other Windows payloads from memory and runs them with parameters
BSD 3-Clause "New" or "Revised" License
3.61k stars 637 forks source link

not work for pyinstaller #93

Closed sh4m2hwz closed 1 year ago

sh4m2hwz commented 3 years ago

latest donut builded on linux use mingw Makefile.

payload for donut packing is https://github.com/Bainky/Telegram-RAT

donut packer output:

> ./donut  ../RAT.exe -z 2 -a 2

  [ Donut shellcode generator v0.9.3
  [ Copyright (c) 2019 TheWover, Odzhan

DEBUG: donut.c:1524:DonutCreate(): Entering.
DEBUG: donut.c:1302:validate_loader_cfg(): Validating loader configuration.
DEBUG: donut.c:1399:validate_loader_cfg(): Loader configuration passed validation.
DEBUG: donut.c:463:read_file_info(): Entering.
DEBUG: donut.c:471:read_file_info(): Checking extension of ../RAT.exe
DEBUG: donut.c:479:read_file_info(): Extension is ".exe"
DEBUG: donut.c:495:read_file_info(): File is EXE
DEBUG: donut.c:507:read_file_info(): Mapping ../RAT.exe into memory
DEBUG: donut.c:249:map_file(): Entering.
DEBUG: donut.c:535:read_file_info(): Checking characteristics
DEBUG: donut.c:594:read_file_info(): Leaving with error :  0
DEBUG: donut.c:1465:validate_file_cfg(): Validating configuration for input file.
DEBUG: donut.c:1507:validate_file_cfg(): Validation passed.
DEBUG: donut.c:686:build_module(): Entering.
DEBUG: donut.c:418:compress_file(): Obtaining size of compressed data from aP_max_packed_size() and allocating memory
DEBUG: donut.c:421:compress_file(): Obtaining size of work memory from aP_workmem_size() and allocating memory
DEBUG: donut.c:424:compress_file(): Compressing with aP_pack()
DEBUG: donut.c:437:compress_file(): Original file size : 10427032 | Compressed : 11186214
DEBUG: donut.c:438:compress_file(): File size reduced by -7%
DEBUG: donut.c:440:compress_file(): Leaving with error :  0
DEBUG: donut.c:696:build_module(): Assigning 11186214 bytes of 0000000002FFB040 to data
DEBUG: donut.c:707:build_module(): Allocating 11187542 bytes of memory for DONUT_MODULE
DEBUG: donut.c:791:build_module(): Copying data to module
DEBUG: donut.c:803:build_module(): Leaving with error :  0
DEBUG: donut.c:823:build_instance(): Entering.
DEBUG: donut.c:826:build_instance(): Allocating memory for instance
DEBUG: donut.c:832:build_instance(): The size of module is 11187542 bytes. Adding to size of instance.
DEBUG: donut.c:836:build_instance(): Total length of instance : 11191206
DEBUG: donut.c:865:build_instance(): Generating random key for instance
DEBUG: donut.c:874:build_instance(): Generating random key for module
DEBUG: donut.c:883:build_instance(): Generating random string to verify decryption
DEBUG: donut.c:890:build_instance(): Generating random IV for Maru hash
DEBUG: donut.c:898:build_instance(): Generating hashes for API using IV: 1E35DEBF43481C54
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : LoadLibraryA           = E8AC7F210E1F3F02
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : GetProcAddress         = F3D8D921EC9A99AE
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : GetModuleHandleA       = A1C1B8D40C5706FA
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : VirtualAlloc           = 547D4F71D05AAC11
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : VirtualFree            = 6C2202BC71983B48
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : VirtualQuery           = C985925B339C8547
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : VirtualProtect         = 793261908369FEF9
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : Sleep                  = 506C0B111E3E5106
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : MultiByteToWideChar    = 3AA2C9F3C392B9C7
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : GetUserDefaultLCID     = F1955B6B856F4875
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : WaitForSingleObject    = D57291392B24DA7E
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : CreateThread           = 04754BC89B15FB64
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : GetThreadContext       = F08B5F1EFC304674
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : GetCurrentThread       = C3FE24D4973217EA
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : GetCommandLineA        = B24A59A4593B1474
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : GetCommandLineW        = 07A3D1D11394BDC1
DEBUG: donut.c:908:build_instance(): Hash for shell32.dll     : CommandLineToArgvW     = 18DFC06FDA034FA9
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SafeArrayCreate        = 3989712459149DD1
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SafeArrayCreateVector  = E3DA5474C1F9786A
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SafeArrayPutElement    = E37091A9E24CFCDC
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SafeArrayDestroy       = 7152E58C758CC7BB
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SafeArrayGetLBound     = B921C572CE95BD2E
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SafeArrayGetUBound     = 2E288705E20BC70A
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SysAllocString         = 9F2002085FF2118E
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : SysFreeString          = 65422B5218EA3A36
DEBUG: donut.c:908:build_instance(): Hash for oleaut32.dll    : LoadTypeLib            = CEE8C545CA921CBC
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : InternetCrackUrlA      = 7C1CBEF755E8AC62
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : InternetOpenA          = DEEE0DFDAF0357C2
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : InternetConnectA       = F36588018B2DA340
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : InternetSetOptionA     = 6941870AF405F087
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : InternetReadFile       = 75B697D47EC2E2A4
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : InternetCloseHandle    = 2E2C45066474D7B1
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : HttpOpenRequestA       = 5DBCA114B30F8B7D
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : HttpSendRequestA       = D774FACDE4A306E3
DEBUG: donut.c:908:build_instance(): Hash for wininet.dll     : HttpQueryInfoA         = C734C3BFE0C1CFAA
DEBUG: donut.c:908:build_instance(): Hash for mscoree.dll     : CorBindToRuntime       = 2A175920C9FFC9A3
DEBUG: donut.c:908:build_instance(): Hash for mscoree.dll     : CLRCreateInstance      = 3158CDE8204EFF16
DEBUG: donut.c:908:build_instance(): Hash for ole32.dll       : CoInitializeEx         = 28B3A3344199600D
DEBUG: donut.c:908:build_instance(): Hash for ole32.dll       : CoCreateInstance       = A611759871C9F601
DEBUG: donut.c:908:build_instance(): Hash for ole32.dll       : CoUninitialize         = 5B1A6976AE5B4434
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlEqualUnicodeString  = 477C39DDD389C87B
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlEqualString         = 6465C074060B0A12
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlUnicodeStringToAnsiString = CBBCEB0A63FE8513
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlInitUnicodeString   = E6924A3D8953ACB3
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlExitUserThread      = D27B847A7B4D4B01
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlExitUserProcess     = 0D800A5ABA2B6736
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlCreateUnicodeString = A750E98D47D929A0
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlGetCompressionWorkSpaceSize = AF90E8B956988F2C
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : RtlDecompressBuffer    = EDFFACCF6C51AC60
DEBUG: donut.c:908:build_instance(): Hash for ntdll.dll       : NtContinue             = 265A5A25D91D20DB
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : AddVectoredExceptionHandler = 23DD80D2D39E2D05
DEBUG: donut.c:908:build_instance(): Hash for kernel32.dll    : RemoveVectoredExceptionHandler = BDE1BA95D22E7EA0
DEBUG: donut.c:914:build_instance(): Setting number of API to 52
DEBUG: donut.c:917:build_instance(): Setting DLL names to ole32;oleaut32;wininet;mscoree;shell32
DEBUG: donut.c:960:build_instance(): Copying strings required to bypass AMSI
DEBUG: donut.c:968:build_instance(): Copying strings required to bypass WLDP
DEBUG: donut.c:1037:build_instance(): Copying module data to instance
DEBUG: donut.c:1043:build_instance(): Encrypting instance
DEBUG: donut.c:1061:build_instance(): Leaving with error :  0
DEBUG: donut.c:1229:build_loader(): Inserting opcodes
DEBUG: donut.c:1258:build_loader(): Copying 22192 bytes of amd64 shellcode
DEBUG: donut.c:1109:save_loader(): Saving instance 00000000046E2040 to file. 11191206 bytes.
DEBUG: donut.c:1080:save_file(): Entering.
DEBUG: donut.c:1084:save_file(): Writing 11191206 bytes of 00000000046E2040 to instance
DEBUG: donut.c:1089:save_file(): Leaving with error :  0
DEBUG: donut.c:1158:save_loader(): Saving loader as binary
DEBUG: donut.c:1191:save_loader(): Leaving with error :  0
DEBUG: donut.c:1559:DonutCreate(): Leaving with error :  0
  [ Instance type : Embedded
  [ Module file   : "../RAT.exe"
  [ Entropy       : Random names + Encryption
  [ Compressed    : aPLib (Reduced by -7%)
  [ File type     : EXE
  [ Target CPU    : amd64
  [ AMSI/WDLP     : continue
  [ Shellcode     : "loader.bin"
DEBUG: donut.c:1575:DonutDelete(): Entering.
DEBUG: donut.c:1581:DonutDelete(): Releasing memory for module.
DEBUG: donut.c:1587:DonutDelete(): Releasing memory for configuration.
DEBUG: donut.c:1593:DonutDelete(): Releasing memory for loader.
DEBUG: donut.c:293:unmap_file(): Releasing compressed data.
DEBUG: donut.c:298:unmap_file(): Unmapping input file.
DEBUG: donut.c:303:unmap_file(): Closing input file.
DEBUG: donut.c:1599:DonutDelete(): Leaving.

loader64 output:


> .\loader64.exe instance
Running...
DEBUG: loader/loader.c:109:MainProc(): Maru IV : 1E35DEBF43481C54
DEBUG: loader/loader.c:112:MainProc(): Resolving address for VirtualAlloc() : 547D4F71D05AAC11
DEBUG: loader/loader.c:116:MainProc(): Resolving address for VirtualFree() : 6C2202BC71983B48
DEBUG: loader/loader.c:120:MainProc(): Resolving address for RtlExitUserProcess() : D800A5ABA2B6736
DEBUG: loader/loader.c:128:MainProc(): VirtualAlloc : 00007FF9F5658500 VirtualFree : 00007FF9F565A130
DEBUG: loader/loader.c:131:MainProc(): Allocating 11191206 bytes of RW memory
DEBUG: loader/loader.c:143:MainProc(): Copying 11191206 bytes of data to memory 0000000003090000
DEBUG: loader/loader.c:147:MainProc(): Zero initializing PDONUT_ASSEMBLY
DEBUG: loader/loader.c:156:MainProc(): Decrypting 11191206 bytes of instance
DEBUG: loader/loader.c:163:MainProc(): Generating hash to verify decryption
DEBUG: loader/loader.c:165:MainProc(): Instance : E4A3BBF6A5F99FD6 | Result : E4A3BBF6A5F99FD6
DEBUG: loader/loader.c:172:MainProc(): Resolving LoadLibraryA
DEBUG: loader/loader.c:189:MainProc(): Loading ole32
DEBUG: loader/loader.c:189:MainProc(): Loading oleaut32
DEBUG: loader/loader.c:189:MainProc(): Loading wininet
DEBUG: loader/loader.c:189:MainProc(): Loading mscoree
DEBUG: loader/loader.c:189:MainProc(): Loading shell32
DEBUG: loader/loader.c:193:MainProc(): Resolving 52 API
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for F3D8D921EC9A99AE
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for A1C1B8D40C5706FA
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 547D4F71D05AAC11
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 6C2202BC71983B48
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for C985925B339C8547
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 793261908369FEF9
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 506C0B111E3E5106
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 3AA2C9F3C392B9C7
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for F1955B6B856F4875
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for D57291392B24DA7E
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 04754BC89B15FB64
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for F08B5F1EFC304674
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for C3FE24D4973217EA
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for B24A59A4593B1474
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 07A3D1D11394BDC1
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 18DFC06FDA034FA9
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 3989712459149DD1
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for E3DA5474C1F9786A
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for E37091A9E24CFCDC
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 7152E58C758CC7BB
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for B921C572CE95BD2E
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 2E288705E20BC70A
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 9F2002085FF2118E
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 65422B5218EA3A36
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for CEE8C545CA921CBC
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 7C1CBEF755E8AC62
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for DEEE0DFDAF0357C2
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for F36588018B2DA340
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 6941870AF405F087
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 75B697D47EC2E2A4
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 2E2C45066474D7B1
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 5DBCA114B30F8B7D
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for D774FACDE4A306E3
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for C734C3BFE0C1CFAA
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 2A175920C9FFC9A3
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 3158CDE8204EFF16
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 28B3A3344199600D
DEBUG: loader/peb.c:86:FindExport(): 28b3a3344199600d is forwarded to api-ms-win-core-com-l1-1-0.CoInitializeEx
DEBUG: loader/peb.c:110:FindExport(): Trying to load api-ms-win-core-com-l1-1-0.dll
DEBUG: loader/peb.c:114:FindExport(): Calling GetProcAddress(CoInitializeEx)
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for A611759871C9F601
DEBUG: loader/peb.c:86:FindExport(): a611759871c9f601 is forwarded to api-ms-win-core-com-l1-1-0.CoCreateInstance
DEBUG: loader/peb.c:110:FindExport(): Trying to load api-ms-win-core-com-l1-1-0.dll
DEBUG: loader/peb.c:114:FindExport(): Calling GetProcAddress(CoCreateInstance)
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 5B1A6976AE5B4434
DEBUG: loader/peb.c:86:FindExport(): 5b1a6976ae5b4434 is forwarded to api-ms-win-core-com-l1-1-0.CoUninitialize
DEBUG: loader/peb.c:110:FindExport(): Trying to load api-ms-win-core-com-l1-1-0.dll
DEBUG: loader/peb.c:114:FindExport(): Calling GetProcAddress(CoUninitialize)
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 477C39DDD389C87B
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 6465C074060B0A12
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for CBBCEB0A63FE8513
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for E6924A3D8953ACB3
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for D27B847A7B4D4B01
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 0D800A5ABA2B6736
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for A750E98D47D929A0
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for AF90E8B956988F2C
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for EDFFACCF6C51AC60
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 265A5A25D91D20DB
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for 23DD80D2D39E2D05
DEBUG: loader/peb.c:86:FindExport(): 23dd80d2d39e2d05 is forwarded to NTDLL.RtlAddVectoredExceptionHandler
DEBUG: loader/peb.c:110:FindExport(): Trying to load NTDLL.dll
DEBUG: loader/peb.c:114:FindExport(): Calling GetProcAddress(RtlAddVectoredExceptionHandler)
DEBUG: loader/loader.c:196:MainProc(): Resolving API address for BDE1BA95D22E7EA0
DEBUG: loader/peb.c:86:FindExport(): bde1ba95d22e7ea0 is forwarded to NTDLL.RtlRemoveVectoredExceptionHandler
DEBUG: loader/peb.c:110:FindExport(): Trying to load NTDLL.dll
DEBUG: loader/peb.c:114:FindExport(): Calling GetProcAddress(RtlRemoveVectoredExceptionHandler)
DEBUG: loader/loader.c:218:MainProc(): Module is embedded.
DEBUG: loader/bypass.c:112:DisableAMSI(): Length of AmsiScanBufferStub is 37 bytes.
DEBUG: loader/bypass.c:122:DisableAMSI(): Overwriting AmsiScanBuffer
DEBUG: loader/bypass.c:137:DisableAMSI(): Length of AmsiScanStringStub is 37 bytes.
DEBUG: loader/bypass.c:147:DisableAMSI(): Overwriting AmsiScanString
DEBUG: loader/loader.c:226:MainProc(): DisableAMSI OK
DEBUG: loader/bypass.c:326:DisableWLDP(): Length of WldpQueryDynamicCodeTrustStub is 23 bytes.
DEBUG: loader/bypass.c:350:DisableWLDP(): Length of WldpIsClassInApprovedListStub is 37 bytes.
DEBUG: loader/loader.c:232:MainProc(): DisableWLDP OK
DEBUG: loader/loader.c:239:MainProc(): Compression engine is 2
DEBUG: loader/loader.c:241:MainProc(): Allocating 10428360 bytes of memory for decompressed file and module information
DEBUG: loader/loader.c:252:MainProc(): Duplicating DONUT_MODULE
DEBUG: loader/loader.c:256:MainProc(): Decompressing 11186214 -> 10427032
DEBUG: loader/loader.c:294:MainProc(): Decompressing with aPLib
DEBUG: loader/loader.c:296:MainProc(): Done
DEBUG: loader/loader.c:302:MainProc(): Checking type of module
DEBUG: loader/inmem_pe.c:102:RunPE(): Allocating 376832 (0x5c000) bytes of RWX memory for file
DEBUG: loader/inmem_pe.c:112:RunPE(): Copying `Headers`
DEBUG: loader/inmem_pe.c:115:RunPE(): Copying each section to RWX memory 00000000006A0000
DEBUG: loader/inmem_pe.c:127:RunPE(): Applying Relocations
DEBUG: loader/inmem_pe.c:151:RunPE(): Processing the Import Table
DEBUG: loader/inmem_pe.c:159:RunPE(): Loading USER32.dll
DEBUG: loader/inmem_pe.c:159:RunPE(): Loading COMCTL32.dll
DEBUG: loader/inmem_pe.c:159:RunPE(): Loading KERNEL32.dll
DEBUG: loader/inmem_pe.c:159:RunPE(): Loading ADVAPI32.dll
DEBUG: loader/inmem_pe.c:159:RunPE(): Loading GDI32.dll
DEBUG: loader/inmem_pe.c:323:RunPE(): Wiping Headers from memory
DEBUG: loader/inmem_pe.c:342:RunPE(): Executing entrypoint

[message]:()