DNS разрешить бросить системный вызов LinuxLinux

Ответить Пред. темаСлед. тема
Anonymous
 DNS разрешить бросить системный вызов Linux

Сообщение Anonymous »

Пожалуйста, помогите. этот код когда-то работает, но иногда не работает
он ​​получает ответ на DNS
иногда он долго ждет от функции приема (и нет ответа), но иногда все работает хорошо
Я скомпилировал его с помощью двух команд jwasm и gcc linux
JWasm212\JWasm.exe -elf64 -Fo=test.o test.asm

gcc -o test.out test.o -nostartfiles -nostdlib -nodefaultlibs --disable-shared -no-pie

иногда функция приема долго ждет (и нет ответа), но иногда все работает хорошо
код:
public _start

socket equ 41
connect equ 42
sendto equ 44
recv equ 45

sockaddr_in struct

sin_family dw ?
sin_port dw ?
sin_addr dd ?
sin_zero db 8 dup (?)

sockaddr_in ends

.data

queryheader db 00h, 03h ; AA AA - ID
db 01h, 00h ; 01 00 - Query parameters
db 00h, 01h ; 00 01 - Number of questions
db 00h, 00h ; 00 00 - Number of answers
db 00h, 00h ; 00 00 - Number of authority records
db 00h, 00h ; 00 00 - Number of additional records

db 06h
db 'g'
db 'o'
db 'o'
db 'g'
db 'l'
db 'e'

db 03h
db 'c'
db 'o'
db 'm'

db 00h ; 00 - zero byte to end the QNAME

db 00h, 01h ; 00 01 - QTYPE
db 00h, 01h ; 00 01 - QCLASS

.code

_start:

_dns proc uses r12 r13 r14 r15 rbx

local sockaddr : sockaddr_in
local cSocket : qword
local fullpacket[512] : byte

lea rdi, sockaddr
mov rcx, sizeof sockaddr

xor al, al
rep stosb

mov word ptr [sockaddr.sin_family], 02h ;AF_INET
mov word ptr [sockaddr.sin_port], 3500h ;port 53 (dns)
mov dword ptr [sockaddr.sin_addr], 08080808h ; 8.8.8.8 google dns

mov rdi, 2 ;AF_INET
mov rsi, 2 ;SOCK_DGRAM
mov rdx, 0

mov rax, socket
syscall

mov qword ptr [cSocket], rax

mov rdi, qword ptr [cSocket]
lea rsi, sockaddr
mov rdx, 16

mov rax, connect
syscall

mov rdi, qword ptr [cSocket]
lea rsi, queryheader
mov rdx, 28 ;len
xor r10, r10 ;flags
xor r8, r8 ;dest_addr
xor r9, r9 ;addrlen

mov rax, sendto
syscall

mov rdi, qword ptr [cSocket]
lea rsi, fullpacket ;*buf
mov rdx, 512 ;packetlen
xor r10, r10 ;flags
xor r8, r8 ;address
xor r9, r9 ;addrlen

mov rax, recv
syscall

ret

_dns endp

end


Подробнее здесь: https://stackoverflow.com/questions/786 ... call-linux
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Linux»