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 04:00 | Nová verze

    Node-RED (Wikipedie, GitHub), webová aplikace postavená na Node.js pro vizuální programování a propojování hardwarových zařízení, API a online služeb, byl vydán ve verzi 5.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    dnes 02:00 | Nová verze

    Byla vydána nová verze 3.27.0 FreeRDP, tj. svobodné implementace protokolu RDP (Remote Desktop Protocol). Opraveno bylo 5 zranitelností.

    Ladislav Hagara | Komentářů: 0
    včera 23:11 | Komunita

    Řídící výbor GCC schválil záměr do GCC začlenit backend WebAssembly.

    Ladislav Hagara | Komentářů: 2
    14.6. 21:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.

    Ladislav Hagara | Komentářů: 0
    14.6. 13:33 | Zajímavý software

    Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.

    Ladislav Hagara | Komentářů: 0
    13.6. 15:22 | IT novinky

    Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.

    Ladislav Hagara | Komentářů: 7
    13.6. 02:22 | Nová verze

    Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.

    Ladislav Hagara | Komentářů: 0
    12.6. 16:33 | Bezpečnostní upozornění

    V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.

    Ladislav Hagara | Komentářů: 14
    12.6. 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    12.6. 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

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


    Dotaz: Chyba v programu v C (avr)

    4.5.2010 16:37 mega8
    Chyba v programu v C (avr)
    Přečteno: 341×
    Zdravím. Snažil jsem se naprogramovat do procesoru mega8 procedury na blikání led diod, ale nějak si to občas dělá co chce. Konkrétně třeba bliknou led diody, které by v tu chvíli vůbec neměly.
    
    uint8_t leds_array[LEDS];
    uint8_t leds_array_pointer = 0;
    
    void leds_add(uint8_t lid) {
            leds_array[leds_array_pointer] = lid;
            if( leds_array_pointer < (LEDS-1) ) leds_array_pointer ++;
    }
    
    void leds_clear() {
            leds_array_pointer = 0;
    }
    
    void leds_blink(uint8_t interval) {
            bool leds_status_before[LEDS];
            if(leds_array_pointer > 0) {
                    for(int i=0; i<=leds_array_pointer; i++) {
                            if(bit_is_set(LED_PIN, leds_array[i]))
                                    leds_status_before[i] = true;
                            else
                                    leds_status_before[i] = false;
                            bitSet (LED_PORT, leds_array[i]);
                    }
                    m_delay_ms(interval);
                    for(int i=0; i<=leds_array_pointer; i++) {
                            bitClear (LED_PORT, leds_array[i]);
                    }
                    m_delay_ms(interval);
                    for(int i=0; i<=leds_array_pointer; i++) {
                            if(leds_status_before[i]) bitSet (LED_PORT, leds_array[i]);
                    }
            leds_clear();
            }
    }
    
    
    v programu potom volám:
    
    if(podmínka1) leds_add(LED_1);
    if(podmínka2) leds_add(LED_2);
    // teoreticky mohou bliknout jen led1 a led2, ale občas blikne i led3
    leds_blink(LED_BLINK_INTERVAL);
    
    
    Kde dělám chybu?

    Řešení dotazu:


    Odpovědi

    4.5.2010 17:28 Sten
    Rozbalit Rozbalit vše Re: Chyba v programu v C (avr)
    Klasická chyba off-by-one.

    for(int i=0; i<=leds_array_pointer; i++) {

    má být

    for(int i=0; i<leds_array_pointer; i++) {

    Po nastavení dvou LEDek je leds_array_pointer == 2, ale ten první (původní) cyklus proběhne třikrát
    4.5.2010 18:08 mega8
    Rozbalit Rozbalit vše Re: Chyba v programu v C (avr)
    díky za pomoc
    5.5.2010 15:44 Farin
    Rozbalit Rozbalit vše Re: Chyba v programu v C (avr)
    leds_array_pointer - dost zavadejici nazev promenne; vystiznejsi je asi leds_array_index || leds_array_ix

    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.