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í
×

včera 13:11 | Komunita

Mozilla.cz informuje o 2 plánovaných novinkách ve Firefoxu. Nové webové funkce budou ve Firefoxu dostupné jen přes HTTPS (en) a nové verze Firefoxu přinesou rychlejší přepínání panelů (předehřívání nebo žhavení panelů, anglicky tab warming).

Ladislav Hagara | Komentářů: 4
včera 12:44 | IT novinky

Hodnota Bitcoinu, decentralizované kryptoměny, klesla na cca 12 000 dolarů. Před měsícem byla hodnota Bitcoinu téměř 20 000 dolarů [reddit].

Ladislav Hagara | Komentářů: 9
včera 05:55 | Bezpečnostní upozornění

Bezpečnostní tým Cisco Talos upozorňuje na celou řadu bezpečnostních chyb v Blenderu. Vývojáři Blenderu byli o chybách informování již v září. Dosud tyto chyby ale opraveny nebyly. Doporučeno je neotevírat v Blenderu soubory z nedůvěryhodných zdrojů.

Ladislav Hagara | Komentářů: 2
15.1. 17:22 | Bezpečnostní upozornění

Společnost F-Secure upozorňuje na bezpečnostní "problém" v Intel AMT (Active Management Technology). Útočník s fyzickým přístupem k počítači s povoleným AMT a nenastaveným heslem k MEBx (Management Engine BIOS Extension) může obejít heslo nastavené v BIOSu, pin v TPM, přihlašovací jméno a heslo do operačního systému nebo i šifrování disků restartováním tohoto počítače a při jeho startu zavedením MEBx (CTRL-P) a zadáním výchozího hesla "admin". Pak už útočníkovi stačí pouze změnit heslo a povolit vzdálený přístup k počítači na úrovni AMT.

Ladislav Hagara | Komentářů: 10
15.1. 15:11 | Zajímavý projekt

Na Indiegogo byla dnes spuštěna kampaň na podporu 6 palcového notebooku a kapesní herní konzole GPD WIN 2. Cena v rámci kampaně byla stanovena na 649 dolarů. Cílová částka 100 tisíc dolarů byla překonána již 8 krát. Ukázka s Linuxem na YouTube.

Ladislav Hagara | Komentářů: 4
15.1. 05:55 | Bezpečnostní upozornění

V GitLabu, v open source alternativě GitHubu, tj. v softwarovém nástroji s webovým rozhraním umožňujícím spolupráci na zdrojových kódech, byl nalezen vážný bezpečnostní problém. Bezpečnostní aktualizace bude vydána ve středu 17. ledna v 00:59.

Ladislav Hagara | Komentářů: 3
15.1. 04:44 | Komunita

Firefox končí s podporou GTK+ 2. Od verze 59 bude možné Firefox sestavit pouze s GTK+ 3 [reddit].

Ladislav Hagara | Komentářů: 30
15.1. 01:22 | Pozvánky

První letošní pražský sraz spolku OpenAlt se koná již tento čtvrtek 18. ledna od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Vítáni jsou všichni příznivci svobodného softwaru a hardwaru, ESP32, DIY, CNC, SDR nebo dobrého piva. Prvních deset účastníků srazu obdrží samolepku There Is No Cloud… just other people's computers. od Free Software Foundation.

xkucf03 | Komentářů: 0
15.1. 00:11 | Pozvánky

Spolek OpenAlt zve příznivce otevřených technologií a otevřeného přístupu na 148. brněnský sraz, který proběhne v pátek 19. ledna od 18:00 hodin v MIKI pub & restaurant na Makovského náměstí 3166/2. Sraz je spojen s návštěvou (již v 16:30) Ústavu fyzikálního inženýrství Fakulty strojního inženýrství Vysokého učení technického v Brně.

Ladislav Hagara | Komentářů: 0
13.1. 23:22 | Nová verze

