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í
×
    včera 23:55 | Zajímavý článek

    Uroš Popović v krátkém článku vysvětluje, co jsou emulátor terminálu, TTY a shell a jaké jsou mezi nimi rozdíly. Jde o první díl seriálu na jeho novém webu Linux Field Guide věnovaném nízkoúrovňové práci s linuxovými systémy.

    |🇵🇸 | Komentářů: 0
    16.5. 22:33 | Nová verze

    Byl vydán Debian 13.5, tj. pátá opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.14, tj. čtrnáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    15.5. 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 3
    15.5. 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 1
    14.5. 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 9
    14.5. 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 27
    14.5. 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    14.5. 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    14.5. 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

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

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1646 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Jak napsat aplikaci realtime bez realtime kernelu?

    11.1.2015 21:55 Jiri K. | skóre: 1
    Jak napsat aplikaci realtime bez realtime kernelu?
    Přečteno: 1139×
    Ahoj,

    chápu to správně, že můžu napsat realtime aplikaci, pokud ji nějakým způsobem dostanu do na roveň modulů, tedy že moduly běží realtime? Chci docílit toho, psát podle potřeby realtime aplkiace aniž bych musel použít realtime kernel. Jaká existuje nejjednodušší cesta k tomu to provést?

    Příklad: ovládat třeba realtime gpio na Raspberry Pi - např. udělat si vlastní komunikační protokol mezi dvěmi RPi přes GPIO (ať už softwarově, nebo HW, to je jedno, prostě to musí běžet realtime).

    Díky

    Odpovědi

    11.1.2015 22:31 NN
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Zajimavy clanek ohledne RTC na RPi..
    13.1.2015 00:35 Jiri K. | skóre: 1
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Super díky.
    rADOn avatar 13.1.2015 11:13 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Nechápeš to správně. Specializované realtime kernely existují proto že jinak to udělat nejde. Pokud nemáš moc velké nároky a rychlý HW – což by dnes neměl být problém – tak se dá předpokládat že moc prodlev nebude a přiměřené robustní protokol se s tím nějak vypořádá. Ale není to totéž jako mít jistotu že prodlevy prostě nebudou.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    13.1.2015 12:48 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Nechápeš to správně. Specializované realtime kernely existují proto že jinak to udělat nejde.
    Ale samozrejme ze to jde - v linuxu si vypne pozadovany pocet jader a pusti si na nich real-time aplikaci napsanou primo pro to zelezo bez kernelu. Celkem bezny postup v embedded.
    13.1.2015 17:48 Radovan
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Co považuješ za "rychlý HW"? Americké jaderné elektrárny řídí a minimálně do roku 2025 budou řídit PDP-11, a řekl bych že tam je potřeba být zatraceně realtime :-D

    Stále také shánějí lidi kteří to dokážou programovat v assembleru, práce zajištěná na roky dopředu...
    13.1.2015 20:36 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Realtime neznamená "proklatě rychle". Realtime znamená, že je garantovaná odozva do času T. Či je čas T=10ms alebo 1 minuta, o tom realtime nehovorí.
    13.1.2015 20:50 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Akporát rychlém HW ale je větší pravděpodobnost, že se to stihne... :-)
    -- OldFrog
    13.1.2015 22:58 mimi.vx | skóre: 37 | blog: Mimi.VX | Praha
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?

    tu nejde o pravdepodobnst ze se to stihne ale o zarucnou odpoved do daneho casu ....

    USE="-gnome -kde";turris
    14.1.2015 00:29 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?

    tu nejde o pravdepodobnst ze se to stihne ale o zarucnou odpoved do daneho casu ....

    Já vím - pouze rozvádím co napsal výšed rADOn (že lze na RT rezignovat).
    -- OldFrog
    14.1.2015 10:12 Sid
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Zda sa, ze naozaj to nechapete. bud potrebujete nieco co povacsine funguje do urciteho casu (a nic sa nestane ak nie) alebo potrebujete nieco co urcite funguje v nejakych casovych mantineloch. To co napisal on hore je v kontexte RT (ziadatel asi chape preco chce RT a nie nieco ine) samozrejme blbost. Ked na tom zariadeni bude zavisiet nieco dolezite tak uz vidim ako to skladate stylom tak dame tam silnejsi procak snad sa to stihne vzdy vykonat.
    14.1.2015 16:05 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Vím co je RT.
    -- OldFrog
    14.1.2015 00:03 Filip Jirsák
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Když budete mít mezi brzdovým pedálem v autě a brzdami realtime aplikaci, nebudete chtít vysokou pravděpodobnost, že brzdy zareagují rychle (a nízkou pravděpodobnost, že to bude trvat pár sekund, když budete mít opravdu smůlu, i desítky sekund), ale jistotu, že vždy zareagují nejdéle do x milisekund.
    16.1.2015 10:53 Erbureth | skóre: 21
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Takže po x milisekundách se čas reakce krátí?
    16.1.2015 13:49 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Vsechno se dela na vysokou pravdepodnobnost, na jistotu to nikdo neumi.
    13.1.2015 22:05 Jiri K. | skóre: 1
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Když děláš třeba na ARM, tak tam má Linux kernel dán frekvenci 100Hz pro scheduler, oproti Desktopu, kde je default 1000Hz. Těch 100Hz je málo, když potřebuješ něco řídit, v mém případě kvadrokoptéru.

    Ale první příspěvek už mi dal zajímavé řešení přes časovače. Domnívám se, že nevýhoda realtime aplikace bez realtime kernelu je, že se nedokáží realtime využívat různé běžící služby, jako např. pro odesílání paketů po wifi. Ale spustit realtime třeba přečtení dat z I2C sběrnice by jít mohlo.
    13.1.2015 23:01 mimi.vx | skóre: 37 | blog: Mimi.VX | Praha
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?

    tak default je i u desktopu 100Hz .. ale vetsina jader je distribuci/uzovatelem nakonfigurova jinak a nic ti nebrani si jadro pro tvuj arm prelozit s vlastnim nastavenim ...

    ale mam pocit ze vubec netusis co RT znamena ..

    USE="-gnome -kde";turris
    14.1.2015 00:21 Jiri K. | skóre: 1
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Když napíšu "Ovládat třeba realtime GPIO mezi dvěma RPi" tak asi vím co znamená RT.
    14.1.2015 07:20 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Domnívám se, že nevýhoda realtime aplikace bez realtime kernelu je, že se nedokáží realtime využívat různé běžící služby, jako např. pro odesílání paketů po wifi. Ale spustit realtime třeba přečtení dat z I2C sběrnice by jít mohlo.

    To není tak úplně pravda, problém je i v tom, že bez realtime jádra nemůžete mít ani jistotu, že vám jádro v nevhodnou chvíli neodscheduluje váš proces na dobu delší, než by se vám líbilo. Pomineme-li poněkud extrémní triky typu výše zmíněného dedikovaného procesoru, dá se to riziko omezit nastavením realtime priority, ale pak je potřeba být velmi opatrný. (Oblíbená zábava je nastavit realtime prioritu procesu, který vůbec nespí, a pak se divit, proč je celý systém mrtvý.)

    14.1.2015 08:57 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Oblíbená zábava je nastavit realtime prioritu procesu, který vůbec nespí, a pak se divit, proč je celý systém mrtvý.
    A toto se vam stalo nebo jste si to vymyslel? Kernel totiz bude tu RT aplikaci postupne prerusovat. Vizte kernel.sched_rt_period_us a kernel.sched_rt_runtime_us a taky RTFM!
    14.1.2015 09:55 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    A toto se vam stalo nebo jste si to vymyslel?

    Mně ne, protože realtime priority používám jen výjimečně a dávám si pozor, abych je nepřiřazoval CPU intensive procesům. Ale několika našim zákazníkům se to podařilo (a to vím jen o těch, u kterých se to coby bugreport dostalo ke mně; ve skutečnosti jich asi bylo víc).

    Vizte kernel.sched_rt_period_us a kernel.sched_rt_runtime_us a taky RTFM!

    Takhle jednoduše to bude fungovat na jednoprocesorovém systému. Na víceprocesorovém si může "vypůjčit" nevyužitý čas z ostatních procesorů. Ve výsledku sice udusí "jen" jeden procesor, ale protože na něm spolehlivě odblokuje kernel threads, dříve či později to znefunkční celý systém nobo jeho podstatnou část, např. jakmile někdo zavolá schedule_on_each_cpu() nebo něco podobného.

    14.1.2015 10:01 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Na víceprocesorovém si může "vypůjčit" nevyužitý čas z ostatních procesorů.

    Viz balance_runtime() and do_balance_runtime().

    14.1.2015 10:57 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    pravda, ve vanilce bezi worker thready v SCHED_OTHER, IMO pekna pitomost, zejmena koncept softirq.
    14.1.2015 11:18 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Tak ze zvedavosti jsem to zkusil na vanilce pro 1 - 6 (pocet jader) FIFO vlaken s prioritou 99 a konzole se (az na lagovani umerne nastaveni) dala normalne pouzivat. Umrela ale sit.
    14.1.2015 11:32 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?

    Pokud to spustíte na všech procesorech, tak už není odkud půjčovat, takže začne účinkovat ten 95% limit. Problémová je situace, kdy běží např. jen jeden takový realtime proces "utržený ze řetězu". Různé věci v systému (od kterých by to člověk na první pohled nečekal) se pak postupně začnou blokovat.

    Jeden z prvních příkladů, který jsem na toto téma viděl, vypadal tak, že se na jednom CPU proces s realtime prioritou točil v nekonečné smyčce a vedle druhý zavolá mlock(). (Původní testcase byl komplikovanější, oni tam volali v nekonečné smyčce ten mlock() a spustili to dvakrát, ale tahle zjednodušená verze je názornější.)

    14.1.2015 12:38 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Asi jsem to nenapsal dost jasne, udelal jsem 6 testu postupne pro 1 az 6 procesu a ani jeden z nich nezpusobil "zasek" systemu (konzole byla porad pouzitelna).

    Pouzivat libovolne syscally z RT procesu neni dobry napad, protoze v kernelu se casto pouzivaji mutexy, ktere nepodporuji priority inheritance a ani priority ceiling, takze to nemuze nikdy dost dobre fungovat. Rozumne reseni je RT procesem ovladat HW a syscally delat pres jiny thread.
    14.1.2015 12:50 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    udelal jsem 6 testu postupne pro 1 az 6 procesu a ani jeden z nich nezpusobil "zasek" systemu (konzole byla porad pouzitelna)

    Já taky netvrdil, že okamžitě nebude fungovat vůbec nic. Místo toho se postupně budou zasekávat různé procesy, které měly tu smůlu, že potřebovaly počkat na blokovaný procesor. Koneckonců, sám jste pozoroval, že při vašem testu začala zlobit síť - to může být u serveru docela zásadní problém.

    Pouzivat libovolne syscally z RT procesu neni dobry napad,

    Ten druhý proces, který volá mlock(), nemusí být realtime. Podstatné je, že se zasekne, protože čeká na worker z jiného CPU, který tam realtime CPU hog (ten žádný syscall volat nepotřebuje) nepustí na procesor. Skutečný problém je přiřazení realtime priority CPU intensive procesu. Realtime slouží k zajištění nízkých latencí, ne k tomu, aby CPU intensive proces mohl vyždímat procesor do poslední kapičky; od toho jsou úplně jiné nástroje.

    14.1.2015 13:02 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Psal jste "celý systém mrtvý", ale ono vytuhne jen to, co potrebuje per core workery, coz treba konzole neni, takze neni problem ten RT proces z te konsole zabit.

    System s RT procesy je lepsi nastavit tak, aby jaderna vlakna s omezenou afinitou mela vetsi prioritu nez pouzivane RT procesy. Ve vanilce je dokonce kompilacni volba, ktera umozni nastavit jadernym vlaknum prioritu vetsi, nez je mozne konfigurovat z uzivatelskeho prostoru.

    14.1.2015 13:20 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    coz treba konzole neni, takze neni problem ten RT proces z te konsole zabit.

    Jen pokud se k ní lze snadno dostat, což nemusí být vždy pravda. A i když ano, je problémem už to, že je to vůbec potřeba. Nebo taky dřív nějaký watchdog odstřelí celý systém, protože nebude dostupná klíčová služba.

    aby jaderna vlakna s omezenou afinitou mela vetsi prioritu nez pouzivane RT procesy … kompilacni volba, ktera umozni nastavit jadernym vlaknum prioritu vetsi, nez je mozne konfigurovat z uzivatelskeho prostoru

    To už jsou jen berličky, které umožňují omezit následky, neodstraňují problém. Navíc mnohdy nemusejí být ani žádoucí, protože pak může dojít k opačnému problému - kernel thread nepustí aplikaci na procesor tak rychle, jak by potřebovala.

    14.1.2015 13:14 Jiri K. | skóre: 1
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Počkat, prioritu přece nastavuješ od -20 do 19, -20 je nejvyšší. Kde jsi teda nastavoval prioritu 99?
    14.1.2015 13:19 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    bavime se o SCHED_FIFO, ne o SCHED_OTHER
    14.1.2015 14:08 luky
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    ctete man sched_setscheduler
    14.1.2015 10:19 Jiri K. | skóre: 1
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    Tak nastavit prioritu procesu na nejnižší jsem zkoušel bez jakékoliv změny v její frekvenci vykonávání a bez jakékoliv změny v tom, že frekvence nebyla vždy stabilní, protože se spustil nějaký jiný proces. Moje zkušenost je, že to nevyvolalo žádnou změnu.
    14.1.2015 10:22 Jiri K. | skóre: 1
    Rozbalit Rozbalit vše Re: Jak napsat aplikaci realtime bez realtime kernelu?
    *resp. na nejvyšší

    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.