- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
// тред лоулевел-хаков #1
#include <stdio.h>
#include <stdlib.h>
void hello(void)
{
puts("Hello!");
}
void goodbye(void)
{
puts("Goodbye!");
}
void set_sp_(void *p)
{
void *s[0];
s[0] = p;
}
void set_sp(void *p)
{
set_sp_((void*)p);
}
int main(void)
{
void *new_stack[1024] = {
[1019] = (void*)0,
[1020] = (void*)&hello,
[1021] = (void*)&goodbye,
[1022] = (void*)&exit
};
set_sp((void*)&new_stack[1019]);
return 0;
}
Hu3KoypoBHeBblunemyx 28.01.2022 21:03 # 0
Hu3KoypoBHeBblunemyx 28.01.2022 21:04 # 0
Hu3KoypoBHeBblunemyx 28.01.2022 21:08 # 0
Hu3KoypoBHeBblunemyx 28.01.2022 21:09 # 0
3.14159265 30.01.2022 04:29 # 0
bormand 30.01.2022 13:06 # 0
Hu3KoypoBHeBblunemyx 28.01.2022 21:11 # 0
Какой багор )))
GamCovidVacGovno 28.01.2022 23:01 # 0
Rooster 29.01.2022 11:06 # 0
You know he ain't gonna die.
Hu3KoypoBHeBblunemyx 30.01.2022 20:14 # 0
Hu3KoypoBHeBblunemyx 30.01.2022 20:16 # 0
Hu3KoypoBHeBblunemyx 30.01.2022 20:20 # +1
bormand 30.01.2022 21:09 # +1
Впрочем, от переполнения буфера это действительно спасёт т.к. задев сохранённый rbp или rip ты неизбежно заденешь и канарейку (т.к. она отделяет их от локалок).
HoBorogHuu_nemyx 30.01.2022 21:25 # +1
Кви-кви-кви си перде леко...
ObeseYoung 30.01.2022 22:30 # 0
Hu3KoypoBHeBblunemyx 01.02.2022 19:03 # 0
bormand 01.02.2022 20:20 # +1
Я здесь вообще не вижу никаких стек протекторов, просто кто-то забыл включить оптимизацию и конпелятор был вынужден сохранять аргумент на стек чтобы отладчику потом не пришлось выковыривать его из других фреймов.
Hu3KoypoBHeBblunemyx 01.02.2022 20:29 # 0
bormand 01.02.2022 20:31 # +1
Возможно, конпелятор охуел от обращения к массиву из 0 элементов, подумал что это в любом случае UB и не стал вставлять протектор.
З.Ы. А, вижу, там просто зазор от локалок до границы фрейма больше стал. Кстати прикольно, на этом примере видно, как конпелятор юзает редзону не двигая rsp. В ядре такой код пизданулся бы на первом прерывании.
Hu3KoypoBHeBblunemyx 01.02.2022 20:37 # 0
А я сперва подумал, что там блу канари)
> В ядре такой код пизданулся бы
А для едра с каким ключиком конпелять?
bormand 01.02.2022 20:38 # 0
guest6 01.02.2022 20:42 # 0
bormand 01.02.2022 20:44 # 0
bormand 01.02.2022 20:35 # +1
This includes functions that call alloca, and functions with buffers larger than or equal to 8 bytes. У тебя буфер маловат, гцц считает, что его невыгодно/нинужно защищать.
А strong уже на все функции с массивами работает.
Hu3KoypoBHeBblunemyx 01.02.2022 20:38 # 0
ISO 01.02.2022 21:26 # 0
Soul_re@ver 01.02.2022 21:40 # 0
HoBorogHuu_nemyx 01.02.2022 22:01 # 0
Поэтому нужно либо создавать экземпляры классов, либо сравнивать их статические свойства. Например, есть встроенное свойство class, которое возвращает его имя:
A::class == B::class
Вернёт false, потому что 'A' не равно 'B'.
bormand 30.01.2022 21:16 # +2
Hu3KoypoBHeBblunemyx 01.02.2022 19:00 # 0
Hu3KoypoBHeBblunemyx 01.02.2022 19:21 # 0
Походу они с оптимизациями собирают
Какой багор )))
bormand 01.02.2022 20:24 # 0
Чтобы предотвратить утечку печеньки, видимо.
> nop
Не помню, если честно. Он то ли для раскрутки стека нужен то ли для отладчика, чтобы однозначно понимать, в теле функции мы навернулись или в эпилоге (иначе не отличить трапа в инструкции n от фолта в инструкции n + 1). Заметь, что стоит он между джвумя инструкциями, которые лезут к памяти.
HoBorogHuu_nemyx 30.01.2022 21:35 # 0
kcalbCube 17.02.2022 09:20 # 0
ucnaHckuu_CTblD 17.02.2022 15:57 # 0