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 19:55 | Zajímavý článek

Byly zveřejněny (pdf) podrobnosti o kritické bezpečnostní chybě CVE-2017-12542 v HPE iLO 4 (Integrated Lights-Out), tj. v proprietárním řešení společnosti Hewlett Packard Enterprise pro vzdálenou správu jejich serverů. Bezpečnostní chyba zneužitelná k obejití autentizace a k vzdálenému spuštění libovolného kódu byla opravena již v květnu loňského roku ve verzi 2.53.

Ladislav Hagara | Komentářů: 0
dnes 17:55 | Zajímavý projekt

CSIRT.CZ informuje o CTF (Capture the Flag) platformě ZSIS CTF s úlohami pro procvičování praktických dovedností z oblasti kybernetické bezpečnosti a upozorňuje na soutěž Google Capture the Flag 2018, kde je možné vyhrát zajímavé ceny.

Ladislav Hagara | Komentářů: 0
dnes 17:00 | Komunita

Byly zveřejněny prezentace a videozáznamy přednášek z prvního československého setkání síťových operátorů CSNOG konaného 11. a 12. června v Brně a semináře IPv6 2018 uskutečněného 6. června v Praze.

Ladislav Hagara | Komentářů: 0
dnes 16:11 | Komunita

Svobodný unixový operační systém FreeBSD slaví 25 let. Přesně před pětadvaceti lety, tj. 19. června 1993, byl vybrán název FreeBSD.

Ladislav Hagara | Komentářů: 0
dnes 15:11 | Komunita

Oficiální YouTube kanál Blenderu je již několik dní blokován. Nadace Blender Foundation informuje, že od společnosti Google dostala šestistránkový návrh nové smlouvy (pdf). Zdá se, že podmínkou další spolupráce je zapnutí reklam na kanálu, tj. zpeněžení obsahu.

Ladislav Hagara | Komentářů: 19
dnes 01:55 | Nová verze

Byla vydána verze 1.13 multiplatformního open source textového editoru Brackets (Wikipedie, GitHub). Přehled novinek v oficiálním oznámení a v poznámkách k vydání. Brackets je nově dostupný také jako balíček ve formátu Flatpak z oficiálního repozitáře Flathub.

Ladislav Hagara | Komentářů: 3
včera 18:44 | Komunita

Oficiální YouTube kanál Blenderu je již několik dní blokován. Důvody jsou zatím nejasné. Pravděpodobně chyba YouTube. Dění lze sledovat na Twitteru Tona Roosendaala.

Ladislav Hagara | Komentářů: 18
včera 17:55 | Zajímavý software

Na GitHubu byly pod open source licencí LLVM zveřejněny zdrojové kódy překladače programovacího jazyka C++ Zapcc vycházejícího z Clangu/LLVM. Překlad pomocí Zapccu je díky lepšímu kešování obvykle několikrát rychlejší než překlad pomocí Clangu. V březnu loňského roku byl vydán Zapcc ve verzi 1.0.

Ladislav Hagara | Komentářů: 0
včera 17:22 | Pozvánky

Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.

xkucf03 | Komentářů: 1
15.6. 22:44 | Zajímavý článek

Na blogu projektu NeoPG (GitHub), kryptografického softwaru vycházejícího z GnuPG, byly zveřejněny 4 příspěvky detailně popisující aktuální bezpečnostní problémy v GnuPG a souvisejících softwarových produktech. V prvním příspěvku je ukázáno, že je možné vytvořit zprávu, o které budou Earlybird, Evolution, Mutt nebo Outlook tvrdit, že jí dešifrovali a přitom ale zpráva vůbec zašifrována nebyla. V druhém příspěvku je popsána

… více »
Ladislav Hagara | Komentářů: 7
Jak čtete delší texty z webových stránek?
 (78%)
 (22%)
 (4%)
 (7%)
 (2%)
 (11%)
