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 15:33 | IT novinky

    Po 26 letech od protiprávního policejního zásahu, který byl spuštěn na základě podnětu společnosti Microsoft, Obvodní soud pro Prahu 2 rozsudkem potvrdil, že Mironet prokázal významnou část svého nároku na náhradu škody vůči Ministerstvu spravedlnosti ČR. Soudem nyní přiznaná část nároku znamená rekordní odškodné, jaké kdy české soudy přiznaly za nesprávný postup státu. Spor byl rozdělen na několik škod, u pravomocně uzavřených částí

    … více »
    Ladislav Hagara | Komentářů: 17
    včera 15:22 | Nová verze

    Lehké desktopové prostředí LXQt bylo vydáno ve verzi 2.4.0. Jde o převážně opravné vydání s drobnými vylepšeními podpory Waylandu.

    |🇵🇸 | Komentářů: 0
    včera 12:44 | IT novinky

    Počítačová hra Kingdom Come: Deliverance 2 českého studia Warhorse získala cenu BAFTA v kategorii nejlepší příběh. V konkurenci pěti dalších nominovaných děl porazila i úspěšnou francouzskou hru Clair Obscur: Expedition 33, která v letošním ročníku získala cenu za nejlepší hru roku.

    Ladislav Hagara | Komentářů: 1
    včera 12:22 | Komunita

    Projekt KDE oslaví v říjnu 30 let. Matthias Ettrich poslal 14. října 1996 do diskusní skupiny comp.os.linux.misc zprávu, která započala historii projektu. Důležité milníky jsou zobrazeny na časové ose KDE.

    Ladislav Hagara | Komentářů: 2
    včera 02:55 | Komunita

    Byly vyhlášeny výsledky letošní volby vedoucí/ho projektu Debian (DPL, Wikipedie). Poprvé povede Debian žena. Novou vedoucí je Sruthi Chandran. Letos byla jedinou kandidátkou. Kandidovala již v letech 2020, 2021, 2024 a 2025. Na konferenci DebConf19 měla přednášku Is Debian (and Free Software) gender diverse enough?

    Ladislav Hagara | Komentářů: 16
    včera 00:55 | Nová verze

    Byla vydána nová verze 10.3 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Přidána byla podpora Orange Pi 4 LTS. Přibyl balíček Prometheus.

    Ladislav Hagara | Komentářů: 0
    19.4. 18:55 | Nová verze

    Implementace VPN softwaru WireGuard (Wikipedie) pro Windows, tj. WireGuard pro Windows a WireGuardNT, dospěly do verze 1.0.

    Ladislav Hagara | Komentářů: 2
    19.4. 16:11 | IT novinky

    V Pekingu dnes proběhl 2. ročník půlmaratonu humanoidních robotů. První 3 místa obsadili roboti Honor Lightning v různých týmech. Nový rekord autonomního robota je 50 minut a 26 sekund. Operátorem řízený robot to zvládl i s pádem za 48 minut a 19 sekund. Řízení roboti měli časovou penalizaci 20 %. Před rokem nejrychlejší robot zvládl půlmaraton za 2 hodiny 40 minut a 42 sekund. Aktuální lidský rekord drží Jacob Kiplimo z Ugandy s časem 57 minut a 20 sekund [𝕏].

    Ladislav Hagara | Komentářů: 6
    17.4. 17:11 | Zajímavý článek

    Stanislav Fort, vedoucí vědecký pracovník z Vlčkovy 'kyberbezpečnostní' firmy AISLE, zkoumal dopady Anthropic Mythos (nový AI model od Anthropicu zaměřený na hledání chyb, který před nedávnem vyplašil celý svět) a předvedl, že schopnosti umělé inteligence nejsou lineárně závislé na velikosti nebo ceně modelu a dokázal, že i některé otevřené modely zvládly v řadě testů odhalit ve zdrojových kódech stejné chyby jako Mythos (například FreeBSD CVE-2026-4747) a to s výrazně nižšími provozními náklady.

    MakeIranBombedAgain❗ | Komentářů: 8
    17.4. 12:44 | IT novinky

    Federální návrh zákona H.R.8250 'Parents Decide Act', 13. dubna předložený demokratem Joshem Gottheimerem a podpořený republikánkou Elise Stefanik coby spolupředkladatelkou (cosponsor), by v případě svého schválení nařizoval všem výrobcům operačních systémů při nastavování zařízení ověřovat věk uživatelů a při používání poskytovat tento věkový údaj aplikacím třetích stran. Hlavní rozdíl oproti kalifornskému zákonu AB 1043 a kolorádskému SB26-051 je ten, že federální návrh by platil rovnou pro celé USA.

    MakeIranBombedAgain❗ | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1369 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: FIFO buffer v C pro AVR

    28.6.2019 09:40 RadekXxX | skóre: 10
    FIFO buffer v C pro AVR
    Přečteno: 551×
    Zdravím, mám udělaný jednoduchý statický FIFO buffer C pro AVR atmel, který je pověšený na UART, funkce FifoAddByte se volá pouze v interruptu uartu na příjem bytu, funkce FifoGetByte se volá v hlavní smyčce while. Nevím proč, ale za nejakých okolností se mě rozhodí registr OfsRD a OfsWR tak, že OfsRD nemá stejnou hodnotu jako OfsWR když je buffer prázdný a pak je samozřejmě buffer nefunkční. Netušíte včem může být problém ?
    typedef struct {
      word    OfsWR;   // Pozice cteni
      word    OfsRD;   // Pozice zapisu
      word    Cnt;     // Pocet ulozenych bytu
      byte *  Buf;     // Buffer
      word    BufSize; // Velikost bufferu
    } Fifo_t;
    
    word FifoGetCount (Fifo_t * Fifo){
      return Fifo->Cnt;
    }
    
    word FifoGetFree (Fifo_t * Fifo){
      return Fifo->BufSize - Fifo->Cnt;
    }
    
    byte FifoAddByte (Fifo_t * Fifo, byte Src){
      if (Fifo->Cnt >= Fifo->BufSize) return 0;
      Fifo->Buf[Fifo->OfsWR++] = Src;
      Fifo->Cnt++;
      if (Fifo->OfsWR >= Fifo->BufSize) Fifo->OfsWR = 0;
      return 1;
    }
    
    byte FifoGetByte (Fifo_t * Fifo){
      byte b;
      if (!Fifo->Cnt) return 0;
      b = Fifo->Buf[Fifo->OfsRD++];
      Fifo->Cnt--;
      if (Fifo->OfsRD >= Fifo->BufSize) Fifo->OfsRD = 0;
      return b;
    }
    
    
    void FifoInit (Fifo_t * Fifo, byte * Buf, word BufSize){
      Fifo->OfsRD = 0;
      Fifo->OfsWR = 0;
      Fifo->Cnt = 0;
      Fifo->BufSize = BufSize;
      Fifo->Buf = Buf;
    }
    

    Odpovědi

    28.6.2019 10:30 TechnikTom
    Rozbalit Rozbalit vše Re: FIFO buffer v C pro AVR
    Zkuste tu strukturu jako volatile. Třeba tam optimalizátor něco vyhodí z kódu, když se některá proměna změní v přerušení mimo hlavní kód.
    28.6.2019 10:39 TechnikTom
    Rozbalit Rozbalit vše Re: FIFO buffer v C pro AVR
    Navíc ty offsety jsou 16bitove, takže increment i decrement není na jednu instrukci a přerušení při příjmu znaků může přijít právě v průběhu provádění, což může být zdrojem problémů.
    28.6.2019 11:09 RadekXxX | skóre: 10
    Rozbalit Rozbalit vše Re: FIFO buffer v C pro AVR
    Zatím to vypadá, že to funguje, díky za radu. Bytová velikost offsetů nepomohla, až volatile byla ta správná volba, nevím proč mě to nenapadlo vyzkoušet, ale hlavně jsem si myslel, že když OfsRD se upravuje pouze v hlavní smyčce a OfsWR pouze v interruptu tak, že to nebude problém, ale asi je.
    28.6.2019 11:57 TechnikTom
    Rozbalit Rozbalit vše Re: FIFO buffer v C pro AVR
    Tak to je dobře. Ale stejně pozor na tu velikost word u Cnt.

    Pokud v hlavní smyčce ve funkci FifoGetBytek když provádíte Fifo->Cnt--;

    přijde přerušení od příjmu zraku, tak ve funkci FifoAddByte

    provedete Fifo->Cnt++; na dosud nedokončené decrementaci.

    Tak buď v tu dobu zakázat přerušení nebo použít atomic.h
    28.6.2019 11:59 TechniTom
    Rozbalit Rozbalit vše Re: FIFO buffer v C pro AVR
    Koukám, že mezitím to kolega Jooky vysvětlil mnohem fundovaněji.
    28.6.2019 11:16 [Jooky]
    Rozbalit Rozbalit vše Re: FIFO buffer v C pro AVR
    V prvom rade treba vsetko, co je pristupne z prerusenia, deklarovat ako volatile. Bez toho compilator nerata, ze hodnota sa moze zmenit mimo kontext aktualneho kodu. Kompilator moze optimalizovat kod tak, ze si udaje drzi v registroch a necita udaje z pamate. Tym padom zmena z prerusenia nie je reflektovana v hlavnej slucke kodu.

    Druha vec je, ze napr do "Cnt" zapisujes aj pocas prerusenia aj mimo neho. Taky kod musi byt spravne zabaleny do tzv. "ATOMIC_BLOCK". Inac povedane, funkcia FifoGetByte by mala docasne vypnut prerusenie a zapnut ho az ked su vsetky zmeny zapisane do pamate. V opacnom pripade moze nastat situacia, ze funkcia "FifoGetByte" a "FifoAddByte" sa bude prelinat a navzajom si prepisu data. Situacia, ked sa napr. nacitaju data pre if a/alebo dekrementaciu. V preruseni dojde k zmene udajov, ale k naslednemu zapisu dojde podla pred tym nacitanych dat a nie realnych .... o tomto by sa dalo dlho hovorit. Ked si pohladas "ATOMIC_BLOCK" v avr-gcc dokumentacii tak najdes hromadu roznych prikladov, preco sa to ma pouzivat.

    Este co sa tyka kodu samotneho. Doproucujem pouzivat tzv. "Exact-width integer types", namiesto char/int/word/etc. ... vasina AVR procesorov je 8bit. Ak je mozne, tak je dobre drzat premene na velkosti 8bit. Vsetko vacsie znamena navyse instrukcie (spomalenie kodu), ale hlavne rozdelenie operacii na viacej krokov. Kym napr inkrementacia 8bit hodnoty bude na jeden krok (instrukciu), tak 16bit hodnota musi byt rozdelena na niekolko dalsich instrukcii. Ak pocas toho este dojde aj k preruseniu, tak je dalsi problem na svete. Nechce sa mi to teraz hladat, ale mam pocit, ze word bude 16bit, co si myslim, ze je aj tak vela na FIFO pre AVR.

    "Exact-width integer types" maju format int8_t (so znamienkom), uint8_t (bez znamienka) az po 64 (8, 16, 32, 64).
    3.7.2019 15:05 ml
    Rozbalit Rozbalit vše Re: FIFO buffer v C pro AVR
    Něco podobného jsem vyřešil před řadou let a od té doby s tím nejsou žádné problémy. U mě se zapisuje do externí RAM (6C4008 = 512K x 8 bitů), ale kdybych místo funkcí zapis_znak(adresa_zapisu++) a precti_znak(adresa_cteni++) které zapisují a vyzvedávají znak volal jiné, bude to fungovat také, možná bych jen musel dát vně vymaskování vyšších bitů. S vnitřní pamětí jsem nevystačil, té je dost málo, teda pro moji potřebu. Mám to na jiném počítači, tak to sem dát teď nemůžu, ale neni to nic závratného. Problém může být, ale to už tu zaznělo dvakrát ve volatile, to jsem taky někdy řešil, ne asi v tomto, ale někdy určitě ano, jedno slovíčko a co to udělá. Buffer je dobrý volit jako mocninu dvou pak se zbavíte podmínky a ukazatele bude stačit jen vymaskovat (popravdě bych namísto podmínky použil modulo, ale když to tak počítám, na počet taktů to vyjde stejně).

    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.