Portál AbcLinuxu, 19. dubna 2024 00:50
Řešení dotazu:
V Linuxe nie je problem zo stackom pri Intel/AMD pouzitom ako bezne PC, lebo ak je maly stack, da sa prealakovat a bude vacsi. V Linuxe nie je problem zo stackom pri Intel/AMD pouzitom ako bezne PC, lebo ak je maly stack, da sa prealakovat a bude vacsi.Toto nie je pravda. Da sa iba zmenit velkost pred spustenim (pripadne bez limitu).
#include <stdio.h> #include <stdlib.h> #define CHARS 1024 long int move_stack(void *stack_bot, void (*jmp_addr)(void)); void function_in_new_stack(void) { long int foo; char string[CHARS]; for (char *ch = string + CHARS; ch >= string; ch--) { *ch = 'A'; } puts(string); printf("Cur. stack ptr: 0x%lx\n", (size_t) &foo); } int main(int argc, char **argv) { long int foo; void *stack, *stack_bot; printf("Cur. stack ptr: 0x%lx\n", (size_t) &foo); stack = malloc(4096); stack_bot = stack + 4096; printf("New stack addr.: 0x%lx\n", (size_t) stack); printf("New stack bottom: 0x%lx\n", (size_t) stack_bot); puts("Moving to the new stack."); foo = move_stack(stack_bot, &function_in_new_stack); printf("Function worked: 0x%lx %c\n", foo, foo); printf("Cur. stack ptr: 0x%lx\n", (size_t) &foo); puts("Freeing the stack."); free(stack); }
.globl move_stack move_stack: /* Tyto registry zachováváme. */ pushq %rbx pushq %r12 pushq %r13 pushq %r14 pushq %r15 /* V %rdi je spodek nového stacku, v %rsi funkce k zavolání. */ /* Poznamenáme si starou adresu stacku. */ mov %rsp, %rbx /* Přejdeme do nového stacku. */ movq %rdi, %rsp /* Adresu uložíme na nový stack. */ pushq %rbx call %rsi /* Vrátíme se zpět. */ popq %rsp /* Uklidíme po sobě. */ popq %r15 popq %r14 popq %r13 popq %r12 popq %rbx /* Vrátíme 'Y' jako návratovou hodnotu. */ movq $0x59, %rax retFunkce
move_stack
zavolá funkci s daným stackem. Funguje to – viz výstup. Pokud nastavím CHARS
na příliš velkou hodnotu (nový stack má 4k), spadne to na SIGSEGV, takže se používá nový stack.
(Tuším tady úkol.)
sou prázniny :O ;D
Tiskni Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.