Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.
Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na
… více »Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.
Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.
Byl zveřejněn program konference Installfest 2026. Konference proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13. Vstup zdarma.
Byla vydána Java 26 / JDK 26. Nových vlastností (JEP - JDK Enhancement Proposal) je 10. Odstraněno bylo Applet API.
Byla vydána nová verze 260 správce systému a služeb systemd (Wikipedie, GitHub). Odstraněna byla podpora skriptů System V. Aktualizovány byly závislosti. Minimální verze Linuxu z 5.4 na 5.10, OpenSSL z 1.1.0 na 3.0.0, Pythonu z 3.7.0 na 3.9.0…
Byla vydána nová verze 5.1 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v poznámkách k vydání. Videopředstavení na YouTube.
Bylo oznámeno vydání nové verze 8.1 "Hoare" kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Doprovodný příspěvek na blogu Khronosu rozebírá kódování a dekódování videa pomocí Vulkan Compute Shaders v FFmpeg.
Byl představen open-source a open-hardware prototyp nízkonákladového raketometu kategorie MANPADS, který byl sestaven z běžně dostupné elektroniky a komponent vytištěných na 3D tiskárně. Raketa využívá skládací stabilizační křidélka a canardovou stabilizaci aktivně řízenou palubním letovým počítačem ESP32, vybaveným inerciální měřicí jednotkou MPU6050 (gyroskop a akcelerometr). Přenosné odpalovací zařízení obsahuje GPS,
… více »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.