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 00:11 | Nová verze

    UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.3. Současně oznámila, že nadcházející větší vydání 24.04-2.0 bude mít modernější webový prohlížeč.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | Zajímavý projekt

    Ploopy po DIY trackballech či sluchátkách představuje nový externí DIY trackpoint se čtyřmi tlačítky Bean. Obsahuje snímač Texas Instruments TMAG5273, spínače Omron D2LS-21 a řadič RP2040, používá firmware QMK. Schémata jsou na GitHubu; sadu lze předobjednat za 69 kanadských dolarů (bez dopravy a DPH).

    |🇵🇸 | Komentářů: 0
    včera 03:33 | Zajímavý článek

    Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    7.5. 22:55 | Bezpečnostní upozornění

    Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].

    Ladislav Hagara | Komentářů: 6
    7.5. 14:00 | Humor

    Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.

    Ladislav Hagara | Komentářů: 10
    7.5. 05:11 | Nová verze

    Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.

    Ladislav Hagara | Komentářů: 0
    7.5. 05:00 | Nová verze

    Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    6.5. 16:44 | Komunita

    Richard Hughes oznámil, že po společnostech Red Hat a Framework a organizacích OSFF a Linux Foundation, službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzorují také společnosti Dell a Lenovo. Do dnešního dne bylo díky LVFS provedeno více než 145 milionů aktualizací firmwarů od více než 100 různých výrobců na milionech linuxových zařízení.

    Ladislav Hagara | Komentářů: 0
    6.5. 15:22 | IT novinky

    Americké technologické společnosti Microsoft, Google a xAI souhlasily, že vládě Spojených států poskytnou přístup k novým modelům umělé inteligence (AI) před jejich uvedením na trh. Oznámila to americká vláda, která tak bude moci prověřit, zda modely nepředstavují hrozbu pro národní bezpečnost. Oznámení podtrhuje rostoucí obavy Washingtonu z rizik spojených s výkonnými AI systémy. Americké úřady chtějí v rámci předběžného přístupu

    … více »
    Ladislav Hagara | Komentářů: 1
    6.5. 14:11 | IT novinky

    Společnost Valve zveřejnila (GitLab) nákresy ovladače Steam Controller a puku. Pro všechny, kdo by jej chtěli hacknout nebo modifikovat, případně pro ně navrhnout nějaké příslušenství. Pod licencí Creative Commons (CC BY-NC-SA 4.0).

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (9%)
     (2%)
     (14%)
     (32%)
     (4%)
     (7%)
     (3%)
     (16%)
     (24%)
    Celkem 1534 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Pomoc s malloc

    6.1.2009 14:49 Cunha
    Pomoc s malloc
    Přečteno: 842×

    Zdravím,

    mohl by mi prosím někdo říct, kde mám chybu ve svém kódu? Čas od času to vyhodí segmentation fault a nejsem schopný říct proč. Po otestování mám pocit, že to dělá přímo ten malloc, ale proč?

    Díky

    int hash_control(char * filename) {
        char *comd, *hash_file_name;
        char * md5 = "md5sum --status -c ";
        char * ext = ".hash";
        int ret = 0;
        if (_PAXOS_DEBUG) printf("Hash control started\n");
        hash_file_name = (char *) malloc((strlen(filename) + strlen(ext) + 1) * sizeof (char));
        bzero(hash_file_name, (strlen(filename) + strlen(ext) + 1) * sizeof (char));
        if (!hash_file_name) {
            perror("Opening log hash file");
            goto err;
        }
        sprintf(hash_file_name, "%s%s", filename, ext);
        comd = (char *) malloc((strlen(md5) + strlen(hash_file_name) + 1) * sizeof (char));
        bzero(comd, (strlen(md5) + strlen(hash_file_name) + 1) * sizeof (char));
        if (!comd) {
            ret = -1;
            goto err;
        }

        sprintf(comd, "%s%s", md5, hash_file_name);

        ret = system(comd);
        if (ret != 0) {
            goto err;
        }

    err:
        if (hash_file_name != NULL) free(hash_file_name);
        if (comd != NULL) free(comd);
        if (ret != 0) perror("Load and hash");

        return ret;
    }

     

    Odpovědi

    6.1.2009 15:10 Vinicius
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    Určitě to bude kanón na vrabce ,ale pomohl by program valgrind, který mimo jiné umí zkontrolovat leaky a sahání na neinicializované proměnné.

    6.1.2009 15:30 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    Vůbec nekontrolujete, jestli se podařil malloc(). Dál bych doporučil vyhodit bzero(), protože tam nemá vůbec žádný smysl (kromě toho by se místo něj mělo používat memset(3)). A nakonec chyba vůbec nemusí být ve vaší funkci. Klidně argument filename muže být ten viník.
    6.1.2009 21:57 Zadavam sve jmeno
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    1) Pokud nektery malloc selze, fce bzero se vola na nulovy pointer.

    2) V pripade, ze bzero bude odstraneno, tak muze nastat druhy problem - promenne comd a hash_file_name nejsou nastaveny na hodnotu NULL. Pokud selze prvni malloc, vola se free i na promennou comd, ktera ma v te chvili nedefinovanou hodnotu ==> nepredvidatelne chovani, koncici SIGSEGV.

    Je ovsem take mozne, ze jsem se spatne podival :-)

    Jardík avatar 6.1.2009 23:22 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    Už tohle:

    char * md5 = "md5sum --status -c ";
    char * ext = ".hash";
    

    je špatně, správně to má být const char*, ale to je pouze jen taková prasárna a není to pravděpodobně zdroj vašeho problému.

    Jak již někdo řekl, problémem může být malloc a bzero, doporučiji comd inicializovat na 0, to může být další problém.

    sprintf ke spojení dvou řetězců je fuj. Použij fce na koupírování paměti a hlavně nezapomeň na ukončovací nulu. Samé strlen zdržuje, zavolej to radši jednou a někam ten výsledek ulož a pak použij.

    goto ... no dobře, je to C, tak to ještě chápu.

    Věřím v jednoho Boha.
    6.1.2009 23:39 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    goto je v Céčku pro ošetřování chyb úplně normální postup, co bys chtěl od přenositelného assembleru? :-)
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    7.1.2009 03:46 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    1) Nebylo by lepsi misto kombinace malloc() a bzero() pouzit calloc() ?

    2) Ten kod neni vubec efektivne napsany, ale o to v tomto pripade asi vubec nejde:)

    3) Pokud na konci testujete 'comd' a 'hash_file_name', bylo by dobre je nastavit hned v deklaraci na NULL v pripade, ze by malloc() opravdu selhal, protoze pokud se tak stane, muzete zavolat free() s neplatnym ukazatelem.
    7.1.2009 09:00 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    4) "kontrola hashe" se anglicky nerekne "hash control"
    In Ada the typical infinite loop would normally be terminated by detonation.
    7.1.2009 11:39 Jirka
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    Tipuji, že to nedělá malloc, ale free. Zkuste vyhodit free a uvidíte.

    Co používáte za kompilátor a OS?

    Co hlášky z debuggeru gdb apod?

    7.1.2009 15:33 Cunha
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    Upravil jsem kód podle komentářů výše. Zkusil jsem valgrind a ten mi pise, ze chyba vznikla na prvním 'malloc'. Zkoušel jsem na Ubuntu 8.10, Lenny a Fedora 9 přes 'gcc'. Vstupní argument je v daném bodě "const char", tak opravdu nevím, co se děje.

    7.1.2009 15:52 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    Vstupní argument je v daném bodě "const char"

    O typ nejde. Jde o to, aby vstupní argument vaší funkce nebyl NULL, a aby paměť, kam ukazuje byla skutečně naalokovaná a to až do místa (včetně), kde se nachází ukončující '\0'.

    Uvěďte sem upravený kód a hodnotu argumentu, na které to padá.

    7.1.2009 19:41 Cunha
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    Funkce:

    int hash_control(char * filename) {
        char *comd = NULL, *hash_file_name = NULL;
        const char * md5 = "md5sum -c ";
        const char * ext = ".hash";
        int ret = 0, size = 0;

        size = (strlen(filename) + strlen(ext) + 2) * sizeof (char);
        hash_file_name = (char *) malloc(size);
        if (!hash_file_name) {
            perror("Opening log hash file");
            goto err;
        }
        memset(hash_file_name, 0, size);
        sprintf(hash_file_name, "%s%s", filename, ext);
        size = (strlen(md5) + strlen(hash_file_name) + 2) * sizeof (char);
        comd = (char *) malloc(size);
        if (!comd) {
            ret = -1;
            goto err;
        }
        memset(comd, 0, size);

        sprintf(comd, "%s%s", md5, hash_file_name);

        ret = system(comd);
        if (ret != 0) {
            goto err;
        }

    err:
        if (hash_file_name != NULL) free(hash_file_name);
        if (comd != NULL) free(comd);
        if (ret != 0) perror("Load and hash");

        return ret;
    }

     

    Tady se to volá:

    #define PAXOS_LOG_FILE "file.log"

    ....

    filename = PAXOS_LOG_FILE;

    ...

    hash_ret = hash_control(filename);

    ....

     

    Je možné, aby to bylo způsobené nedostatkem paměti?

    7.1.2009 20:31 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    Tak, jak to je, by to mělo fungovat.

    Sice by bylo dobré na začátku hash_control() testovat, zda-li filename != NULL, a chybová hlášení by šlo vylepšit (volat po druhé perror() je nespolehlivé) a taky při počítání délky by stačilo +1 místo +2 a vyhodit zbytečné memset()y by šlo, ale v principu by to nemělo nikde padat.

    Jedině, že byste používal vlákna a třeba mezi malloc() a sprintf() by vám někdo přepsal filename.

    Pak taky, kdybyste měl špatnou libc, tak by to mohlo padnout někdě uvnitř perror() nebo sprinf(), ale tyhle funkce by se ve vašem případě měly obejít bez dalšího alokování.

    A ještě by se mohlo stát, že vám došel zásobník. Na to standardně taky dostanete SIGSEGV.

    7.1.2009 21:18 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    Podle mě je to způsobené na jiném místě v programu. Pokud programujete tak, jak jste ukázal váš první zdroják, tak bych se tomu moc nedivil. Ono stačí někde blbě přepsat místo v paměti a pak vám může udělat chybu i malloc(), nebo free() nebo klidně i ten perror().

    Doporučuju nástroj valgrind, ten vám může pomoct odhalit místa v programu, kde přistupujete k neinicializované paměti. Můžete si zkusit program i krokovat a dívat se, jak se mění hodnoty vašich proměnných, jestli někde náhodou nepřepisujete třeba zásobník, atd :)

    Pokud máte Windows a Visual Studio, tak můžete zkusit program zkompilovat i tam, můžete si zapnout automatickou kontrolu stavu zásobníku a třeba i tato blbost vám pomůže.

    Osobně bych se vás nechtěl nějak dotknout, ale vážně by mě zajímalo, jestli si dovedete představit, co provádí funkce sprintf() a memset(). Píšu to, protože ty memsety jsou úplně zbytečné.

    Pokud bych šel ještě dál, tak si můžete napsat nějakou funkci na to alokování místa v paměti pro 2 řetězce a jejich zkopírování.
    char* combine_str(const char* a, const char* b)
    {
      size_t alen = strlen(a);
      size_t blen = strlen(b);
      size_t rlen = alen + blen;
    
      char* result = malloc(rlen + 1);
      if (!result) return NULL;
    
      memcpy(result, a, alen);
      memcpy(result + alen, b, blen);
      result[rlen] = '\0';
    
      return result;
    }
    
    Přeju hodně štěstí v hledání té mouchy ;-)
    7.1.2009 22:15 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    Můžete si zkusit program i krokovat a dívat se, jak se mění hodnoty vašich proměnných, jestli někde náhodou nepřepisujete třeba zásobník, atd :)
    Tenhle přístup má jednu vadu. Chyba se obvykle neprojeví :-)
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    7.1.2009 22:53 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    Jsem to špatně napsal, každopádně krokováním nic nezkazí ;-)
    Bluebear avatar 7.1.2009 23:35 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    Pokud je to na Linuxu a není třeba uvažovat o přenositelnosti, tak lze výhodně použít GNU rozšíření asprintf() a pak by mělo stačit něco jako (POZOR, NEZKOUŠEL JSEM - je to jen hrubá idea):
    #define _GNU_SOURCE
    #include <string.h>
    
    /* ... */
    
    int hash_control(char * filename) {
        char * comd = NULL;
        int ret;
    
        ret = asprintf(&comd, "md5sum -c %s.hash", filename);
        if (ret <= 0) {
            perror("asprintf()");
            return -1;
        }
    
        ret = system(comd);
        free(comd);
    
        if (ret != 0) {
            perror("Load and hash");
        }
    
        return ret;
    }
    
    To mi připomíná, jak jsem si pořídil květináč, že v něm budu mít květinu. Opravdu tam byla, ale potom být přestala...
    8.1.2009 06:54 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Pomoc s malloc
    Pokud potřebujete vědět, kde a za jakých okolností program spadne, a v debuggeru se to odkrokovat nedá, obvyklý postup je povolit core dump (ulimit -c unlimited), nechat program spadnout a v gdb si otevřít ten core dump (příkaz core-dump). Místo gdb lze použí i pohodlnější nadstavby, např. ddd nebo kdbg.
    9.1.2009 12:48 mity | skóre: 6 | Praha
    Rozbalit Rozbalit vše Re: Pomoc s malloc

    Ja bych zacal ujistenim, ze do te funkce jde rozumny vstup. Co kydz to kiksne uz na strlen(filename)?

     

    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.