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 20:22 | Zajímavý článek

Nadace Raspberry Pi vydala již osmapadesáté číslo (pdf) stostránkového anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači a druhé číslo (pdf) časopisu Hello World primárně určeného pro učitele informatiky a výpočetní techniky.

Ladislav Hagara | Komentářů: 0
dnes 19:55 | Humor

Portál Stack Overflow informuje na svém blogu, že pomohl ukončit editor Vim už více než milionu vývojářů. V loňském roce například hledal odpověď na otázku Jak ukončit editor Vim v průměru 1 z 20 000 návštěvníků.

Ladislav Hagara | Komentářů: 4
dnes 19:22 | Nová verze

Po pěti měsících od vydání verze 3.5.0 byla vydána nová stabilní verze 3.6.0, tj. první z nové řady 3.6, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie). Z novinek lze zmínit například podporu dvou nových 64bitových platforem little-endian POWER machines (ppc64le) a IBM z Systems (s390x) nebo nové balíčky Rust 1.17.0, Cargo 0.18.0, GHC 8.0.2 a Julia 0.5.2.

Ladislav Hagara | Komentářů: 0
včera 21:33 | Bezpečnostní upozornění

V Sambě byla nalezena a opravena bezpečnostní chyba CVE-2017-7494. Má-li útočník právo ukládat soubory na vzdálený server, může tam uložit připravenou sdílenou knihovnu a přinutit smbd server k jejímu načtení a tím pádem ke spuštění libovolných příkazů. Chyba je opravena v upstream verzích 4.6.4, 4.5.10 a 4.4.14. Chyba se týká všech verzí Samby od verze 3.5.0 vydané 1. března 2010.

Ladislav Hagara | Komentářů: 3
včera 20:44 | Nová verze

Byla vydána nová stabilní verze 4.3.0 integrovaného vývojového prostředí (IDE) Qt Creator. Z novinek lze zmínit například integraci editoru kódu do Qt Quick Designeru.

Ladislav Hagara | Komentářů: 1
včera 20:11 | Bezpečnostní upozornění

Společnost Check Point informuje na svém blogu o novém vektoru útoku. Pomocí titulků lze útočit na multimediální přehrávače VLC, Kodi, Popcorn Time, Stremio a pravděpodobně i další. Otevření útočníkem připraveného souboru s titulky v neaktualizovaném multimediálním přehrávači může vést ke spuštění libovolných příkazů pod právy uživatele. Ukázka na YouTube. Chyba je opravena v Kodi 17.2 nebo ve VLC 2.2.6.

Ladislav Hagara | Komentářů: 11
23.5. 15:18 | Zajímavý software

CrossOver, komerční produkt založený na Wine, je dnes (23. 5. 2017) dostupný ve slevě. Roční předplatné linuxové verze vyjde s kódem TWENTYONE na $21, resp. $1 v případě IP z chudších zemí. Firma CodeWeavers, která CrossOver vyvíjí, významně přispívá do Wine. Přidaná hodnota CrossOver spočívá v přívětivějším uživatelském rozhraní, integraci do desktopu a podpoře.

Fluttershy, yay! | Komentářů: 26
23.5. 15:11 | Zajímavý projekt

V únoru loňského roku bylo představeno několik útoků na celou řadu bezdrátových klávesnic a myší s názvem MouseJack. Po více než roce lze chybu opravit, tj. aktualizovat firmware, také z Linuxu. Richardu Hughesovi se podařilo navázat spolupráci se společností Logitech, získat od nich dokumentaci, přesvědčit je, aby firmware poskytovali přímo a ne jako součást .exe souboru, aby mohl být popis začleněn do služby Linux Vendor Firmware Service (LVFS) a aktualizace tak mohla proběhnou přímo z Linuxu pomocí projektu fwupd.

Ladislav Hagara | Komentářů: 2
23.5. 13:22 | Nová verze

Po roce a půl vydali vývojáři projektu SANE (Scanner Access Now Easy) (Wikipedie) novou verzi 1.0.27 balíku SANE-Backends. Nejnovější verze tohoto balíku pro přístup ke skenerům přináší například významná vylepšení v několika backendech nebo podporu pro více než 30 nových modelů skenerů. Verze 1.0.26 byla přeskočena.

Ladislav Hagara | Komentářů: 0
22.5. 20:55 | Komunita

Od 18. do 21. května proběhla v Saint-Étienne Linux Audio Conference 2017. Na programu byla řada zajímavých přednášek a seminářů. Videozáznamy přednášek lze zhlédnout na YouTube. K dispozici jsou také články a prezentace.