Celkem 212 hlasů
 Komentářů: 36, poslední včera 21:16
    Rozcestník

    Dotaz: gdb problem pri trasovani

    6.3.2008 00:43 depka
    gdb problem pri trasovani
    Přečteno: 203×
    zdravim, snazim se debugovat tento kus kodu:
        
         38 void FileDictionary::activate()
         39 {
         40         index.clear();
         41         std::ifstream f(INDEX_FILENAME);
         42         if (f.is_open())
         43         {               
         44                 ***string line;
         45                 std::string temp;
         46         gulong pos;
         47         while(std::getline(f, temp, '\t') >> pos)
         48         {
         49             line = temp;
         50             index.insert(std::pair<****ustring, gulong>(line,pos));     
         51                         f.ignore();
         52         }
         53         }
         54         else
         55                 exit(1);
         56         
         57         fdictionary.close();
         58         fdictionary.open(DICTIONARY_FILENAME);
         59         if (!fdictionary.is_open())
         60                 exit(1);
         61 }
    
    
    

    nastavim breakpoint na zacatku funkce, a pokracuju prikazem next, jenze gdb me skoci do hlubin STL(index.clear()) a dalsim nextovanim nakonec vyskoci az na 60 radku(kod pred 60 radkem ani netrasuje)
    jeste prikladam vypis gdb:
    $ gdb program
    GNU gdb 6.6-debian
    Copyright (C) 2006 Free Software Foundation, Inc.
    GDB is free software, covered by the GNU General Public License, and you are
    welcome to change it and/or distribute copies of it under certain conditions.
    Type "show copying" to see the conditions.
    There is absolutely no warranty for GDB.  Type "show warranty" for details.
    This GDB was configured as "i486-linux-gnu"...
    Using host libthread_db library "/lib/tls/i686/cmov/libthread_db.so.1".
    (gdb) break file-dictionary.cpp:40
    Breakpoint 1 at 0x804fdc2: file file-dictionary.cpp, line 40.
    (gdb) run
    Starting program: program 
    [Thread debugging using libthread_db enabled]
    [New Thread -1232501056 (LWP 19194)]
    [Switching to Thread -1232501056 (LWP 19194)]
    
    Breakpoint 1, FileDictionary::activate (this=0x80c2200) at file-dictionary.cpp:41
    41              std::ifstream f(INDEX_FILENAME);
    (gdb) next
    696             _M_impl._M_node_count = 0;
    (gdb) next
    693             _M_leftmost() = _M_end();
    (gdb) next
    695             _M_rightmost() = _M_end();
    (gdb) next
    446           _M_streambuf(0), _M_ctype(0), _M_num_put(0), _M_num_get(0)
    (gdb) next
    574           basic_istream(): _M_gcount(streamsize(0)) { }
    (gdb) next
    446           _M_streambuf(0), _M_ctype(0), _M_num_put(0), _M_num_get(0)
    (gdb) next
    574           basic_istream(): _M_gcount(streamsize(0)) { }
    (gdb) next
    446           _M_streambuf(0), _M_ctype(0), _M_num_put(0), _M_num_get(0)
    (gdb) next
    574           basic_istream(): _M_gcount(streamsize(0)) { }
    (gdb) next
    446           _M_streambuf(0), _M_ctype(0), _M_num_put(0), _M_num_get(0)
    (gdb) next
    574           basic_istream(): _M_gcount(streamsize(0)) { }
    (gdb) next
    443           : __istream_type(), _M_filebuf()
    (gdb) next
    445             this->init(&_M_filebuf);
    (gdb) next
    497             if (!_M_filebuf.open(__s, __mode | ios_base::in))
    (gdb) next
    498               this->setstate(ios_base::failbit);
    (gdb) next
    144           { this->clear(this->rdstate() | __state); }
    (gdb) next
    248           { return _M_file.is_open(); }
    (gdb) next
    42              if (f.is_open())
    (gdb) next
    60                      exit(1);
    (gdb) 
    
    
    

    Odpovědi

    6.3.2008 01:17 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    Možná se jedná o exit na řádku 55 a ne 60. (Nějak se mi nechce věřit že by to gdb nerozeznal, ale já se v tom moc neorientuji a proto nevím, jestli je číslo řádku uloženo v binárce nebo ho gdb nějak odhaduje.) Taky je divný, že ten breakpoint se nastavil prakticky až na řádek 41, ale to je už jiný problém :-)

    Navrhované řešení - rozliš ty dva exity od sebe nějak. A vůbec, jak to že exituješ a přitom ani neřekneš uživateli, proč? :-)
    6.3.2008 08:30 rastos | skóre: 61 | blog: rastos
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    Kompiluješ s optimalizáciou (napr. -O2)? Ak áno, skús ju vypnúť.
    6.3.2008 08:43 dementni.lojzik | skóre: 19 | blog: ze zivota na vsi
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    jj, presne tak, takto se to obvykle chova, kdyz je zapnuta otimalizace
    6.3.2008 09:35 depka
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    a muzete me poradit jak se to dela pri pouzivani autoconfu a automake? uz sem to zkousel nastavenim promenne prostredi CFLAGS="-g -O0" ale pri komopilace jsem stejne videl v seznamu parametru gcc -O2
    6.3.2008 09:42 Ivan
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    ./configure CXXFLAGS='-O0 -fno-inline -ggdb3' LDFLAGS='-Bsymbolic'

    CFLAGS jsou pro Ccko CXXFLAGS jsou pro C++ a CPPFLAGS jsou pro preprocessor
    6.3.2008 09:43 qk_
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    Dulezity je posledni parametr tedy kdyz bude -O2 a za nim -O0 tak se jede pres -O0. Pri autotools je nejlepsi si udelat volbu neco jako --enable-debug, ktery zapne debugovani (typicky -DDEBUG a -O0 -g). A pro c++ zdrojaky zkus misto CFLAGS pouzit CPPFLAGS, zalezi jak je to udelany vevnitr toho scriptu.
    6.3.2008 09:45 qk_
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    jj, nademnou je spravne CXX misto CPP (furt se mi to plete)
    6.3.2008 10:39 depka
    Rozbalit Rozbalit vše Re: gdb problem pri trasovani
    takze vypnout tu optimalizaci pomohlo, vsem dekuji.

    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.