Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.
Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.
Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.
Byl vydán Mozilla Firefox 151.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 151 bude brzy k dispozici také na Flathubu a Snapcraftu.
Elon Musk prohrál soudní spor se společností OpenAI, která se podle jeho žaloby odchýlila od původně uváděného cíle vyvíjet umělou inteligenci (AI) ku prospěchu lidstva. Porota včera po necelých dvou hodinách dospěla k jednomyslnému závěru, že Musk žalobu podal příliš pozdě. Musk byl jedním ze spoluzakladatelů společnosti OpenAI, která vznikla v roce 2015 a vyvinula populární chatovací systém ChatGPT. V roce 2018 na svůj post ve vedení
… více »Byla vydána nová verze 10.4 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Opraveny jsou zranitelnosti Copy Fail a Dirty Frag. Přibyl nový obraz pro Orange Pi 5B.
Pokud je zranitelnost Linuxu v nepoužívaném jaderném modulu, lze ji jednoduše vyřešit zakázáním automatického načítání tohoto konkrétního zranitelného modulu. Projekt ModuleJail si klade za cíl zvýšit bezpečnost Linuxu zakázáním automatického načítání všech nepoužívaných jaderných modulů. Jedná se o skript, který dá všechny nepoužívané jaderné moduly na blacklist (/etc/modprobe.d/modulejail-blacklist.conf).
Odborníci z Penn State University zkoumají způsob ukládání informací na lepicí pásku. Principiálně by podle nich bylo možné kombinací odlepení a zpětného přilepení dosáhnout uložení informace, kterou opětovným odlepením dokážou přečíst. Výhodou je, že způsob uložení i přečtení je čistě mechanický. Zde o tom referují ve volně dostupném článku. Zajímavé bude sledovat zda se jim v rámci výzkumu podaří prokázat použitelnost i v jiné než
… více »Na GitHubu byl publikován reprodukovatelný návod, jak rozchodit Adobe Lightroom CC na Linuxu a Wine. Návod byl vytvořený pomocí AI Claude Code.
Mám aplikaci v avr pro atmega16. Zatím zkouším přesně měřit otáčky. Měřím způsobem, že počítám čas mezi pulsy a pak kolik je pulsů do sekundy. Problém je, že zřejmě pokud zrovna atmega přijímá nějaká data přes sériovou linku, tak asi nemůže běžet přerušení pro měření otáček, které běží Xkrát za sekundu. Proto jsou výsledné hodnoty např. 550 +-30. Co s tím? Jak nastavit, aby přerušení pro měření otáček mohlo přerušit cokoliv jiného a tudíš nedocházelo ke zpožděním?
Nebo i v té obsluze seriového portu nejdříve počítat otáčky.
Teď tam mám krystal 14.7456 MHz, což je nejrychlejší co tam mohu dát aby se to dobře dělilo.
Tak v ostatních přerušeních problém asi nebude. Vypnul jsem je totiž a povolil jen to, kde se měří otáčky a ještě je povolené přerušení od sériového portu, ale vyrubal jsem odtamtud všechen kód. Co mám tedy špatně? Měřím nějak špatně otáčky? Vím, že bych měl měřit přes několik pulsů, ale zkouším odchylku v tom jednom a ta je +- 5 cyklů, což ve výsledku dává docela velikou odchylku v rychlosti. Zde jsou povolená přerušení:
ISR(TIMER2_OVF_vect) {
TCNT2=255; // 14.7456MHz/1024/1=14400 preruseni/sec
longac++;
if (longac>=2880) {
longac=0;
longacDOit=1;
}
if (longac10<288001) longac10++;
if (longac10==288000) {
//longac10=0;
longac10DOit=1;
OCR1A=0;
}
if (longac10==1) {
OCR1A=300;
}
pulsecounterL++;
if (bit_is_set(PIND, 6) && ! speedLcounted1) {
pulseL++;
speedLcounted3 = 0;
speedLcounted1 = 1;
}
if (bit_is_set(PIND, 7) && ! speedLcounted2) {
pulseL++;
speedLcounted4 = 0;
speedLcounted2 = 1;
}
if (bit_is_clear(PIND, 6) && ! speedLcounted3) {
pulseL++;
speedLcounted1 = 0;
speedLcounted3 = 1;
}
if (bit_is_clear(PIND, 7) && ! speedLcounted4) {
pulseL++;
speedLcounted2 = 0;
speedLcounted4 = 1;
}
if (pulseL>=1 || pulsecounterL>=14400) {
//finalSpeedL = (pulseL*(14400000/pulsecounterL))/1000;
finalSpeedL=pulsecounterL; // pro ladeni, zobrazi jen kolik cyklu mezi 2 pulsy
pulsecounterL = 0;
pulseL = 0;
}
if (speedLcounted1 && speedLcounted2) {
if (!speedLdirTest) speedLdir = 1; else speedLdir = 0;
}
if (speedLcounted1 && ! speedLcounted2) {
speedLdirTest=0;
}
if (! speedLcounted1 && speedLcounted2) {
speedLdirTest=1;
}
}
// preruseni po prichodu noveho znaku na USART
// novy byte zapise do pozice 0, ostatni posune o 1 vyse = FIFO fornta
// po prichodu \n nastavi priznak enteru - je zpracovan v main()
ISR(USART_RXC_vect) {
unsigned char status,data,i;
}
Zkusim zvysit frekvenci odecitani. Mohlo by pomoct.
ISR(INT0_vect) {
pin1set = bit_is_set(PIND, 2);
pulseL++;
// zde kód pro určení směru
}
Analogicky pro ISR(INT1_vect), v přerušení od časovače by sis jenom přečetl to, kolik pulsů se za daný interval přečetlo. Samozřejmě je nutné mít proměnné deklarované jako volatile tam, kde je to potřeba.
Tiskni
Sdílej: