Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 4.5.0. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Byl vydán Mozilla Firefox 138.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 138 je již k dispozici také na Flathubu a Snapcraftu.
Šestnáctý ročník ne-konference jOpenSpace se koná 3. – 5. října 2025 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytvářejí všichni účastníci, se skládá z desetiminutových
… více »Richard Stallman přednáší ve středu 7. května od 16:30 na Technické univerzitě v Liberci o vlivu technologií na svobodu. Přednáška je určená jak odborné tak laické veřejnosti.
Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.04.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.
TmuxAI (GitHub) je AI asistent pro práci v terminálu. Vyžaduje účet na OpenRouter.
Byla vydána nová verze R14.1.4 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek i s náhledy v poznámkách k vydání. Podrobný přehled v Changelogu.
Bylo vydáno OpenBSD 7.7. Opět bez písničky.
V Tiraně proběhl letošní Linux App Summit (LAS) (Mastodon). Zatím nesestříhané videozáznamy přednášek jsou k dispozici na YouTube.
Každý geek by měl jedny mít. A pro ty, kteří opovrhují koupenými nebo jen nemají dost peněz je určen následující návod.
Důležité: před zahájením práce doporučuji přečíst následující články: Jednočipy pod Linuxem I Jednočipy pod Linuxem II a Jednočip ATtiny2313 pod Linuxem. Nebudu se zde zabývat základními věcmi jako jednoduchý programátor, vývojové prostředí nebo nahrávání programu do jednočipu
Disclaimer: veškeré zde uvedené postupy činíte na vlastní nebezpečí. I když jsem tento postup vyzkoušel, za případný spálený paralelní port, základní desku, nebo vlasy. Zkrátka když bude něco špatně, mě z toho vynechte.
#include <avr/io.h> #include <avr/interrupt.h> // definice maker pro prace s bity #define bitSet(var, mask) ((var) |= (1 << (mask))) #define bitClear(var, mask) ((var) &= ~(1 << (mask))) short s=0, m=0, h=0; void showMins(short m); void showHours(short h); SIGNAL (SIG_OVERFLOW0) { // zavola se pri preteceni interniho 8bit citace static unsigned char count = 0; TCNT0=6; // 8MHz/256/250=125 preruseni/sec - pocita s nastavenim interniho oscilatoru na // 8MHz. Pokud tak neni, je nutne prepocitat // 256 (velikost counteru) - 250 (nas delitel) = 6 (pri kazdem preteceni // zaciname od 6 a ne od 0) count ++; if (count == 125) { // pracujeme s kazdym 125 preruseni count=0; extern short h, m, s; s++; if (s%2==0) // kazdou sudou vterinu rozsvitime LED a kazdou lichou zhasneme bitSet(PORTD, PD0); else bitClear(PORTD, PD0); if (s>=60) { // postarame se o korektni cas s=s-60; m++; } if (m>=60) { h++; m=m-60; } if (h==24) h=0; // a nakonec zavolame funkce pro zobrazeni hodin/minut showHours(h); showMins(m); } } SIGNAL (SIG_INT0) { // zavola se pri stisknuti tlacitka minut extern short m,s; m++; s=0; // resetuje vteriny if(m>=60) m=0; // neprehazujeme hodiny, nastavujeme showMins(m); } SIGNAL (SIG_INT1) { // zavola se pri stisknuti tlacitka hodin extern short h,s; h++; s=0; // resetuje vteriny if(h>=24) h=0; showHours(h); } void showHours(short h) { // funkce starajici se o rozsveceni jednotlivych LED pro hodiny if(h>=16) { bitSet(PORTB, PB0); h=h-16; } else bitClear(PORTB, PB0); if(h>=8) { bitSet(PORTD, PD6); h=h-8; } else bitClear(PORTD, PD6); if(h>=4) { bitSet(PORTD, PD5); h=h-4; } else bitClear(PORTD, PD5); if(h>=2) { bitSet(PORTD, PD4); h=h-2; } else bitClear(PORTD, PD4); if(h==1) bitSet(PORTD, PD1); else bitClear(PORTD, PD1); } void showMins(short m) { // funkce starajici se o rozsveceni jednotlivych LED pro minuty if(m>=32) { bitSet(PORTB, PB6); m=m-32; } else bitClear(PORTB, PB6); if(m>=16) { bitSet(PORTB, PB5); m=m-16; } else bitClear(PORTB, PB5); if(m>=8) { bitSet(PORTB, PB4); m=m-8; } else bitClear(PORTB, PB4); if(m>=4) { bitSet(PORTB, PB3); m=m-4; } else bitClear(PORTB, PB3); if(m>=2) { bitSet(PORTB, PB2); m=m-2; } else bitClear(PORTB, PB2); if(m==1) bitSet(PORTB, PB1); else bitClear(PORTB, PB1); } int main() { // Nastaveni pinu jako vystupnich bitSet (DDRD, PD0); // vterinovy blikatko bitSet (DDRD, PD1); // hodiny - 1 bitSet (DDRD, PD4); // 2 bitSet (DDRD, PD5); // 4 bitSet (DDRD, PD6); // 8 bitSet (DDRB, PB0); // 16 bitSet (DDRB, PB1); // minuty - 1 bitSet (DDRB, PB2); // 2 bitSet (DDRB, PB3); // 4 bitSet (DDRB, PB4); // 8 bitSet (DDRB, PB5); // 16 bitSet (DDRB, PB6); // 32 // Nastaveni preruseni bitSet (PCMSK, PD2); // minutovy button bitSet (MCUCR, ISC11); // falling edge bitSet (MCUCR, ISC01); bitSet (GIMSK, INT0); // povoleni preruseni 0 bitSet (PCMSK, PD3); // hodinovy button bitSet (GIMSK, INT1); // povoleni preruseni 1 bitSet(TCCR0B, CS02); // Clock prescaler (/ 256) bitSet(TIMSK, TOIE0); // povoleni preruseni od casovace sei(); // povoleni preruseni globalne while(1) { } return 0; }
Ke zdrojáku snad nemusím nic dodávat, komentáře jsou doufám srozumitelné. Kód zkompilujte a
nahrajte do čipu (návody jsou v již zmíněných článcích). Pokud jste se rozhodli nic nepočítat a
používat 8MHz, je nutné ještě upravit pojistku (odstranit CKDIV8 bit):
avrdude -c dapa -p
t2313 -U lfuse:w:0xE4:m
(pokud používáte jiný programátor, upravte příkaz podle
svého).
Tady přichází ta zajímavější část - součástky pozapojujte podle schématu (POZOR: piny nejsou poporade, ridte se cislovnim - viz datasheet[PDF]).
Zapojte napájení a mělo by to fungovat. :) Dioda D1 svítí každou sudou vteřinu, diody D2-D7 ukazují hodiny a D8-12 minuty. Tlačítkem T1 nastavujete minuty, T2 hodiny a RESET je reset.
A to je pro dnešek vše, přátelé. Jen se na ty hodiny raději moc nespoléhejte, pochybuju, že budou přesné :D
P.S.0: takhle to vypadá u mě:
Místo jednoho kondenzátoru mám 4 menší a na desce v prvém horním rohu jsou vývody "programátoru" (na paralelní port).
P.S.1: Nekamenujte me, je to moje prvni ubastlena hracka :)
P.S.2: Jeste doplnim info o spotrebe, pokud by nekoho zajimala: cca 13mA pri vetsine rozsvicenych diod a napeti 2.7V
Tiskni
Sdílej:
Ke zdrojáku snad nemusím nic dodávat, komentáře jsou doufám srozumitelné.1) SIGNAL je deprecated. V novém kódu se má používat ISR. 2) Funkce showMins() je krásná ukázka toho, jak se dá naprosto jednoduchá věc udělat zbytečně složitě. Tohle bude fungovat podstatně efektivněji:
void showMins (unsigned char m) { m <<= 1; if (PORTB & (1 << PORTB0)) m |= 1; m &= 0x7e; //vynuluje bity, které nejsou součástí minut PORTB = m; }(unsigned char je stejně velká, jako short; u short si nejsem jistý, jestli není znaménkové) 3) Přerušení nastavuješ divně:
bitSet (PCMSK, PD2); // minutovy button bitSet (PCMSK, PD3); // hodinovy buttonjsou přerušení na změnu stavu logické hodnoty na pinu (PCINT). Ty ale používáš (a obsluhuješ) signál vnějšího přerušení (INTx). Tato dvě nastavení jsou tedy zbytečná, protože nemají na nic vliv.
1) nevedel jsemhttp://www.nongnu.org/avr-libc/user-manual/group__avr__interrupts.html Úplně dole.
Diky moc :) Rad se poucim :)Není zač. Rád pomůžu - čím víc lidí bude umět s AVR, tím víc lidí si je bude kupovat a používat a tím budou levnější.
- pouzitie non-isp jednocipaku v roku 2008Co to znamena?
- pouzitie modrych supersvietivych led (neznasam ich)Myslim, ze te nikdo neomezuje v tom, tam dat treba zeleny matny nebo fialovo-zluty polomatny s cervenejma puntikama...
- pouzitie non-isp jednocipaku v roku 2008- a proc ne? Doma se mi jich par valelo, tak proc kupovat?
- pouzitie modrych supersvietivych led (neznasam ich)- ale v cerny krabici (pokud to tam nekdy zadrtuju) to bude vypadat skvele!
- pouzitie non-isp jednocipaku v roku 2008Tak to v Atmelu museli od doby, co jsem s Attiny2313 pracoval, to ISP vymontovat.
avrdude -c dapa -p t2313 -t
používají se 2 příkazy: write lfuse 0 hodnota
a read lfuse 0 1
(hodnota může být v decimálním tvaru nebo v hexa 0x..)
V tomhle režimu můžeš hodnotu pomocí write zapsat a pomocí read si potom přečíst, co se skutečně zapsalo. Stejným způsobem můžeš číst/psát do hfuse.
Terminálový režim ukončíš příkazem quit
, pokud jsi změnil některou z hodnot, tak se tě bude ptát, jestli to skutečně myslíš vážně.
Máš dobře připojený ten krystal?Snad jo. Mezi vyvody XTAL1 a 2 a potom pres kondenzatory na zem (zkousel jsem dva krystaly, pro pripad, ze by jeden byl nefunkcni).
Jinak zkus tu hodnotu změnit v terminálovém režimu avrdude: avrdude -c dapa -p t2313 -t
Problem je, ze ten terminalovy rezim uz nespustim. AVRdude skonci, ze nemuze komunikovat s cipem. :( A riskovat dalsi se mi nechce :)
Problem je, ze ten terminalovy rezim uz nespustim. AVRdude skonci, ze nemuze komunikovat s cipem.Což to je mi jasné, myslel jsem vzít jiný čip. S tímhle bez paralelního programátoru nehneš, protože jestli jsi zapsal 0xff do hfuse, tak jsi zakázal programování přes ISP (tj. přes ty vývody MISO/MOSI/SCK) a s dapa programátorem (ani obdobnými) už si neškrtneš Ale i tak je to divný, protože jestli jsi zapsal 0xff do hfuse místo do lfuse, tak by pořád měl fungovat asopň program na vnitřní oscilátor.