Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
Snazim se pomoci gdb debugovat program, ktery dela neco jineho nez si myslim, ze by mel delat.
a docela me prekvapilo:
305 poradi=0; (gdb) print &poradi $20 = (int *) 0x41401128 (gdb) s 306 vytvorpole(koren); (gdb) print &poradi $21 = (int *) 0x41401128 (gdb) s vytvorpole (kmen=0x46d7250) at pipestat.c:276 276 if (kmen->mensi != NULL ) { (gdb) print &poradi $22 = (int *) 0x413fd288
Jaktoze je poradi pokazde neco jineho?
Jsem si jisty, ze je definovano prave jednou.
marekporadi
definováno v hlavičkovém souboru?
Nechtel jsem zatezovat prehnanou delkou kodu, pokud by to bylo pro nekoho zkusenejsiho jasne a pripadne zcela v poradku.
takze:
typedef struct zaznam { char text[MAXRECLEN]; int pocet; struct zaznam *mensi,*vetsi; } zaznam; void *findexer() { zaznam **pole; pole = (zaznam **) malloc( sizeof(zaznam *) * (prvku) ); int poradi; void *vytvorpole(zaznam *kmen) { if (kmen->mensi != NULL ) { vytvorpole(kmen->mensi); } //printf("---------%10d %s\n", kmen->pocet, kmen->text); pole[poradi]=kmen; poradi++; if (kmen->vetsi != NULL ) { vytvorpole(kmen->vetsi); } } while (1) { sleep(1); if (koren != NULL) { pthread_mutex_lock( &mdata ); int pozadi; for (pozadi=0;pozadi<prvku;pozadi++) { pole[pozadi]=NULL; } poradi=0; vytvorpole(koren); printf("%d*********************\n",prvku); for (pozadi=0;pozadi<prvku;pozadi++) { printf("%s %d\n",pole[pozadi]->text,pozadi); } pthread_mutex_unlock(&mdata ); } } }
funkce ma podle me naplnit pole[] seradenejma ukazatelama na zaznamy
marekporadi
sídlí v paměti. Měl byste se akorát starat o to, že když do té proměnné něco zapíšete, tak budete z toho schopen to samé později přečíst. Jestli mezitím proměnná odtancuje na druhej konec paměti, na disk, nebo jiný počítač, do toho nešťourejte.
Jedno možné vysvětlení, proč je proměnná jinde, může být, že je to automatická proměnná na zásobníku a Vy používáte navíc vnořené funkce, což není zrovna C-standardní. Může být, že překladač tu proměnnou propasuje do té vnitřní funkce tak, že jí skopíruje na jiné místo na stacku (a pak zpět). Ale to jen hádám. Podstatný je odstavec číslo jedna.
Takze chybu mam.
Alokace pole musi byt v tom cyklu, kde se testuje, jestli uz existuje koren a zase se to musi vzdy uvolnit.
Jak jsem to psal postupne, tak jsem si to chtel ze zacatku jenom vyzkouset a predpokladal jsem, ze kdyz tu funkci zavolam, tak uz mam nactene vsechny testovaci zaznamy. To bylo bohuzel chyba - zaznamy se nactou az v tom sleepu. A ja jsem mel tim padem naalokovano do pole 0. A ukazovalo to na to same misto, kam se naalokovalo poradi a za nej prvni zaznam. Takze pole se zapisovalo do poradi a prvniho potom alokovaneho zaznamu.
Sice to nevysvetluje to &poradi, ale to me vlastne i podle pht nemusi vubec trapit.
Pouceni: kdyz se pise vicevlaknove, tak nema moc smysl neco zkouset, dokud neni dopsan cely logicky blok
marekjsem si to chtel ze zacatku jenom vyzkousetJe lepší programy vyzkoušet tak, že napíšete automatický testovací kód. Pak obvykle víte přesně co se v testovaném programu děje.
Tiskni
Sdílej: