Proběhla hackerská soutěž Pwn2Own Ireland 2025. Celkově bylo vyplaceno 1 024 750 dolarů za 73 unikátních zranitelností nultého dne (0-day). Vítězný Summoning Team si odnesl 187 500 dolarů. Shrnutí po jednotlivých dnech na blogu Zero Day Initiative (1. den, 2. den a 3. den) a na YouTube.
Byl publikován říjnový přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Pracuje se na podpoře M3. Zanedlouho vyjde Fedora Asahi Remix 43. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.
Iniciativa Open Device Partnership (ODP) nedávno představila projekt Patina. Jedná se o implementaci UEFI firmwaru v Rustu. Vývoj probíhá na GitHubu. Zdrojové kódy jsou k dispozici pod licencí Apache 2.0. Nejnovější verze Patiny je 13.0.0.
Obrovská poptávka po plynových turbínách zapříčinila, že datová centra začala používat v generátorech dodávajících energii pro provoz AI staré dobré proudové letecké motory, konvertované na plyn. Jejich výhodou je, že jsou menší, lehčí a lépe udržovatelné než jejich průmyslové protějšky. Proto jsou ideální pro dočasné nebo mobilní použití.
Typst byl vydán ve verzi 0.14. Jedná se o rozšiřitelný značkovací jazyk a překladač pro vytváření dokumentů včetně odborných textů s matematickými vzorci, diagramy či bibliografií.
Specialisté společnosti ESET zaznamenali útočnou kampaň, která cílí na uživatele a uživatelky v Česku a na Slovensku. Útočníci po telefonu zmanipulují oběť ke stažení falešné aplikace údajně od České národní banky (ČNB) nebo Národní banky Slovenska (NBS), přiložení platební karty k telefonu a zadání PINu. Malware poté v reálném čase přenese data z karty útočníkovi, který je bezkontaktně zneužije u bankomatu nebo na platebním terminálu.
V Ubuntu 25.10 byl balíček základních nástrojů gnu-coreutils nahrazen balíčkem rust-coreutils se základními nástroji přepsanými do Rustu. Ukázalo se, že nový "date" znefunkčnil automatickou aktualizaci. Pro obnovu je nutno balíček rust-coreutils manuálně aktualizovat.
VST 3 je nově pod licencí MIT. S verzí 3.8.0 proběhlo přelicencování zdrojových kódů z licencí "Proprietary Steinberg VST3 License" a "General Public License (GPL) Version 3". VST (Virtual Studio Technology, Wikipedie) je softwarové rozhraní pro komunikaci mezi hostitelským programem a zásuvnými moduly (pluginy), kde tyto moduly slouží ke generování a úpravě digitálního audio signálu.
Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 25.10. Podrobný přehled novinek v poznámkách k vydání.
V Londýně probíhá dvoudenní Ubuntu Summit 25.10. Na programu je řada zajímavých přednášek. Zhlédnout je lze také na YouTube (23. 10. a 24. 10.).
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.