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í
×
    26.12. 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    26.12. 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 7
    26.12. 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    26.12. 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

    Ladislav Hagara | Komentářů: 0
    25.12. 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 30
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (36%)
     (1%)
     (19%)
     (1%)
     (1%)
     (1%)
     (14%)
     (13%)
     (14%)
    Celkem 140 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    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: 1036×
    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.