Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) zveřejnil Národní politiku koordinovaného zveřejňování zranitelností (pdf), jejímž cílem je nejen zvyšování bezpečnosti produktů informačních a komunikačních technologií (ICT), ale také ochrana objevitelů zranitelností před negativními právními dopady. Součástí je rovněž vytvoření „koordinátora pro účely CVD“, jímž je podle nového zákona o kybernetické … více »
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.12. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Společnost System76 vydala Pop!_OS 24.04 LTS s desktopovým prostředím COSMIC. Videoukázky na YouTube.
Byla vydána verze 1.92.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2024. Oceněni byli Andy Wingo, jeden ze správců GNU Guile, Alx Sa za příspěvky do Gimpu a Govdirectory jako společensky prospěšný projekt.
Bylo vydáno Eclipse IDE 2025-12 aneb Eclipse 4.38. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
U příležitosti oslav osmi let prací na debianím balíčku vyšlo GPXSee 15.6. Nová verze přináší především podporu pro geotagované MP4 soubory, včetně GoPro videí. Kdo nechce čekat, až nová verze dorazí do jeho distribuce, nalezne zdrojové kódy na GitHubu.
Monado, tj. multiplatformní open source implementace standardu OpenXR specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro virtuální realitu (VR) a rozšířenou realitu (AR), bylo vydáno ve verzi 25.1.0. Přehled novinek v poznámkách k vydání.
Byla vydána listopadová aktualizace aneb nová verze 1.107 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.107 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Pornhub zveřejnil podrobné statistiky za rok 2025. V části věnované zařízením a technologiím se lze dočíst, že 87 % přenášených dat směrovalo na telefony, 2 % na tablety a 11 % na desktopy. Operační systém Linux běžel na 6,3 % desktopů. O 22,4 % více než před rokem. Firefox má na desktopu 8,4 % podíl.
ioctl().
/dev/ttyS0 (nebo jiný) pro čtení i zápis, zapisujte tam a čtěte z něj, jako by to byl normální soubor. Něco složitějšího by bylo potřeba řešit teprve ve chvíli, kdy byste potřeboval zpracovávat data od protějšku asynchronně.
sigaction(). Funguje to asi takhle:
struct sigaction saio; saio.sa_handler = signal_handler_IO; sigemptyset(&saio.sa_mask); saio.sa_flags = 0; saio.sa_restorer = NULL; sigaction(SIGIO,&saio,NULL); fcntl(fd, F_SETOWN, getpid()); fcntl(fd, F_SETFL, FASYNC);
signal_handler_IO() je funkce, kterou si napíšeš sám. Tohle funguje jako přerušení - když přijdou data z portu, tvůj program přeruší běh a vykoná tuhle funkci; pak se vrátí tam, odkud vyskočil. Je to příklad, který jsem našel na netu, neověřoval jsem, jestli bude fungovat - cílem bylo ukázat na dvě podstatné funkce: sigaction() a fcntl()
Pokud si vzpomínám, ten port musí být otevřen jako neblokující (parametr O_NONBLOCK předaný funkci open()) a asynchronní. Příklad s nějakou teorií okolo toho najdeš tady
Druhá možnost je využití sigwait() nebo sigwaitinfo(). To se hodí, když program čeká na víc věcí naráz. Z hlediska programátora to funguje tak, že program se po zavolání této funkce zastaví a čeká, až se něco stane - vypršení časovače, přijetí dat na portu atd. Když jsem naposledy hledal, moc jsem toho na webu nenašel, ale něco je tady
Nějaké srovnání mezi těmito způsoby najdeš v diskuzi zde. Popis všech jmenovaných funkcí najdeš v manuálových stránkách (man jméno_funkce), popřípadě na webu: Linux man pages.
Který způsob si vybereš (signál jedním či druhým způsobem nebo samostatné vlákno), je na tobě; asi to bude záviset na tom, co ten program dělá kromě obsluhy portu, jaké má uživatelské rozhraní (jestli nějaké má) a podobně.
Pokud nepotřebujete během toho čekání na data dělat něco jiného, tak v tom není žádný problém. Syscall read() se nevrátí, dokud nepřečte nějaká data, nedojde k chybě nebo nedostanete nějaký signál. Pokud potřebujete během čekání vyvíjet nějakou činnost, je možné podle okolností použít select()/poll(), asynchronní čtení, samostatný thread, možná jsou i další možnosti. Ale pak by to chtělo víc informací.
Tiskni
Sdílej: