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 13:11 | Pozvánky

    Chcete vědět, co se odehrálo ve světě techniky za poslední měsíc? Nebo si popovídat o tom, co zrovna bastlíte? Pak dorazte na prosincovou Virtuální Bastlírnu s mikrofonem a kamerou, nalijte si něco k pití a ponořte se s strahovskými bastlíři do diskuze u virtuálního piva o technice i všem možném okolo. O čem budou tentokrát strahováci referovat? Téměř každý už si všiml významného zdražení RAM a SSD, jsou zde ale i příjemnější zprávy. Průša uvádí

    … více »
    bkralik | Komentářů: 0
    dnes 12:55 | Bezpečnostní upozornění

    Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) podporuje vyjádření partnerů ze Spojeného království, kteří upozorňují na škodlivé aktivity společností Anxun Information Technology (též „I-S00N“) (pdf) a Beijing Integrity Technology (též „Integrity Tech“) působících v kyberprostoru a sídlících v Čínské lidové republice (ČLR). Tyto společnosti jsou součástí komplexního ekosystému soukromých subjektů v ČLR,

    … více »
    Ladislav Hagara | Komentářů: 2
    dnes 04:55 | IT novinky

    Společnost Pebble představila (YouTube) prsten s tlačítkem a mikrofonem Pebble Index 01 pro rychlé nahrávání hlasových poznámek. Prsten lze předobjednat za 75 dolarů.

    Ladislav Hagara | Komentářů: 3
    dnes 04:22 | IT novinky

    Společnost JetBrains v listopadu 2021 představila nové IDE s názvem Fleet. Tento týden oznámila jeho konec. Od 22. prosince 2025 již nebude možné Fleet stáhnout.

    Ladislav Hagara | Komentářů: 1
    včera 21:22 | Nová verze

    Byl vydán Mozilla Firefox 146.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 146 bude brzy k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 17:00 | IT novinky

    Před rokem převzala Digitální a informační agentura (DIA) vlastnictví a provoz jednotné státní domény gov.cz. Nyní spustila samoobslužný portál, který umožňuje orgánům veřejné moci snadno registrovat nové domény státní správy pod doménu gov.cz nebo spravovat ty stávající. Proces nové registrace, který dříve trval 30 dní, se nyní zkrátil na několik minut.

    Ladislav Hagara | Komentářů: 7
    včera 11:33 | IT novinky

    IBM kupuje za 11 miliard USD (229,1 miliardy Kč) firmu Confluent zabývající se datovou infrastrukturou. Posílí tak svoji nabídku cloudových služeb a využije růstu poptávky po těchto službách, který je poháněný umělou inteligencí.

    Ladislav Hagara | Komentářů: 0
    včera 01:55 | IT novinky

    Nejvyšší správní soud (NSS) podruhé zrušil pokutu za únik zákaznických údajů z e-shopu Mall.cz. Incidentem se musí znovu zabývat Úřad pro ochranu osobních údajů (ÚOOÚ). Samotný únik ještě neznamená, že správce dat porušil svou povinnost zajistit jejich bezpečnost, plyne z rozsudku dočasně zpřístupněného na úřední desce. Úřad musí vždy posoudit, zda byla přijatá opatření přiměřená povaze rizik, stavu techniky a nákladům.

    Ladislav Hagara | Komentářů: 11
    8.12. 18:44 | Komunita

    Organizace Free Software Foundation Europe (FSFE) zrušila svůj účet na 𝕏 (Twitter) s odůvodněním: "To, co mělo být původně místem pro dialog a výměnu informací, se proměnilo v centralizovanou arénu nepřátelství, dezinformací a ziskem motivovaného řízení, což je daleko od ideálů svobody, za nimiž stojíme". FSFE je aktivní na Mastodonu.

    Ladislav Hagara | Komentářů: 33
    8.12. 17:55 | IT novinky

    Paramount nabízí za celý Warner Bros. Discovery 30 USD na akcii, tj. celkově o 18 miliard USD více než nabízí Netflix. V hotovosti.

    Ladislav Hagara | Komentářů: 3
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (48%)
     (19%)
     (17%)
     (22%)
     (15%)
     (24%)
     (16%)
     (18%)
    Celkem 450 hlasů
     Komentářů: 18, poslední 2.12. 18:34
    Rozcestník
    Štítky: není přiřazen žádný štítek


    Vložit další komentář
    14.1.2013 17:33 Sten
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Za zkušenosti má kompilátor vždy pravdu, když varuje, i když tvrdí trochu něco jiného, než co je skutečný problém. Použití return ret ? ret : len; ukazuje na nepříliš promyšlenou strukturu kódu, protože zbytečně porovnávám ret na konci funkce, když už někde dříve muselo být jasné a musel jsem otestovat, že není nulové (a tedy jsem měl funkci ukončit už tam), protože jinak by len bylo inicializováno.
    14.1.2013 18:29 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    To není tak úplně jisté...

    Jednak mám dojem, že dle C89 (s -pedantic) musíš mít deklarace proměnných na začátku scope. Ale nevim, podle jakýho standardu se kompiluje jádro.

    No a jednak si umím představit i takovej kód, kde by to opravdu muselo být rozlišeno až na konci. Asi by to chtělo vidět ten konkrétní kód...
    14.1.2013 20:16 Sten
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Jednak mám dojem, že dle C89 (s -pedantic) musíš mít deklarace proměnných na začátku scope. Ale nevim, podle jakýho standardu se kompiluje jádro.
    To by nevadilo, to varování vyvolá až použití.
    No a jednak si umím představit i takovej kód, kde by to opravdu muselo být rozlišeno až na konci. Asi by to chtělo vidět ten konkrétní kód...
    Já si ho samozřejmě taky umí představit, to ale neznamená, že je strukturálně správně.
    Goheeca avatar 14.1.2013 21:25 Goheeca | skóre: 7
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    static int uhid_hid_get_raw(struct hid_device *hid, unsigned char rnum,
    			    __u8 *buf, size_t count, unsigned char rtype)
    {
    	struct uhid_device *uhid = hid->driver_data;
    	__u8 report_type;
    	struct uhid_event *ev;
    	unsigned long flags;
    	int ret;
    	size_t uninitialized_var(len);
    	struct uhid_feature_answer_req *req;
    
    	if (!uhid->running)
    		return -EIO;
    
    	switch (rtype) {
    	case HID_FEATURE_REPORT:
    		report_type = UHID_FEATURE_REPORT;
    		break;
    	case HID_OUTPUT_REPORT:
    		report_type = UHID_OUTPUT_REPORT;
    		break;
    	case HID_INPUT_REPORT:
    		report_type = UHID_INPUT_REPORT;
    		break;
    	default:
    		return -EINVAL;
    	}
    
    	ret = mutex_lock_interruptible(&uhid->report_lock);
    	if (ret)
    		return ret;
    
    	ev = kzalloc(sizeof(*ev), GFP_KERNEL);
    	if (!ev) {
    		ret = -ENOMEM;
    		goto unlock;
    	}
    
    	spin_lock_irqsave(&uhid->qlock, flags);
    	ev->type = UHID_FEATURE;
    	ev->u.feature.id = atomic_inc_return(&uhid->report_id);
    	ev->u.feature.rnum = rnum;
    	ev->u.feature.rtype = report_type;
    
    	atomic_set(&uhid->report_done, 0);
    	uhid_queue(uhid, ev);
    	spin_unlock_irqrestore(&uhid->qlock, flags);
    
    	ret = wait_event_interruptible_timeout(uhid->report_wait,
    				atomic_read(&uhid->report_done), 5 * HZ);
    
    	/*
    	 * Make sure "uhid->running" is cleared on shutdown before
    	 * "uhid->report_done" is set.
    	 */
    	smp_rmb();
    	if (!ret || !uhid->running) {
    		ret = -EIO;
    	} else if (ret < 0) {
    		ret = -ERESTARTSYS;
    	} else {
    		spin_lock_irqsave(&uhid->qlock, flags);
    		req = &uhid->report_buf.u.feature_answer;
    
    		if (req->err) {
    			ret = -EIO;
    		} else {
    			ret = 0;
    			len = min(count,
    				min_t(size_t, req->size, UHID_DATA_MAX));
    			memcpy(buf, req->data, len);
    		}
    
    		spin_unlock_irqrestore(&uhid->qlock, flags);
    	}
    
    	atomic_set(&uhid->report_done, 1);
    
    unlock:
    	mutex_unlock(&uhid->report_lock);
    	return ret ? ret : len;
    }
    Stačilo by přiřadit len do ret v té else větvi.
    15.1.2013 17:50 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    No to je teda prasečina... Nelíbí se mi na tom, že ret i celá ta funkce je int, kdežto len je size_t.
    Goheeca avatar 16.1.2013 15:09 Goheeca | skóre: 7
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Jo to implicitní přetypování se mi taky nelíbí.
    14.1.2013 17:40 j
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    A nebylo by lepsi opravit ten kompilator?
    14.1.2013 19:00 Ondrej 'SanTiago' Zajicek
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Jestli pod 'opravit' myslis upravit GCC tak, aby nehlasil to varovani tam, kde nemuze k problemu dojit, a hlasil tam, kde muze, tak to principielne neni mozne. At pouzijes sebelepsi algoritmus, tak vzdy jsou pripady, kdy nelze spolehlive ani potvrdit ani vyvratit chybu, a maximalne v takovych pripadech lze zvolit zda hlasit varovani (a riskovat false positive) nebo nehlasit (a riskovat false negative). Pritom ty priklady mohou byt treba prokazatelne korektni. Abych se nepoustel do konstrukci spojenych s vycislitelnosti, tak staci vzit v uvahu pripad, kdy chovani zavisi na nejakem vnejsim faktoru (napr. externi funkci), o niz kompilator nema zadne informace, ale programator ma.
    14.1.2013 19:03 teoretik
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Opravit? U te analyzy inicializaci se v extremnich pripadech muze jednat o ekvivalent problemu zastaveni, tedy o neco algoritmicky neresitelneho. I kdyz mohl by to Honza Hubicka zadat jako semestralku studentum, treba mu to nekdo omylem vyresi... :)
    14.1.2013 19:47 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    poslyste vy dva teoretici nademnou. Principielne resitelny to samozrejme je a s problemem zastaveni to nema nic spolecnyho.

    Ale je pravda ze kvuli volani dalsich funkci nemusi mit kompilator vsechny potrebny informace a shanet je by zbytecne zpomalovalo preklad.
    14.1.2013 21:14 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Principielne resitelny to samozrejme je a s problemem zastaveni to nema nic spolecnyho.

    Důkaz máte? :)

    14.1.2013 22:34 teoretik
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Nejsem sam kdo si to mysli:

    http://gcc.gnu.org/wiki/Better_Uninitialized_Warnings <- "Unfortunately, detecting when the use of an uninitialized variable is equivalent, in the general case, to solving the halting problem."
    Grunt avatar 14.1.2013 22:28 Grunt | skóre: 23 | blog: Expresivní zabručení | Lanžhot
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Co třeba inicializace na nějakou předefinovanou hodnotu nečíselného typu (podobně jako je NaN) kdy při libovolné operaci s touto hodnotou vyhodí procesor debugovací přerušení nebo si udělá zářez na křemík nebo tak něco? Bylo by to o moc blbější?
    Na co 64-bitů když to jde i s jedním? | 80.78.148.5 | Hack (for) free or Die Hard!
    Bluebear avatar 14.1.2013 23:46 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Ale co dělat u integerů? :-)

    Respektive, dalo by se přidat zvláštní flag "je-není inicializován". Bohužel myslím, že tohle tam dát, tak Linus vezme nunčaky a půjde po krvi toho, kdo ten patch do GCC poslal.

    Ukazatele by samozřejmě šlo inicializovat na NULL, a osobně bych byl pro, ale spousta lidí by (právem) začala nadávat, že to je v drtivé většině případů zcela zbytečná instrukce a přístup do paměti.
    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...
    Grunt avatar 15.1.2013 09:21 Grunt | skóre: 23 | blog: Expresivní zabručení | Lanžhot
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Ale co dělat u integerů?
    To by se asi muselo implementovat na procesoru, kdy libovolná aritmetická operace s nějakým specifickým číslem (nebo číslem s flagem) by způsobila vyhození z běžného běhu.
    Ukazatele by samozřejmě šlo inicializovat na NULL, a osobně bych byl pro, ale spousta lidí by (právem) začala nadávat, že to je v drtivé většině případů zcela zbytečná instrukce a přístup do paměti.
    Tak třeba #ifdef DEBUG. Furt lepší kfree(NULL) než kfree(rand()).
    Na co 64-bitů když to jde i s jedním? | 80.78.148.5 | Hack (for) free or Die Hard!
    15.1.2013 08:10 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Pokud někdo potřebuje něco takového, tak nepoužije C, ale Adu. C má mnohem více záludnějších problémů ,jako ke třeba přetečení znaménkového integeru. Ostatně těšte se na GCC 4.8, které jde s optimalizacemi ještě více na dřeň specifikace, kdy například takovéto přiřazení do iterátoru povede k zacyklení programu.
    Grunt avatar 15.1.2013 09:17 Grunt | skóre: 23 | blog: Expresivní zabručení | Lanžhot
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Pokud někdo potřebuje něco takového, tak nepoužije C, ale Adu.
    Takže už jen stačí přepsat jádro z Céčka do Ady…
    jako ke třeba přetečení znaménkového integeru
    V tom problém nevidím. Když přeteče, tak se začne počítat znova od spodní hranice rozsahu, ne?
    Na co 64-bitů když to jde i s jedním? | 80.78.148.5 | Hack (for) free or Die Hard!
    Voty avatar 15.1.2013 12:07 Voty | skóre: 12 | blog: gemini
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    jako ke třeba přetečení znaménkového integeru
    V tom problém nevidím. Když přeteče, tak se začne počítat znova od spodní hranice rozsahu, ne?
    Dle normy je to nedefinovaná operace a tudíž se může stát cokoliv. Například v kódu:

    int a, b;
    
    ...
    
    if(a > 0 && b > 0)
    {
        int c = a + b;
        
        if(c < 0)
        {
            printf("Overflow");
        }
    }
    

    může překladač usoudit, že při sčítání dvou kladných čísel nemůže nastat "legální" situace, kdy výsledek součtu bude záporný a Overflow se nikdy nevypíše.
    Jednu rozbil a tu druhou ztratil.
    Grunt avatar 15.1.2013 12:36 Grunt | skóre: 23 | blog: Expresivní zabručení | Lanžhot
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    1. Furt nevidím problém
    2. Tohle
      if(c < 0)
          {
              printf("Overflow");
          }
      mi moc validní nepřijde. Není k detekci přetečení určen overflow flag v SR?
    Na co 64-bitů když to jde i s jedním? | 80.78.148.5 | Hack (for) free or Die Hard!
    Voty avatar 15.1.2013 15:47 Voty | skóre: 12 | blog: gemini
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Byla to jen ukázka, co se může stát (přišlo mi to lepší než příklad s auty :)

    Každopádně jde o to, že u znaménkových integerů v jazyce C obecně neplatí (nelze se spolehnout) na to, že se začne počítat od spodní hranice rozsahu. A vyrobit podobnou chybu může být poměrně snadné, v příkladu je naznačen jeden možný (a zcela zřejmý) postup.

    Norma C poměrně jasně říká, že pokud dojde k přetečení integeru, může se dále dít prakticky cokoliv a další chování programu je _zcela_ nedefinované. Mimojiné je tak překladači dovoleno jakékoliv testy na zjištění, že došlo k přetečení ignorovat a v rámci optimalizace je úplně vyhodit. Nehledě na to, že svět není jen x86 a některé arch overflow flag ani nemají.
    Jednu rozbil a tu druhou ztratil.
    15.1.2013 22:38 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jaderné noviny – 20. 12. 2012: Umlčování GCC ne vždy přínosné
    Doporučuji nečíst vlákno, proč bash vrací na $((2**63)) divný výstup. Mohl byste mít špatné spaní.

    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.