Po čtyřech měsících vývoje od vydání verze 5.7.0 byla vydána verze 5.8.0 správce digitálních fotografií digiKam (digiKam Software Collection). V Bugzille bylo uzavřeno 231 záznamů. Ke stažení je také balíček ve formátu AppImage (Wikipedie).

Ladislav Hagara | Komentářů: 0
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (7%)
 (1%)
 (1%)
 (1%)
 (77%)
 (13%)
Celkem 1306 hlasů
 Komentářů: 48, poslední 22.12. 22:05
    Rozcestník

    Dotaz: Jak najít uniklou paměť (leaky)

    31.1.2013 04:02 ček
    Jak najít uniklou paměť (leaky)
    Přečteno: 582×
    Ahoj. Zajímalo by mě, jestli a jak je možné najít v běžícím programu (napsaném např. v C) paměť, na kterou už neukazují žádné ukazatele, ale nebyla uvolněna? Takhle vlastně vzniknul memory leak a mám teoreticky nepoužitelnou paměť. Nicméně operační systém ví, kterou paměť má proces alokovanou, takže by to mohlo jít čistě teoreticky zjistit i v běžícím programu, jenže jak?

    Řešení dotazu:


    Odpovědi

    Řešení 1× (rastos)
    31.1.2013 07:52 pesspi | skóre: 7 | blog: hateblog
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    valgrind
    31.1.2013 16:15 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Tazatel ale chce řešit již běžící proces.
    Řešení 1× (petr_p)
    31.1.2013 12:25 mike
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Ahoj. Zajímalo by mě, jestli a jak je možné najít v běžícím programu (napsaném např. v C) paměť, na kterou už neukazují žádné ukazatele

    Nelze, v C nemas zadny reference counter. Proste si alokujes pamet a je na tobe abys ji uvolnil. Valgrind ti muze vypsat kolikrat se zavolal malloc() a kolikrat se zavolal free(), tim muzes zjistit jestli se vsechno uvolnilo.

    Nicméně operační systém ví, kterou paměť má proces alokovanou, takže by to mohlo jít čistě teoreticky zjistit i v běžícím programu, jenže jak?

    Obecne to neni pravda. Zalezi na alokatoru.

    31.1.2013 13:25 l4m4
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Upřesnil bych: Operační systém ví, kterou paměť má proces alokovanou z pohledu jádra. To je ale k ničemu. Funkce typu free() (a podobné, v závislosti na alokátoru) normálně pouze vracejí paměť do heapu procesu, která je z pohledu jádra celá alokovaná tomu procesu. Neděje se žádné volání brk(), kterým by se proces zase datovou část adresního prostoru zmenšil. Operační systém proto až na výjimky nerozpozná, která část paměti je alokovaná a která není z pohledu aplikace.
    31.1.2013 16:19 ček
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Funkce typu free() (a podobné, v závislosti na alokátoru) normálně pouze vracejí paměť do heapu procesu, která je z pohledu jádra celá alokovaná tomu procesu.
    O to mi jde. Zjistit v samotném běžícím programu, jakou všechnu datovou paměť má pro daný proces alokovanou jádro. Pak by čistě teoreticky nebyl problém zjistit, na kterou část paměti už program nemá referenci. Chápu, že je blbost tohle dělat. Zajímá mě to čistě na teoretické úrovni, zda by to šlo naprogramovat.
    31.1.2013 16:32 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Hm, dost těžko, adresa v aplikaci není totožná s fyzickou adresou.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    2.2.2013 17:06 luky
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Hm, dost těžko, adresa v aplikaci není totožná s fyzickou adresou.
    Hm, dost snadne, adresa v jadre je totozna s adresou v aplikaci ;-)

    cat /proc/PID/maps
    2.2.2013 17:29 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    No vida, přemýšlel jsem nad tím špatně… ;-)
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    31.1.2013 16:40 l4m4
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Tato informace je v /proc/self/maps (nebo /proc/$PID/maps, pokud to chceš číst jinému procesu).
    31.1.2013 17:44 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)

    Budete zklamaný. Přiblížím Linux na x86:

    Každý proces má vlastní virtuální paměť. Na některá místa jsou mapované různé části kódu procesu (program a knihovny) a na některá samotný Linux. Tohle všechno je v podstatě statická věc jen pro čtení. Ta vás vůbec nezajímá. Pak máte různé bloky se sdílenou pamětí (SHM, I/O), to vás ale také nemusí zajímat (kdyby ano, pak byste se na to tady neptal, protože by to pro vás byla trivialita).

    A pak jsou už jen dvě velké oblasti. Halda a zásobník. Haldu si proces voláním brk(2) zvětšuje či zmenšuje, ale nikdy do ní nemůže udělat díry. Vždy se jedná o spojitou oblast. Zásobník roste z druhého konce adresního prostoru proti haldě. Ten ovšem z hlediska jádra je předalokován na konkrétní velikost (ulimit(1)) a z principu x86 ABI taky v něm nemohou být díry a navíc si jeho velikost proces (zjednodušeně vzato) nemůže měnit.

    Takže když to shrnu, tak jediný zajímavý údaj je velikost haldy. Tedy jedno číslo. Tedy přesně ten údaj který vidí jádro.

    2.2.2013 17:09 luky
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Ten ovšem z hlediska jádra je předalokován na konkrétní velikost (ulimit(1))
    Zasobnik se zvetsuje dynamicky podle toho, jak je vyuzivan (ulimit pouze omezuje maximalni velikost). Pri startu programu zabira pouze jednu stranku.
    2.2.2013 17:14 Sten
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Jen protože Linux používá overcommit. Když jej vypnete, bude zásobník alokován při spuštění programu celý.
    2.2.2013 18:56 luky
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Doporucuju si ve zdrojovych kodech vyhledat flag neco_GROWSDOWN (nepamatuju si prefix). Pokud dojde k vypadku a pozadovana stranka neni soucasti mapovani, kontroluje se, jestli je _blizko_. Pokud ano, prislusna stranka se domapuje.

    2.2.2013 17:22 Sten
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Velké alokace (> MMAP_THRESHOLD, výchozí hodnota je 128 KiB) malloc nebere z haldy, ale použije anonymní mmap, který hned po free zase vrátí. Lepší alokátory vůbec nepoužívají haldu a veškeré alokace dělají právě přes mmapy, právě protože je lze snadno vracet. Tyhle mmapy jsou taky vidět ve výpisu paměti procesu. Jádro ale samozřejmě ani tady neví, co je uvnitř jednotlivých mmapů, které jsou většinou alokovány po velkých blocích (typicky stovky kilobajtů až megabajty), aby se předešlo přílišné fragmentaci, která velmi zpomaluje nové alokace.
    2.2.2013 18:07 l4m4
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Lepší alokátory vůbec nepoužívají haldu a veškeré alokace dělají právě přes mmapy, právě protože je lze snadno vracet.
    Spíš overengineered než lepší, protože to je optimalizace na situaci, že se podaří současně uvolnit všechny bloky z daného mapování a že aplikace pak nebude zase dlouho potřebovat paměť, kterou by šlo získat recyklováním těchto bloků. Jinak to akorát znamená větší množství syscallů a menší možnost konsolidace volných segmentů. Mluvím o použití haldy typickým způsobem, tj. množství menších až středních alokací ‚náhodných‘ velikosti se slabě korelovanými dobami života.
    31.1.2013 13:43 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Pokud nemáte zdrojáky tak jen dynamickou analýzou valgrind, pokud máte zdrojáky můžete použít i statickou analýzu třeba tímto.
    OS to neví, ví jen o nadřazeném celku, který je uvolněn chcípne-li aplikace.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    31.1.2013 14:16 Semo | skóre: 44 | blog: Semo
    Rozbalit Rozbalit vše Re: Jak najít uniklou paměť (leaky)
    Cca pred 9-10 rokmi bol kratky serial o valgrinde na root.cz. Povedal by som, ze aspon 90% z neho je stale aplikovatelne.
    If you hold a Unix shell up to your ear, you can you hear the C.

    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.