abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 13:44 | Upozornění

    ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.

    Ladislav Hagara | Komentářů: 6
    dnes 13:33 | Komunita

    Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.

    Ladislav Hagara | Komentářů: 0
    dnes 13:00 | Nová verze

    Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    včera 23:44 | Nová verze

    Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Zajímavý článek

    50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.

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

    Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.

    TomasVondra | Komentářů: 0
    včera 03:00 | IT novinky

    Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].

    Ladislav Hagara | Komentářů: 6
    včera 02:00 | IT novinky

    Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).

    Ladislav Hagara | Komentářů: 9
    21.4. 19:11 | Komunita

    Thunderbird 128, příští major verze naplánovaná na červenec, přijde s nativní podporou Exchange napsanou v Rustu.

    Ladislav Hagara | Komentářů: 28
    KDE Plasma 6
     (71%)
     (10%)
     (2%)
     (17%)
    Celkem 688 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: pthread_mutex_init ve strukture

    31.7.2014 11:37 pou | skóre: 18
    pthread_mutex_init ve strukture
    Přečteno: 476×
    Dobrý den, píšu si jeden takový malinky program v C.

    V tom programu definuji strukturu:
    struct HANDLER{
        MEMORY * memory;
    };
    
    
    struct MEMORY{
        CMD action;
        pthread_mutex_t mutex;
        char * Buffer;
        int start;
        int stop;
    };
    
    a k ni inicializacni funkci:
    HANDLER * init_handler(){
        HANDLER * handler;
        handler=new HANDLER;
        handler->memory=new MEMORY;
        handler->memory->Buffer=new char [BUFFER_SIZE];
        handler->memory->start=0;
        handler->memory->stop=0;
        pthread_mutex_init(&handler->memory->mutex, NULL);
        handler->memory->action=READY;
        return handler;
    }
    
    Pomocí debugu jsem zjistil, že ukazatel handler->memory->Buffer spravne ukazuje na nejake misto v pameti (konkretne 0x6126D0) ale po inicializaci funkci pthread_mutex_init se změní adresa na kterou ukazatel Buffer ukazuje na 0X00. Nevíte prosím někdo co dělám špatně? Místo pro pthread_mutex_t(32B) ve strukture je ale funkce pthread_mutex_init z nějakého důvodu přepíše i několik B za zvím místem!

    Všem moc díky!

    Řešení dotazu:


    Odpovědi

    31.7.2014 12:09 logik
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Zkompilovals to s valgrindem (nebo něčím podobným)? Pokud ne, tak s tím bych začal...
    31.7.2014 15:02 pou | skóre: 18
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Valgrid je dobra rada, ale v podstatě mi řekl jen to co jsem věděl - definitně ztraceny blok paměti na řadku, kde alokuji pamět pro buffer (new char [BUFF_SIZE).

    31.7.2014 15:55 Sten
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Pokud je to v C, mělo by tam být malloc místo new.

    Neběží to na 64-bitovém systému? Tam by měl pthread_mutext_t mít 40 bajtů, takže problém by byl nejspíš s includy nebo nějakými define.
    31.7.2014 17:08 pou | skóre: 18
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Někde jsem se docetl, že pokud se ve struktuře objevuje např std::string není dobre volat na alokaci struktury malloc, protoze se nezavola prislusny konstruktor->proto volam radeji new - je pravda ze u bufferu muzu volat i malloc ale to je asi jedno.

    Ano systém je 64b. Jak napravit ty špatny includy??
    31.7.2014 17:22 Sten
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    std::string ani konstruktory nejsou v C, jen v C++. V C++ bych nedělal žádné takovéhle struktury, ale pořádné objekty.

    Jakým způsobem to kompilujete?
    31.7.2014 20:13 benn | skóre: 18
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Píšeš, že je to v C, tak zkusit nahradit new za malloc. Zda to dělá podobnou neplechu. U malloc vyloženě musíš určit velikosti. Pak se uvidí
    
    HANDLER * handler;
    handler                 = (HANDLER*) malloc(sizeof(HANDLER));
    handler->memory         = (MEMORY*)  malloc(sizeof(MEMORY));
    handler->memory->Buffer = (char*)    malloc(BUFFER_SIZE);
    
    
    Pak snad prohodit ty definovaný struktury.
    1.8.2014 07:58 DK
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    malloc(BUFFER_SIZE * sizeof(char))
    1.8.2014 08:46 Jakub Galgonek | skóre: 3
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    To není nutné, sizeof(char) je vždy jedna.
    Jardík avatar 3.8.2014 11:27 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Stejně tak přetypovávat jak kokot z void* na cokoliv*.
    Věřím v jednoho Boha.
    1.8.2014 08:13 rastos | skóre: 62 | blog: rastos
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Ten kód v povodnej otázke nie je C, ale C++. C kompilátor by mu nadával na kľúčové slovo "new" na použitie "MEMORY" miesto "struct MEMORY" v definícii štruktúry HANDLER a podobne. S C kompilátorom by sa nedostal k tomu, aby to debugoval a videl kam ukazuje Buffer. Pri kompilovaní s C++ kompilácia prejde, ale ani tam nie je žiaden problém s prepisovaním pamäte.

    Tak, ako to je napísané, je hodnota Buffer po vykonaní pthread_mutex_init() nedotknutá. Zádrhel je niekde inde. Niečo, čo tu v tom kóde nevidíme, tam urobí bordel.
    3.8.2014 22:45 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Zádrhel je niekde inde. Niečo, čo tu v tom kóde nevidíme, tam urobí bordel.

    Souhlasím. Aby bylo možné určit, kde je problém, chtělo by to kompletní zdroják(y) (stačí minimalistický testcase, kde se to projevuje) a informaci, jak se to přesně překládalo a linkovalo (a na jaké architektuře).

    4.8.2014 12:54 pou | skóre: 18
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    kus zdrojáku je v úvodním příšpěvku, jinde už jen volám tuto funkci a pristupuji k té struktuře, problém je (jak jsem psal) v té inicializační funkci, že inicializace mutexu přepíše ukazatel na tu přidělenou pamět.

    A v tomto případě si myslím, že je jedno jestli tu pamět získám pomocí malloc nebo new.

    kompiluji pomocí:

    g++ -c -m64 -pipe -g -Wall -W -I/usr/share/qt4/mkspecs/linux-g++-64 -o test.o ../test.cpp

    jinak sizeof mutexu vraci 32b

    Honza
    4.8.2014 12:58 pou | skóre: 18
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    OMLOUVAM SE!!! jinak sizeof(pthread_mutex_t) vraci 40

    4.8.2014 13:12 Jakub Galgonek | skóre: 3
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    To s tím minimalistickým testcasem je ale dobrá rada. Při jeho vytváření dost možmá tu chybu najdeš sám. A i kdyby ne, tak ti pak více více lidí může pomoci s jejím hledáním.
    4.8.2014 13:30 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    kus zdrojáku je v úvodním příšpěvku, jinde už jen volám tuto funkci a pristupuji k té struktuře, problém je (jak jsem psal) v té inicializační funkci, že inicializace mutexu přepíše ukazatel na tu přidělenou pamět.

    A právě proto je potřeba vidět celý zdroják, protože pravděpodobné vysvětlení je, že na různých místech se pracuje s různým layoutem některé z těch struktur. Kvůli tomu by bylo dobré vidět celý soubor (resp. celé soubory, pokud to není v jednom).

    A v tomto případě si myslím, že je jedno jestli tu pamět získám pomocí malloc nebo new.

    To nepopírám. Problém by byl, kdybyste alokoval jedním a zkusil uvolnit druhým, ale to by se samozřejmě projevovalo jinak.

    kompiluji pomocí:

    g++ -c -m64 -pipe -g -Wall -W -I/usr/share/qt4/mkspecs/linux-g++-64 -o test.o ../test.cpp
    

    Pokud používáte pthreads (což podle toho mutexu používáte), mělo by se všechno kompilovat s -pthread

    4.8.2014 13:48 rastos | skóre: 62 | blog: rastos
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Příloha:
    Test case je v prílohe. A jeho výstupom je:
    allocated       0x82a3048
    before pthread_mutex_init()     0x82a3048
    after pthread_mutex_init()      0x82a3048
    after init_handler()    0x82a3048
    4.8.2014 14:13 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    To ovšem znamená, že ten testcase nedemonstruje ten problém…
    4.8.2014 14:50 rastos | skóre: 62 | blog: rastos
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    To znamená, že problém nie je v tom kóde, ktorý tu vidíme.
    4.8.2014 15:01 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Aha, pardon, nějak jsem automaticky předpokládal, že ten testcase sem dával tazatel. :-)
    4.8.2014 15:26 pou | skóre: 18
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Takže jsem zkusil testcase.cpp a vse funguje, patral jsem kde je tedy problem, nasel - přiznávám, je to moje blbost :-/.

    Problém byl v tom, že program kompiluji i pro ARM, a tak mám nastavené u vývojového prostředí cesty i k tem ARM knihovnám -> ted kdyz muj kod zkompiluji se správnými cestami vse funguje bez problému.

    Sam bych asi na tuto "moji hloupost" nepřišel.

    Děkuji!! Vsem
    1.8.2014 14:18 Radek Isa | skóre: 14
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    pthread_mutex_init(&(handler->memory->mutex), NULL); nevim ktery operator ma prednost &a->b tak to skus napsat &(a->b)
    pavlix avatar 1.8.2014 15:49 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Pokud C/C++ denně nepoužíváš, stačí se podívat na tabulku operátorů dle priority a nemusí se pak ani upravovat kód ani psát takovéto příspěvky.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    3.8.2014 22:39 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    Doplnil bych, že ve většině případů funguje pravidlo, že autoři C se obvykle řídili zdravým rozumem a tím, co je praktičtější, takže je např. na rozdíl od autora Pascalu nenapadlo dát porovnávání nižší prioritu než logickým spojkám, aby se "a < b && b < c" muselo závorkovat. V tomto případě nemá smysl, aby "&a->b" znamenalo "(&a)->b", protože to lze jednoduše zapsat jako "a.b".
    pavlix avatar 3.8.2014 22:47 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: pthread_mutex_init ve strukture
    +1
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.

    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.