V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 15.0 (Mastodon). Forgejo je fork Gitei.
Současně se SUSECON 2026 proběhne příští čtvrtek v Praze také komunitní Open Developer Summit (ODS) zaměřený na open source a openSUSE. Akce se koná ve čtvrtek 23. 4. (poslední den SUSECONu) v Hilton Prague (místnost Berlin 3) a je zcela zdarma, bez nutnosti registrace na SUSECON. Na programu jsou témata jako automatizace (AutoYaST), DevOps, AI v terminálu, bezpečnost, RISC-V nebo image-based systémy. Všichni jste srdečně zváni.
Český úřad zeměměřický a katastrální zavedl u anonymního nahlížení do katastru nemovitostí novou CAPTCHA ve formě mapové puzzle: nepřihlášení uživatelé musí nově správně otočit devět dlaždic v 3x3 poli tak, aby dohromady daly souvislý obrázek výseče reálné mapy, přičemž na to mají pouze jeden časově omezený pokus. Test je podle uživatelů i odborníků příliš obtížný a na sociálních sítích pochopitelně schytává zaslouženou kritiku a
… více »Byla vydána verze 1.95.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.
Mozilla prostřednictvím své dceřiné společnosti MZLA Technologies Corporation představila open-source AI klienta Thunderbolt. Primárně je určený pro firemní nasazení.
Firma Cal.com oznámila, že přesouvá svůj produkční kód z otevřeného do uzavřeného repozitáře z důvodu bezpečnostního rizika umělé inteligence, která prý dokáže vyhledávat a zneužívat zranitelnosti rychleji, než by je jejich vývojářský tým stíhal opravovat. Zároveň zveřejnila samostatnou, open-source verzi Cal.diy pod licencí MIT, ovšem bez řady původních funkcí. O tom, zda je toto opatření rozumné, existují pochyby. … více »
Vývojáři KDE na Mastodonu oznámili vydání balíku aplikací KDE Gear 26.04. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Kryptografická knihovna OpenSSL byla vydána v nové verzi 4.0. Přehled změn v souboru CHANGES.md na GitHubu. Odstraněna byla podpora SSLv2 Client Hello a SSLv3. Ve výchozím nastavení byla zakázána podpora odmítnutých eliptických křivek v TLS dle RFC 8422. Přibyla například podpora Encrypted Client Hello (ECH, RFC 9849).
curl up 2026, tj. setkání vývojářů a uživatelů curlu, proběhne opět v Praze. O víkendu 23. a 24. května v Pracovně.
Aplikace pro ověřování věku uživatelů on-line platforem je technicky hotová a brzy bude k dispozici pro občany EU, oznámila dnes předsedkyně Evropské komise Ursula von der Leyenová. Půjde podle ní o bezplatné a snadno použitelné řešení, které pomůže chránit děti před škodlivým a nelegálním obsahem. Aplikace bude podle ní fungovat na jakémkoli zařízení a bude zcela anonymní.
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:
Jen pockejte, zajicove, jednou Vam v susi soutezi ukazu, co jsou to opravdove binarni hodiny
.
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 -tProblem 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.