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 12:33 | Zajímavý projekt

    Kevin Lin zkouší využívat chytré brýle Mentra při hraní na piano. Vytváří aplikaci AugmentedChords, pomocí které si do brýlí posílá notový zápis (YouTube). Uvnitř brýlí běží AugmentOS (GitHub), tj. open source operační systém pro chytré brýle.

    Ladislav Hagara | Komentářů: 0
    dnes 12:11 | Pozvánky

    Jarní konference EurOpen.cz 2025 proběhne 26. až 28. května v Brandýse nad Labem. Věnována je programovacím jazykům, vývoji softwaru a programovacím technikám.

    Ladislav Hagara | Komentářů: 0
    včera 21:44 | Komunita

    Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.

    Ladislav Hagara | Komentářů: 0
    včera 14:22 | IT novinky

    Před 25 lety zaplavil celý svět virus ILOVEYOU. Virus se šířil e-mailem, jenž nesl přílohu s názvem I Love You. Příjemci, zvědavému, kdo se do něj zamiloval, pak program spuštěný otevřením přílohy načetl z adresáře e-mailové adresy a na ně pak „milostný vzkaz“ poslal dál. Škody vznikaly jak zahlcením e-mailových serverů, tak i druhou činností viru, kterou bylo přemazání souborů uložených v napadeném počítači.

    Ladislav Hagara | Komentářů: 25
    3.5. 22:33 | Nová verze

    Byla vydána nová major verze 5.0.0 svobodného multiplatformního nástroje BleachBit (GitHub, Wikipedie) určeného především k efektivnímu čištění disku od nepotřebných souborů.

    Ladislav Hagara | Komentářů: 2
    2.5. 22:22 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za duben (YouTube).

    Ladislav Hagara | Komentářů: 0
    2.5. 19:11 | IT novinky

    Provozovatel čínské sociální sítě TikTok dostal v Evropské unii pokutu 530 milionů eur (13,2 miliardy Kč) za nedostatky při ochraně osobních údajů. Ve svém oznámení to dnes uvedla irská Komise pro ochranu údajů (DPC), která jedná jménem EU. Zároveň TikToku nařídila, že pokud správu dat neuvede do šesti měsíců do souladu s požadavky, musí přestat posílat data o unijních uživatelích do Číny. TikTok uvedl, že se proti rozhodnutí odvolá.

    Ladislav Hagara | Komentářů: 5
    2.5. 11:22 | Zajímavý projekt

    Společnost JetBrains uvolnila Mellum, tj. svůj velký jazykový model (LLM) pro vývojáře, jako open source. Mellum podporuje programovací jazyky Java, Kotlin, Python, Go, PHP, C, C++, C#, JavaScript, TypeScript, CSS, HTML, Rust a Ruby.

    Ladislav Hagara | Komentářů: 2
    2.5. 09:11 | Bezpečnostní upozornění

    Vývojáři Kali Linuxu upozorňují na nový klíč pro podepisování balíčků. K původnímu klíči ztratili přístup.

    Ladislav Hagara | Komentářů: 2
    1.5. 20:00 | Komunita

    V březnu loňského roku přestal být Redis svobodný. Společnost Redis Labs jej přelicencovala z licence BSD na nesvobodné licence Redis Source Available License (RSALv2) a Server Side Public License (SSPLv1). Hned o pár dní později vznikly svobodné forky Redisu s názvy Valkey a Redict. Dnes bylo oznámeno, že Redis je opět svobodný. S nejnovější verzí 8 je k dispozici také pod licencí AGPLv3.

    Ladislav Hagara | Komentářů: 3
    Jaký filesystém primárně používáte?
     (58%)
     (1%)
     (8%)
     (21%)
     (4%)
     (2%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 524 hlasů
     Komentářů: 22, poslední dnes 10:06
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Vložit další komentář
    Gilhad avatar 3.3.2014 06:04 Gilhad | skóre: 20 | blog: gilhadoviny
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    důvod, proč je potřeba definovat nové volání, je jednoduchý: renameat2() postrádá způsob, jak by jádro mohlo podporovat (a uživatel mohl požadovat) změny v jeho chování. Jinými slovy, schází mu argument typu flags,

    Nema jit o renameat() ?
    3.3.2014 07:21 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Proč "podezírám Davema", ale "opravám od PeterZ"?
    3.3.2014 10:36 nikdo
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Dokázal by někdo vysvětlit, proč není na otázku „Máme nějaký důvod nepřidat argument flags?“ odpověď vždy ne? Neboli proč se návrhový vzor argumentu flags nepoužívá mechanicky u všech nových systémových volání? Je to jen porušení konceptu "minimalismu" nebo je za tím něco víc? Nevedla se o tom někde diskuze? Co na to říká Linus?
    3.3.2014 11:16 random
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Znepřehledňuje to kód. Pokud chceš příklad, podívej se na ioctl(). Funkce by měla mít jen jeden účel, přesně definovaný a verifikovatelný. Přidáním flags vlastně dochází k multiplexování více různých funkcí pod jeden název.
    3.3.2014 13:06 nikdo
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    To se mi ale zdá spíš jako námitka proti konkrétnímu použití flags než obecně proti jejich plošnému 'preventivnímu' použití.

    Asi je rozdíl, jestli flags použiji např pro parametrizaci funkce uvař_kafe(S_MLEKEM|BEZ_CUKRU) kde je to očividně lepší, než mít 4 varianty uvař_kafe_scukrem_smlekem(), uvař_kafe_scukrem_bezmleka() apod., nebo ve funkci uvař(KAFE|PIVO|MOTOR), kde ta funkce pak dělá očividně různé věci.

    Ví někdo ještě o nějakém dalším důvodu, proč se to nepoužívá automaticky u všecho nových systémových vlání?

    ----

    Mimo téma: v ioctl(int d, int request, ...) žádné flags nejsou, ale pochopil jsem smysl námitky.
    5.3.2014 00:52 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Protože můžete mít také funkci (záměrně jsem obrátil definice v opačné, pořadí než by byly ve zdrojáku):

    uvař_kafe(struct coffee_t *);

    struct coffee_t { int with_milk; int with_sugar; enum coffee_kind_t coffee_kind; int max_temperature; int coffeine_content; ... };

    A v tomto případě je flags zcela zbytečným řešením a i méně přehledným a méně flexibilním.

    Hint: Syscall volání jsou plné různých struktur.

    Miloslav Ponkrác
    Stanislav Brabec avatar 5.3.2014 18:12 Stanislav Brabec | skóre: 45 | Praha
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    A vidíte, zrovna toto je špatný návrh.

    Až budete chtít přidat do struct coffee_t další položku, změní se velikost struktury. A programy zkompilované před změnou velikosti náhle budou vařit kafe s mlékem a citronem, protože se kvůli citronu podívají na pseudonáhodné hodnoty přesahující původní velikost pole. Anebo, pokud budou zkompilovány s runtime kontrolou velikosti struktur a polí, tak rovnou spadnou.

    Lepší návrh by bylo pole značka+hodnota předem neznámé velikosti, ukončené nulovým záznamem.

    uvař_kafe(NULL) by uvařilo nějaké obyčejné standardní kafe, a přidáním položek do pole by se daly upravovat hodnoty.

    No a časem by se ukázalo, že je problém implementovat přípravu kakaa. A tak by buď vznikl tag KAFE_BEZ_KAFE, nebo nové volání uvař_kakao()

    Zrovna nedávno jsem na podobný problém v kernelu narazil: V poli pro hardwarové hodiny chybí položka pro časovou zónu, kterou mají nové BIOSy. A bude asi nutné vytvořit novou strukturu, a nová volání, protože tomu starému to není jako předat, nepočítáme-li odporné obezličky.
    6.3.2014 10:15 nikdo
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    No vida, to je další obecný problém - změna velikosti datové struktury. Na to se nějakým rozumným způsobem dopředu připravit dá? (Aniž by to přinášelo problémy jako v návrhu JS1?) Občas vídávám v některých protokolech "reserved for future use". To ale asi nebude zrovna přístup, který by se v jádře používal. Nebo se mýlím?
    5.3.2014 04:54 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Kromě toho Vás nenapadá jednoduchá varianta?

    uvař_kafe(int with_milk, int with_sugar);

    5.3.2014 09:20 nikdo
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Samozřejmě že napadá. A je taky zřejmé, že z hlediska dalšího možného vývoje je to varianta vedoucí do nesnází.

    Protože za měsíc od zavedení funkce uvař_kafe si někdo vzpomene, že by chtěl třeba uvařit lungo nebo americano a najednou bude muset buď volání změnit na uvař_kafe(int with_milk, int with_sugar, int more_water); nebo zavést funkci uvař_kafe2 nebo uvař_kafe3 či dělat různé obskurnosti jako nacpat argument množství vody do horních bitů with_milk;

    Proto se pídím po tom, proč právě pří vývoji jádra, kde jde o maximální udržitelnost po dlouhý čas bez rozbití stávajícího API se nějaký návrhový vzor při přidávání nové funkcionality neustálil jako standard. Ze čtení jaderných novin mám dojem, že problém "jak něco opravit / upravit / změnit a nerozbít stávající API" je poměrně častý.
    5.3.2014 18:28 JS1 | skóre: 2 | blog: intuition_pump
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Nepovazuji se za odbornika v C ani v jadre, ale asi bych to delal tak, ze pridam extra int argument pro flagy a extra pointer argument na strukturu, ktera bude verzovana (prvni bajt/short bude cislo verze). A tak struktura se bude pouzivat pro predavani slozitejsich a mene castych parametru, normalne muze zustal NULL.
    Lidstvo čelí v tomto století hrozbě civilizačního kolapsu. Podpořte hnutí klimatickakoalice.cz!
    Stanislav Brabec avatar 5.3.2014 19:09 Stanislav Brabec | skóre: 45 | Praha
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Ne, že by to nefungovalo, ale komplikovalo by to kód v jádře, který by se vždy musel větvit podle toho, jaká verze parametrů byla použita.

    Navíc, napsat funkci, která si od takové struktury udělá privátní kopii, bude docela netriviální, ba dokonce nemožné bez aktuální verze příslušné knihovny v uživatelském prostoru.

    Oproti tomu nový syscall přidává pouze wrapper pro staré volání. Nové volání je již bez zbytečné režie.
    pavlix avatar 5.3.2014 22:13 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    na strukturu, ktera bude verzovana
    To už mi přijde daleko jednodušší současný systém, který verzuje celé volání. Případně se to dá do budoucna schovat za nějakou abstrakci v libc, kde nejsou takové extrémní nároky na kompatibilitu, nebo se to zabalí do abstrakce o krok dál.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    6.3.2014 11:04 JS1 | skóre: 2 | blog: intuition_pump
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Asi mas pravdu, ale vychazel jsem z toho, ze verzovat cele volani lidem vadilo.. Aspon je videt, ze to je asi skutecne lepsi.

    Jinak si myslim, ze pro obskurni argumenty by se to i tak vyplatilo.
    Lidstvo čelí v tomto století hrozbě civilizačního kolapsu. Podpořte hnutí klimatickakoalice.cz!
    6.3.2014 06:27 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Pán je milovník netlinku :)
    pavlix avatar 6.3.2014 10:14 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Tak je fakt, že na komplikovanější věci dává nějaký takový protokol smysl.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    6.3.2014 15:10 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Koneckonců netlink vznikl právě proto, že další rozšiřování rozhraní ioctl() bylo příliš šílené a ne dost flexibilní.
    Petr Tomášek avatar 3.3.2014 15:24 Petr Tomášek | skóre: 39 | blog: Vejšplechty
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Spíše je otázkou, proč linux nemá systémová volání s proměnlivým počtem parametrů...
    multicult.fm | monokultura je zlo | welcome refugees!
    3.3.2014 17:35 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Protože je to prasečina.

    Chcete-li variabilní volání na úrovni systému, je lepší předat pointer na nějakou strukturu, kde si můžete řádit jak chcete, případně mít nějaký systémem udržovaný deskriptor, do kterého nacpete co chcete, než mít proměnný počet parametrů.

    Navíc vše musí být dostatečně přenositelné. Proto se třeba v systémových voláních vyhýbáme předávání parametrů typu floating point number, nebo boolean.

    Proměnný počet parametrů lze implementovat různými způsoby a různé jazyky to také dělají. Byl by v tom další problém.
    3.3.2014 17:29 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Protože jednou ustanovené API se velmi těžko mění.

    Ve světle dnešní rychlé doby, ba přímo módy, kdy třeba Python, Perl, Ruby a další překopávají rozhraní to mnoho lidfí těžko chápe.

    Představte si to tak, kdyby každou změnou API kernelu přestalo fungovat polovina programů. Protože se API změnilo. Nebo byste musel přepsat z každou verzí bashe skripty, protože by se nekompatibilně změnila sybtaxe shell skriptů.

    To se nesmí stát, a proto na prvním místě je stabilita a neměnnost API. Je nutné zajistit, aby jendou ustanovené volání API zůstalo na věky věků stejné. Jinak přestanou fungovat programuy, knihovny, začne se to hroutit.

    Z toho důvodu se při vymýšlení systémových volání myslí v první řadě na budoucnost, a na stabilitu a neměnnost tohoto volání v budoucnosti. Protože pokud to neodhadnete, musíte přidat později funkce2, pokud ani tak, pak funkce3 – a to vše se musí v budoucnu třeba desítky let udržovat včetně zastaralých neodhadnutých funkcí. Což má zvýšený nárok na údržbu, programátory, atd. atd. atd.

    V dlouhodobých projektech se v první řadě myslí na úzdržbu takového API.

    Rozhodně je lepší přidat flags, které se v určitých případech nepoužije, než ho nepřidat a namísto X systémových volání míst dvojnásobek a celé to udržovat.

    Mechanicky se ale flags vždy nepřidává, protože někteří lidé vyvíjející Linux nemyslí dostatečně dopředu (programují jen lidé), a nebo proto, že v některých voláních si absolutně nikdo nedokáže představit, že by to kdy mělo jakýkoli význam přidat flags.

    Odhadování budoucnosti různých volání API se zkrátka vždy nepovede. Chce to značné zkušenosti a i tak někdy vývoj překvapí.

    Miloslav Ponkrác
    4.3.2014 19:06 nikdo
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Děkuji za Váš odstavec č.8, který se vyjadřuje k mé otázce (byť se mi zdá, že pouze fabulujete, chybí mi nějaký příklad či jiná fakta).

    Zbývajících 8 odstavců je sice pěkné slohové cvičení, nicméně je poněkud mimo téma.

    Neměl by náhodou někdo jiný více informací o tématu "návrhový vzor" flags v jádru linuxu"?
    5.3.2014 00:29 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Určitě měl. Jmenuje se Google.

    Jenom si člověk nesmí hrát na pašu.
    5.3.2014 09:10 nikdo
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Kdybych odpověď našel pomocí gůglu, jistě bych se na ni neptal zde. Hledal jsem, nenašel. Ostatně je to ten typ dotazů, na něž gůgl odpověď dává málokdy.

    Tak ať si na něj ten člověk nehraje.
    Stanislav Brabec avatar 5.3.2014 17:49 Stanislav Brabec | skóre: 45 | Praha
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Ostatně zmíněná 31bitová architektura S390 je také příkladem udržování API. Existuje zde kvůli 40–60 let starým programům – 32. bit se používá jako flag. Hodnota 1 identifikuje platnost horních bitů adresy. Hodnota 0 signalizuje program pro S360 nebo S370, kde se horních 8 bitů adresy ignorovalo (tedy program pro hardware z let 1964 až 1983).

    A aby kompatibilita byla dokonalá, S390 bootuje z děrné pásky (pravda, virtuální).
    6.3.2014 14:30 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Dodal bych, že i když je v plánu odstranit architekturu S/390 (ve 3.16), nadále zůstane v jádře podpora pro spouštění 31-bitových aplikací na S/390-64 (podobně jako lze spouštět 32-bitové x86 aplikace na x86_64 nebo IA-64), takže ty programy ze šedesátých let v dohledné době fungovat nepřestanou, jen tam místo jedné vrstvy pro zpětnou kompatibilitu budou dvě.
    4.3.2014 20:12 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Bývaly doby, kdy jste měl v procesoru jen 4 registry k obecnému použití. Protože v Linuxu se používá jediné přerušení, tak pro argumenty systémového volání zbývají jen 3. Takže přidávat bezhlavě argument pro příznaky nebylo možné.
    5.3.2014 00:41 Miloslav Ponkrác
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Což není principiálně problém, protože další argumenty lze ukládat na stack – viz sys_ipc.

    Ostatně neexistují jenom x86 procesory, měl jsem dojem, že linux kernel chodí i na jiných procesorech. Na každém musíte vymyslet nějaké volací schéma systémových volání.

    5.3.2014 07:30 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:
    Principiální problém to není, ale je to pomalejší. Psal jsem bývaly doby. Linux začínal na x86.
    5.3.2014 08:52 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014:

    Abychom to nepřeháněli, začínalo se na 80386, sice se později objevily i pokusy portovat Linux i na starší verze, ale to byly spíš takové experimenty a IIRC to k ničemu kloudnému nevedlo.

    C sice podporuje funkce s proměnným počtem parametrů, ale kdo s tím někdy pracoval, dospěl nejspíš k závěru, že lze-li se tomu vyhnout, je rozhodně lepší tak učinit. Aspoň já ano.

    A předávat všechno přes pointer na strukturu? Jde-li o komplikovanější data, jako třeba u sigaction(), pak jistě. Ale představa, že bych místo

      L = read(fd, buf, len);
    

    měl pokaždé psát

      struct read_params par;
      ...
      par.fd = fd;
      par.buf = buf;
      par.count = len;
      L = read(&par);
    

    (s tím, že nemám-li C99, musí být první řádek na začátku bloku) mi rozhodně nepřipadá jako krok správným směrem. A i pro debugování je lepší, když u jednodušších syscallů (a těch je většina) najdu parametry v registrech a nemusím je dohledávat na zásobníku nebo dokonce v paměti, kterou nemusím ani mít k dispozici.

    Jinak řečeno, je vždycky nepříjemné, když se ukáže, že člověk nebyl dostatečně prozíravý. Ale být prozíravý až příliš také není ideální.

    10.3.2014 19:39 Pev | skóre: 28
    Rozbalit Rozbalit vše Re: Jaderné noviny – 13. 2. 2014
    počet argumentů v zásvislosti => závislosti.

    Díky za hezký překlad :-).

    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.