169 похожих чатов

Короче сгенерила мне эта штука код на ассемблере: struc string val

{
common
local .value
dq .value
.value:
if ~val eq
db val
end if
db 0
}

format ELF64 EXECUTABLE 3

; function main
main:
push rbp
mov rbp, rsp
argc equ ebp+16
argv equ ebp+24
mov rax, [_ba3a02b09bc44fb1]
push rax
call puts
add rsp, 8
mov rax, 0
leave
ret


; function puts
puts:
push rbp
mov rbp, rsp
string equ ebp+16
mov rax, [string]
push rax
call strlen
add rsp, 8
mov rdx, rax
mov rax, 4
mov rax, rax
mov rax, 1
mov rbx, rax
mov rax, [string]
mov rcx, rax
int 0x80
leave
ret


; function strlen
strlen:
push rbp
mov rbp, rsp
string equ ebp+16
mov rax, [string]
mov rsi, rax
mov rax, rcx
mov rbx, rax
mov rax, rcx
xor rax, rbx
mov rcx, rax
repnz scasb
mov rax, rcx
leave
ret


_ba3a02b09bc44fb1 string <"Hello, world!", 10, 0>

А этот код, падла, сегфолтит. можете подсказать, в чём проблема?

12 ответов

59 просмотров

* оптимизатор ещё не писал

Стикер

хз, я без дебаггера запускал

я нашел несколько багов в своем генераторе, исправил, код теперь другой, но всё ещё сегфолтит struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } format ELF64 EXECUTABLE 3 ; function main main: push rbp mov rbp, rsp argc equ rbp+16 argv equ rbp+24 mov qword rax, [_31849ec0716e454d] push qword rax call puts add qword rsp, 8 mov qword rax, 0 leave ret ; function puts puts: push rbp mov rbp, rsp string equ rbp+16 mov qword rax, [string] push qword rax call strlen add qword rsp, 8 mov rdx, rax mov qword rax, 4 mov rax, rax mov qword rax, 1 mov rbx, rax mov qword rax, [string] mov rcx, rax int 0x80 leave ret ; function strlen strlen: push rbp mov rbp, rsp string equ rbp+16 mov qword rax, [string] mov rsi, rax mov qword rax, rcx mov rbx, rax mov qword rax, rcx xor rax, rbx mov rcx, rax repnz scasb mov qword rax, rcx leave ret _31849ec0716e454d string <"Hello, world!", 10, 0>

Vi Chapmann ٩( 💢•̀ з•́)و Chapmann
я нашел несколько багов в своем генераторе, исправ...

* и да, я знаю, что там куча бесполезных инструкций. будет исправлено

да как это узнать? я gdb толком не пользовался

а как ещё длину строки вернуть то

☝️

Похожие вопросы

Обсуждают сегодня

Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
22
Is there a digital way to cut the electricity from a usb in linux? It sounds weird, but it's exactly what I need to do. I tried to simulate the unplug/replug but is not the ...
Eduard Rivas
15
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
generic procedure function test<T>(param: T); type case T of longint: NewT = word; longword: NewT = byte; end; var v1: NewT; Как это можно сделать? Чтобы у меня...
notme
21
Делал задачу вот такую https://stepik.org/lesson/4985/step/9?unit=1083 получилось такое https://play.haskell.org/saved/ipKrepqe оно работает, тестов много не писал, но работае...
Fedor
22
Можно вообще написать: Person fName' lName' age'. Тогда действительно имена полей потребуются лишь в строковом виде, чтобы эти fName' и т.д. достать :-) Но разве для этого нуж...
Михаил
8
Hello everyone I am trying to run 4 year old project and I am having this issue anyone can help?
Nitish Garg
11
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Карта сайта