Ladislav Hagara | Komentářů: 0
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (32%)
 (1%)
 (8%)
 (44%)
 (9%)
Celkem 615 hlasů
 Komentářů: 62, poslední 19.5. 01:57
    Rozcestník

    Dotaz: funkce poll() a timeout při nečinnosti sériového portu - jazyk C

    21.3.2010 19:37 J@rys | skóre: 11 | blog: Jarduv_blog
    funkce poll() a timeout při nečinnosti sériového portu - jazyk C
    Přečteno: 265×
    Ahojte. Potřeboval bych poradit. Vytvořil jsem fungujici aplikaci v C pro posilani a prijem dat ze serioveho portu. Aplikace jako celek funguje bezvadne. Jedine co nefunguje je timeout u funkce poll(). Potrebuji totiz, aby pokud nastane necinnost na seriovem portu po dobu 30s aplikace provedla resend dat odzacatku. Problem je jaksi v tom, ze se mi timeout ze zahadneho duvodu nedari naplnit. Misto toho zustane aplikace stat na volani poll() a je tedy jakoby zamrzla. U funkce select(), kterou jsem zkousel ve vedlejsi verzi tento problem nemam. Ale select() je pro me nedostacujici, nebot nedokaze rozlisit, zda jde o udalost "odeslana" nebo "prijata" data. Zkusil jsem to u ni trochu obejit, ale nedarilo se mi. Zde jsou fragmenty kodu s funkci poll():

    //Otevreni portu pro cteni a zapis se zamezenim kontroly tarminalu: fd = open(argv[2], O_RDWR | O_NOCTTY );

    //Ulozeni aktualnijho nastaveni terminalu pro otevreny com port: tcgetattr(fd,&oldtio); //Naplneni struktury s novym nastavenim nulami: bzero(&newtio, sizeof(newtio)); //Nastaveni konfigurace: prenosove rychlosti, hardveroveho rizeni RTSCTS, 8bitu, ignorovat modem control lines, povoleni prijmu newtio.c_cflag = BAUDRATE | CS8 | CLOCAL | CREAD;

    //Vstupni zpracovani - ignoruji se chyby parity a vzorkovani, je zapnuto interpretace carriege return na novy radek: newtio.c_iflag = IGNPAR | IGNCR; //ICRNL, ne IGNCR

    //Vystupni zpracovani zadne pro odchozi data: newtio.c_oflag = 0; //Kanonicky vstup - konce radku \n: newtio.c_lflag = ICANON;

    //Zrusi vsechna zapsana, ale neodeslana data a prijata, ale neprectena: tcflush(fd, TCIFLUSH);

    //Provedeni zmeny nastaveni: tcsetattr(fd,TCSANOW,&newtio);

    //Specifikace monitorovani deskriptoru: struct pollfd fds[1];

    //Timeout, ktery vyprsi, pokud nenastane zadna udalost na fd [ms]: int timeout = 20000;

    //Navratova hodnota funkce poll: int ret; //Nastaveni monitorovaneho fd: fds[0].fd = fd;

    //Nastaveni priznaku, ktere budeme monitorovat (cteni zapis): fds[0].events = POLLIN | POLLOUT;

    //Maska nastalych udalosti na 0 (zadna udalost dosud nenastala): fds[0].revents = 0; //Monitorovani filedescriptoru: ret = poll(fds, 1, timeout);

    Podotykam jeste, ze preklad je bez Warningu.

    Řešení dotazu:


    Odpovědi

    Řešení 1× (J@rys (tazatel))
    22.3.2010 00:47 Jirka P
    Rozbalit Rozbalit vše Re: funkce poll() a timeout při nečinnosti sériového portu - jazyk C
    1) Nafomátujte ten příspěvek (<pre>...), takhle se to nedá číst.

    2) select()em se dá rozlišit, jestli data přišla nebo odešla (viz parametry readfds, writefds)

    3) Možná je to nějaké chyba v jádře, mohl byste napsat konfiguraci? Zkuste, jestli ten timeout funguje bez filedeskriptorů.

    4) Zkuste volání ppoll().

    5) Zkuste použít timerfd místo timeoutu.

    6) (poslední zoufalý krok) Můžete se nechat probudit signálem, viz alarm(). Bohužel, tohle většinou znamená race (s obyč. select()em).
    22.3.2010 18:42 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: funkce poll() a timeout při nečinnosti sériového portu - jazyk C
    Správně, takhle se to nedá přečíst.
    In Ada the typical infinite loop would normally be terminated by detonation.

    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.