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

Подскажите пожалуйста, для того, что бы сохранить регистры неимезнными в

соответствии с calling convention, я делаю вот так:
push RBP
push RBX
push RDI
push RSI
push R12
push R13
push R14
push R15
mov RBP, RSP
sub RSP, 8 ;align saved registers
;--- /пролог
...some code...
;--- эпилог
mov RSP, RBP
pop R15
pop R14
pop R13
pop R12
pop RSI
pop RDI
pop RBX
pop RBP
ret

и я так понимаю, что так делать нельзя, потому что теперь некоторые winapi затирают ret адрес в моих функциях
так делать нельзя ? ) я знаю, что в линуксе например есть красная зона за указателем стека процедуры которая сохраняется неизменной и не трогается системой, смею предположить, что написав эпилог таким образом я вышел за рамки этой красной зоны или что-то в этом роде в винде, что скажите ?

2 ответов

7 просмотров

погодь, так ты регистры сохраняешь как параметры с rbp+, а надо сохранять как локальные переменные с rbp-

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

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

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
22
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Карта сайта