Byla vydána nová verze 1.12.0 dynamického programovacího jazyka Julia (Wikipedie) určeného zejména pro vědecké výpočty. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Aktualizována byla také dokumentace.
V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).
Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.
Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.
Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.
Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.
Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.
Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.
Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.
Ř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: