abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 13:11 | Nová verze

    Coppwr, tj. GUI nástroj pro nízkoúrovňové ovládání PipeWire, byl vydán v nové verzi 1.6.0. Zdrojové kódy jsou k dispozici na GitHubu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    2.5. 22:33 | Nová verze

    Byla vydána dubnová aktualizace aneb nová verze 1.89 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Vypíchnout lze, že v terminálu lze nově povolit vkládání kopírovaného textu stisknutím středního tlačítka myši. Ve verzi 1.89 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 14
    2.5. 21:22 | Nová verze

    Proton, tj. fork Wine integrovaný v Steam Play a umožňující v Linuxu přímo ze Steamu hrát hry určené pouze pro Windows, byl vydán ve verzi 9.0-1 (𝕏). Přehled novinek se seznamem nově podporovaných her na GitHubu. Aktuální přehled her pro Windows běžících díky Protonu také na Linuxu na stránkách ProtonDB.

    Ladislav Hagara | Komentářů: 2
    2.5. 19:33 | Nová verze

    Byla vydána verze 1.78.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání na GitHubu. Vyzkoušet Rust lze například na stránce Rust by Example.

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

    Služba Dropbox Sign (původně HelloSign) pro elektronické podepisování smluv byla hacknuta.

    Ladislav Hagara | Komentářů: 2
    2.5. 11:00 | Nová verze

    Byla vydána nová major verze 8.0 textového editoru GNU nano (Wikipedie). Podrobný přehled novinek a oprav v oznámení v diskusním listu info-nano nebo v souboru ChangeLog na Savannah. Volbou --modernbindings (-/) lze povolit "moderní" klávesové zkratky: ^C kopírování, ^V vložení, ^Z vrácení zpět, … Tato volba je aktivována také pokud binárka s nano nebo link na ni začíná písmenem "e".

    Ladislav Hagara | Komentářů: 3
    1.5. 23:22 | IT novinky

    Před 60 lety, 1. května 1964, byl představen programovací jazyk BASIC (Beginners' All-purpose Symbolic Instruction Code).

    Ladislav Hagara | Komentářů: 22
    1.5. 22:22 | Nová verze

    Byla vydána nová verze 12.0 minimalistické linuxové distribuce (JeOS, Just enough Operating System) pro Kodi (dříve XBMC) a multimediálního centra LibreELEC (Libre Embedded Linux Entertainment Center). Jedná se o fork linuxové distribuce OpenELEC (Open Embedded Linux Entertainment Center). LibreELEC 12.0 přichází s Kodi 21.0 "Omega".

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

    Microsoft vydal novou velkou aktualizaci 2404.23 v září 2019 pod licencí SIL Open Font License (OFL) zveřejněné rodiny písma Cascadia Code pro zobrazování textu v emulátorech terminálu a vývojových prostředích.

    Ladislav Hagara | Komentářů: 0
    1.5. 05:33 | Nová verze

    OpenTofu, tj. svobodný a otevřený fork Terraformu vzniknuvší jako reakce na přelicencování Terraformu z MPL na BSL (Business Source License) společností HashiCorp, bylo vydáno ve verzi 1.7.0. Přehled novinek v aktualizované dokumentaci. Vypíchnout lze State encryption.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (31%)
     (20%)
     (31%)
     (17%)
    Celkem 35 hlasů
     Komentářů: 8, poslední dnes 08:25
    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: 1055×
    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: 62 | 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: 72 | 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: 72 | 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: 72 | 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: 72 | 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: 72 | 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: 72 | 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.