abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:00 | Humor

    Adam Rice předvedl, že pomocí DNS lze distribuovat a spustit kompletní hru DOOM. Rozdělil WAD soubory a binárky do téměř 2000 DNS záznamů v Cloudflare zóně (jeden TXT záznam v DNS může nést okolo 2000 znaků textu). Ty pak stáhl PowerShellem, dekomprimoval a spustil přímo v paměti počítače bez nutnosti zápisu na disk, což prakticky dokazuje, že DNS může sloužit jako distribuované úložiště dat a možný kanál pro načítání kódu. Repozitář projektu je na GitHubu.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 13:00 | Komunita

    Dnes a zítra probíhají Arduino Days 2026. Na programu je řada zajímavých přednášek. Sledovat je lze od 17:00 na YouTube. Zúčastnit se lze i lokálních akcí. Dnes v Poličce v městské knihovně a zítra v Praze na Matfyzu.

    Ladislav Hagara | Komentářů: 2
    včera 12:11 | Nová verze

    Byla vydána beta verze Ubuntu 26.04 LTS s kódovým názvem Resolute Raccoon. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 26.04 LTS mělo vyjít 23. dubna 2026.

    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Komunita Ladislav Hagara | Komentářů: 8
    26.3. 23:22 | Komunita

    Ubuntu plánuje v budoucích verzích nahradit tradiční nástroje pro synchronizaci času (chrony, linuxptp a gpsd) novým, v Rustu napsaným ntpd-rs, který nabídne vyšší bezpečnost a stabilitu.

    Ladislav Hagara | Komentářů: 3
    26.3. 22:33 | Nová verze

    Byla vydána nová verze 7.6 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Správce hesel KeePassXC byl nahrazen správcem hesel GNOME Secrets. Bitcoinová peněženka Electrum byla povýšena na verzi 4.7.0. Tor Browser byl povýšen na verzi 15.0.8. Další novinky v příslušném seznamu.

    Ladislav Hagara | Komentářů: 1
    26.3. 11:33 | Zajímavý článek

    Chris Down v obsáhlém článku „vyvrací mýty o zswap a zram“, vysvětluje, co vlastně dělají a jaké jsou mezi nimi rozdíly. Doporučuje vyhýbat se zram na serveru a bez OOM.

    |🇵🇸 | Komentářů: 1
    26.3. 11:22 | IT novinky

    Porota v Los Angeles shledala firmy Google a Meta odpovědnými v přelomovém soudním sporu, který se týká závislosti na sociálních sítích; firmy musí zaplatit odškodné tři miliony dolarů (63,4 milionu Kč). Společnosti, které s verdiktem nesouhlasí, čelily obvinění, že své sociální sítě a platformy záměrně navrhly tak, aby si na nich děti vypěstovaly závislost. Porota došla k závěru, že technologické společnosti při navrhování a

    … více »
    Ladislav Hagara | Komentářů: 14
    25.3. 19:11 | Komunita

    Jelikož vývojáři editorů Vim a Neovim začali při vývoji využívat LLM, Drew DeVault se rozhodl forknout Vim a vytvořil projekt Vim Classic. Vychází z Vimu 8.2.0148, tj. těsně před zavedením Vim9 skriptování.

    Ladislav Hagara | Komentářů: 6
    25.3. 16:11 | Nová verze

    Byla vydána nová verze 0.56 open source počítačové hry Unvanquished (Wikipedie), forku počítačové hry Tremulous. Instalovat ji lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1163 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    Dotaz: C dohledání memory leaks

    5.5.2022 14:20 MilanC | skóre: 16
    C dohledání memory leaks
    Přečteno: 1047×
    Ahoj,

    potřeboval bych svůj výtvor nějak ověřit a být si jistý, že neobsahuje žádné memory leaks. Beží na embedded mips zařízení, proto využívám cross kompilace. V samotném mém programu je jedinný malloc a realloc, takže o to mi až tak nejde. Jde mi hlavně o využívané funkce ze sdílených knihoven - typicky libcurl a json-c.

    Pokoušel jsem se tam dostat valgrind a to se mi i povedlo, nicméně jej nemohu použít z důvodu nedostatku RAM. Zkusil jsem nyní přikompilovat do projektu memwatch, ale když nad tím přemýšlím, podle mého mi to asi ve věci využívaných sdílených knihoven příliš nepomůže?

    Můj program je hardwarově závislý, takže využívá i knihovny pro přístup k danému HW. Proto nevidím moc reálné to ladit někde jinde, kde bude více RAM, třeba v nějakém emulátoru. Samozřejmě bych si ty hw knihovny mohl namockovat, ale takové ověření by pak postrádalo trochu smysl a opravdu bych možná ověřil jen ten curl a json a nic víc.

    Nemáte nějaký nápad nebo tip na nástroj, který by mi s tím pomohl? Z běžných linuxových nástrojů mám v podstatě jen busybox a ulibc, takže dost omezení.

    Děkuji.

    Odpovědi

    5.5.2022 14:58 X
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    To je furt to same jako minule? To se snad vyresilo ne?
    5.5.2022 15:21 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    Ahoj, vyřešilo, zabraná paměť se rapidně snížila, ale to samé to není.

    Já teď potřebuji ověřit, protože je z toho v podstatě trvale běžící "démon" provádějící různé akce na pozadí, že mi to za týden nevyžere zdroje. Zatím to mám pořešené restartovací smyčkou, ale to je takové trochu prasácké a komplikuje mi i trochu život. :-)

    Já s těmito nástroji nemám moc zkušenost, naposledy jsem hojně využíval MemProof pro Delphi, tak nevím, jestli je možnost nějak ty chyby odhalit. Prostě si představuji, že to nechám chvíli běžet, pak tomu pošlu kill a získám nějaký report, že vše, co bylo alokováno bylo také uvolněno. Ale fakt nemám zkušenost a už vůbec ne s těmi sdílenými knihovnami. Třeba u json-c je pro uvolnění dost často volat json_object_put, ale ani v oficiálních příkladech jej nevolají pokaždé, takže těžko tušit, kdy přesně ho tam mít (jestli i u parse metod nebo jen když vytvářím novou json strukturu atd.). Prostě tam mám nějaké nejistoty a rád bych si je nějak potvrdil. :)
    5.5.2022 17:17 X
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    5.5.2022 21:07 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    Joj, ach. Cečko ma dve spôsoby predávania dát, priamo (skopírujú sa na zásobník) a cez pointere. Parameter const znamená, že sa dáta čítajú, nemodifikujú. Musíš vedieť, ako ktorá funkcia pracuje a tak sa zariadiť. Čo sa novo alokuje, následné dealokovať. Aj pri pomocných funkciách.

    Ak nevieš čo robí Ta funkcia, tak si pozrí jej kód, ak je knižnica open-source a budeš mať (väčšiu) istotu.

    Prečo robíš a la embed C? Prečo to nenecháš, čo sa v tom vyznajú, keď si trošku stratený.

    Rob si monitoring systému so záznamy v historií, aby si vedel ako sa to správa. A prípadne maj poistku - pri istej vyťaženosti proces reštartuješ.
    debian.plus@protonmail.com
    6.5.2022 00:32 dsss
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    S oblibou pouzivam promenne prostredi MALLOC_CHECK_ (man 3 mallopt) a valgrind.
    6.5.2022 13:24 ehmmm
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    Nevim, co to je za stroj, takze obecne rady.

    Pokud to je neco typu Arduino, tak dlouhodobe sledovat stack a heap a prostor mezi nima. Osobne se mallocu v embedded vyhybam a kdyz uz, tak uvolnovat presne v opacnem poradi, nez se alokuje, aby nebyly v heapu diry.

    Pokud to je neco, kde uz je treba i Linux, tak koukat na velikost obsazene pameti jednotlivych procesu a nesmi proste stoupat. Proste za tyden musi byt stejna jako pred tydnem.

    Pokud mas podezreni na nejakou funkci, tak misto abys ji volal obvykle napr. jednou za hodinu, tak ji zavolej milionkrat a hned budes vedet, jestli to je v poradku.

    Vsichni si tu delaji legraci s Pascalu, ale treba Lazarus ma HeapTrc a ten ukaze, jestli jsem nahodou nezapomnel neco uvolnit.
    8.5.2022 04:03 BFU
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    Co zkusit LSan:

    https://github.com/google/sanitizers/wiki/AddressSanitizerLeakSanitizer

    Je to soucast gcc i clang, dela to compile-time instrumentaci takze je to signifikantne rychlejsi nez valgrind. Pouziti je tim stylem, ze se userspace prekompiluje s '-g3 -Og -fsanitize=address'/'leak' CFLAGS/LDFLAGS (at to ma debug symboly bez optimalizace at to muze rozumne resolvovat backtrace) a pak se to proste spusti. Jakmile program skonci, tak vyhodi nejakou statistiku leaku.
    8.5.2022 21:08 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    Tohle by se mi dost líbilo, ale asi mám smůlu... ale díky
    helper.c:1:0: error: -fsanitize=address not supported for this target [-Werror]
    8.5.2022 23:19 BFU
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    ASan by mel Linux/MIPS target umet. Mozna to staci zapnout pri kompilovani toolchainu, nebo je toolchain opravdu moc stary ?
    23.5.2022 12:14 Jindřich Makovička | skóre: 17
    Rozbalit Rozbalit vše Re: C dohledání memory leaks
    Toho valgrindu je škoda, kromě detekce leaků umí i heap profiling, který ukáže i paměť, která se třeba na konci uvolní, jen se jí alokuje zbytečně moc, např.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.