Na dnešní akci Made by Google 2025 (YouTube) byly představeny telefony Pixel 10 s novým čipem Google Tensor G5 a novými AI funkcemi, hodinky Pixel Watch 4 a sluchátka Pixel Buds 2a.
The Document Foundation oznámila vydání nové major verze 25.8 svobodného kancelářského balíku LibreOffice. Podrobný přehled nových vlastností i s náhledy v poznámkách k vydání (cs) a také na Youtube a PeerTube.
Zeek (Wikipedie), původně Bro, byl vydán v nové major verzi 8.0.0. Jedná se o open source platformu pro analýzu síťového provozu. Vyzkoušet lze online.
Byl vydán Mozilla Firefox 142.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 142 je již k dispozici také na Flathubu a Snapcraftu.
Python Developers Survey 2024, výsledky průzkumu mezi vývojáři v Pythonu organizovaném Python Software Foundation ve spolupráci se společností JetBrains v říjnu a listopadu loňského roku. Zúčastnilo se 30 tisíc vývojářů z 200 zemí. Linux používá 59 % z nich.
Farid Abdelnour se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.08.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.
Byla vydána nová verze 2.51.0 distribuovaného systému správy verzí Git. Přispělo 91 vývojářů, z toho 21 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
Po roce bylo vydáno nové číslo magazínu Phrack: Phrack 72.
OpenSSL Corporation zve na den otevřených dveří ve středu 20. srpna v Brně a konferenci OpenSSL od 7. do 9. října v Praze.
Ř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: