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 10:44 | IT novinky

    Revolut nabídne neomezený mobilní tarif za 12,50 eur (312 Kč). Aktuálně startuje ve Velké Británii a Německu.

    Ladislav Hagara | Komentářů: 0
    dnes 09:55 | IT novinky

    Společnost Amazon miliardáře Jeffa Bezose vypustila na oběžnou dráhu první várku družic svého projektu Kuiper, který má z vesmíru poskytovat vysokorychlostní internetové připojení po celém světě a snažit se konkurovat nyní dominantnímu Starlinku nejbohatšího muže planety Elona Muska.

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

    Poslední aktualizací začal model GPT-4o uživatelům příliš podlézat. OpenAI jej tak vrátila k předchozí verzi.

    Ladislav Hagara | Komentářů: 0
    dnes 08:11 | Nová verze

    Google Chrome 136 byl prohlášen za stabilní. Nejnovější stabilní verze 136.0.7103.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 8 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 20:55 | Nová verze

    Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 4.5.0. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.

    Ladislav Hagara | Komentářů: 0
    včera 16:22 | Nová verze

    Byl vydán Mozilla Firefox 138.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 138 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 15:55 | Pozvánky

    Šestnáctý ročník ne-konference jOpenSpace se koná 3. – 5. října 2025 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytvářejí všichni účastníci, se skládá z desetiminutových

    … více »
    Zdenek H. | Komentářů: 2
    včera 15:44 | IT novinky Ladislav Hagara | Komentářů: 2
    včera 13:55 | Komunita

    Richard Stallman přednáší ve středu 7. května od 16:30 na Technické univerzitě v Liberci o vlivu technologií na svobodu. Přednáška je určená jak odborné tak laické veřejnosti.

    Ladislav Hagara | Komentářů: 10
    28.4. 23:33 | Nová verze

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.04.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    Jaký filesystém primárně používáte?
     (58%)
     (1%)
     (9%)
     (21%)
     (4%)
     (1%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 486 hlasů
     Komentářů: 18, poslední 17.4. 12:41
    Rozcestník

    GNU bloatware

    9.3.2006 13:46 | Přečteno: 1322× | Linux | poslední úprava: 9.3.2006 13:48

    Kdysi dávno existovaly toolchainy, která "prostě fungovaly", uměly vše potřebné a nedělaly zbytečné blbosti. Pak nás postihlo GNU, které přineslo zkázu v podobě emacsu a gcc. Ten neuvěřitelný bordel co má gcc v includech je naštěstí viditelný, takže se proti němu občas bojuje, ovšem proti tomu co vyvádí ld jde o slabý odvar. Přeji příjemnou zábavu s čtením map file triviálního executable:

    $ more main.c
    int main () { return 0; }
    $ gcc -Wl,-M main.c 2>map
    $ more map
    

    Sice jsem chtěl napsat pouze "bez komentáře", ale neudržím se. Proč na linkování jednoho object file potřebuje GNU ld načíst a použít 13 obj souborů nebo knihoven? Proč je výsledkem linku (po agregaci linkovacím skriptem!) neskutečných 62 sekcí, z toho 34 obsahujících nějaká data, a 28 které se mapují do paměti? Proč je i taková blbost jako inicializace současně implementována třemi nezávislými způsoby (.preinit_array, .init_array, .ctors)? Opravdu je potřeba jen kvůli uložení čísla verze překladače vyplýtvat 3 sekce (.gnu.version , .gnu.version_d, .gnu.version_r)? Proč je debug info uloženo v 23 různých sekcích? Jsou ty lidi vůbec normální?        

    Hodnocení: 33 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    9.3.2006 16:40 Luboš Luňák | skóre: 19 | blog: Seli
    Rozbalit Rozbalit vše Proc?
    Protoze vetsinou odpoved je "protoze to je jedno"? Protoze spoustu tohohle diktuje ELF a ne GNU?

    > Kdysi dávno existovaly toolchainy, která "prostě fungovaly", uměly vše potřebné a nedělaly zbytečné blbosti.

    No jo, zlaty .COM z DOSu, co chtit vic. A uz ani ta nostalgie neni co byvala.

    > Proč na linkování jednoho object file potřebuje GNU ld načíst a použít 13 obj souborů nebo knihoven?

    Protoze v tom map souboru jsou nektere vypisovane opakovane a tak jich vlastne 13 neni? A i kdyby, vadilo by to vlastne necemu?

    > Proč je výsledkem linku (po agregaci linkovacím skriptem!) neskutečných 62 sekcí, z toho 34 obsahujících nějaká data, a 28 které se mapují do paměti?

    Protoze ELF soubory se do pameti nemapuji po ELF sekcich, ale po ELF segmentech? Protoze mit extra sekci na kazdou vec je lepsi nez to mit vsechno nahazeno v jedne (jen tak hadam)? Protoze podle 'objdump --headers' ta vysledna binarka tech sekci 62 nema (alespon tady ne)?

    > Opravdu je potřeba jen kvůli uložení čísla verze překladače vyplýtvat 3 sekce (.gnu.version , .gnu.version_d, .gnu.version_r)?

    Soude podle http://www.linuxbase.org/spec/refspecs/LSB_1.2.0/gLSB/specialsections.html, nejspis ne, ale ja tomu vlastne nerozumim.

    PS: Ne ze bych je chtel zrovna branit, asi bych u neceho takoveho byl posledni a vlastne nadavat bych na GNU toolchain dokazal pekne dlouho, ale alespon by to moje nadavani nebyl takovyhle hrozny blabol.
    9.3.2006 17:36 zde | skóre: 9 | blog: Linuch | Brno
    Rozbalit Rozbalit vše Re: Proc?
    > Protoze vetsinou odpoved je "protoze to je jedno"?

    sizeof(Elf32_Shdr) je 40 byte + rekneme 10 byte na nazev v string table. 62 sekcí napd = 3kB napd.

    > Protoze spoustu tohohle diktuje ELF a ne GNU?

    Neni pravda, ELF je docela rozumny- blbe udelali akorat hashovani symbolu.

    > No jo, zlaty .COM z DOSu, co chtit vic. A uz ani ta nostalgie neni co byvala.

    ??? Mel jsem na mysli 32-bitove kompilatory od Watcomu, Borlandu, Intelu, nebo Microsoftu. Stary dobry OMF s 32-bit rozsirenimi. Jeden OBJ soubor na zacatek, druhy na konec, mezi to co programator racil plus LIBC a bylo vymalovano. Zadne potrhle linker scripty, zadne miliony segmentu a sekci (prestoze OMF je samozrejme umel).

    > Protoze v tom map souboru jsou nektere vypisovane opakovane a tak jich vlastne 13 neni? A i kdyby, vadilo by to vlastne necemu?

    Dobra, unikatnich je 11. I kdyz odectu CRT1.O, MAIN.O, LIBC.SO a CRTN.O, ktere maji nejaky smysl, a at nezeru tak i LIBGCC.A, porad tam smrdi 6 modulu navic.

    > Protoze ELF soubory se do pameti nemapuji po ELF sekcich, ale po ELF segmentech? Protoze mit extra sekci na kazdou vec je lepsi nez to mit vsechno nahazeno v jedne (jen tak hadam)?

    ELF header se mapuje cely. Mas pravdu, sekci v A.OUI neni 62, ale jen 30. 62 jich definuje linker script, ale nejaka data sla pouze do 30 z nich. I tak je ale 30 neopodstatnene cislo.

    > ale ja tomu vlastne nerozumim.

    Nevadi, ja taky ne.

    > ale alespon by to moje nadavani nebyl takovyhle hrozny blabol.

    Kde si to nadavani muzu precist? Protoze kdyz nebudes nadavat, nikdy se to nezlepsi.
    Táto, ty de byl? V práci, já debil.
    10.3.2006 11:07 zde | skóre: 9 | blog: Linuch | Brno
    Rozbalit Rozbalit vše Re: Proc?
    > Protoze podle 'objdump --headers' ...

    objdump z nejakeho podivneho duvodu nezobrazuje sekce .shstrtab .symtab .strtab a take sekci NULL, prestoze je binarka obsahuje, jak dokazuje readelf --section-headers.
    Táto, ty de byl? V práci, já debil.
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.