FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.
K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.
Yazi je správce souborů běžící v terminálu. Napsán je v programovacím jazyce Rust. Podporuje asynchronní I/O operace. Vydán byl v nové verzi 25.12.29. Instalovat jej lze také ze Snapcraftu.
Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.
Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.
XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).
Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.
Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.
Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.
Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.
Asi před rokem vyšel na serveru AbcLinuxu článek Jana Martínka o programování jednočipů ATMEL pod linuxem: Jednočipy pod Linuxem.
Tento článek byl jistě pro mnohé začátečníky výborným seznámením s jednočipy. Od doby jeho vzniku se však změnila jedna věc. Jednočip AT90S2313, který je v článku použitý, přestala firma ATMEL vyrábět, a dnes je možné koupit jen jeho náhradu ATtiny2313. Ta má za stejné peníze několik příjemných vylepšení, bohužel však není s AT90S2313 kompatibilní a doposud chybí její podpora v některých vývojářských balíčcích (bohužel právě těch, které užívá zmíněný článek).
V tomto mini-howto bych proto rád popsal, jak nefunkční programy nahradit a jak obejít zmíněnou nekompatibilitu.
V citovaném článku se k nahrávání programu do mikročipu používá
program uisp. Ten si bohužel prozatím s tiny2313 neumí
poradit (nová verze jednočipu by měla používat zápis do flashe po blocích
na rozdíl od zápisu po bytech u AT90S2313). Řešením je použít
program avrdude.
S tímto programem je ovšem spojeno několik malých zádrhelů. Prvním z
nich je, že ve standardní distribuci chybí podpora právě pro to zapojení
programátoru, které používá uisp. Jelikož má ale
avrdude tu sympatickou vlastnost, že se zapojení programátoru
dá nastavit v konfiguračním souboru a není nutné jej znovu kompilovat,
pomoc je snadná: Stačí přidat do souboru /etc/avrdude tyto
řádky:
programmer id = "dapa"; desc = "Direct Parallel... as found in uisp..."; type = par; reset = 16; sck = 1; miso = 11; mosi = 2; ;
Program je potom do jednočipu možné nahrát následujícím příkazem:
avrdude -c dapa -p t2313 -U flash:w:helloworld.hex
Pokud používáme k nahrávání Makefile z článku, stačí nahradit
řádku s příkazem uisp za něco takovéhoto (připomínám, že
kvůli struktuře souboru Makefile musí být prvním znakem na řádce
tabulátor):
load: $(PROJECT).hex avrdude -c dapa -p t2313 -U flash:w:$(PROJECT).hex
Jednou z novinek, která se v ATtiny2313 objevila, je, že jednočip nepotřebuje už nutně externí krystal, neboť má v sobě integrován interní oscilátor. Špatnou zprávou ovšem je, že nám to rozhodí časování sériového portu. Při nastavení od výrobce totiž jednočip tepe pouze rychlostí 4/8Mhz, tj. 500kHz.
Abychom zapnuli externí krystal jako zdroj hodinového taktu, je
potřeba nastavit takzvané pojistky ("fuses"). Pro krystal s taktem
větším, než 8MHz a pro zařízení s pomalým náběhem proudu
by nastavení (s pomocí programu avrdude) vypadalo takto:
avrdude -c dapa -p t2313 -U lfuse:w:0xff:m
Jinými slovy "nižší byte pojistky" (Fuse Low Byte) je nastaven na hodnotu 0xff, což vykoná přesně to, co potřebujeme (standardní hodnota od výrobce je 0x62). POZOR, při každém experimentování s pojistkami se doporučuje důkladně prostudovat příslušný datasheet k jednočipu. Jinak bychom si také mohli vypnout programování přes sériové rozhraní, nebo udělat z pinu RESET další vstupně-výstupní linku. Pak bychom už do jednočipu bez speciálního programátoru žádný program nenahráli. Chtěl bych také upozornit na to, že tyto pojistky jsou u každého typu jednočipu jiné a je vždy třeba nahlédnout do příslušné dokumentace.
Avr-gcc zatím bohužel (pokud vím) nemá pro ATtiny2313 podporu.
Nová verze avr-gcc by měla být nekompatibilní se starší (například
by měla přestat fungovat makra sbi() a cbi()),
takže pokud máte již nějaké projekty pro AVR-ka rozdělané, nemusel
by přechod na novější verzi být tím pravým.
Naštěstí jsou si AT90S2313 a ATtiny2313 do velké míry podobné, takže některé jednodušší programy budou fungovat tak, jak jsou, u složitějších stačí provést drobné změny.
Nejpodstatnější změnou pro čtenáře zmíněného článku je fakt, že ATMEL v novém ATtiny2313 používá modernizované sériové rozhraní (které nazývá jako USART, oproti předchozímu UART). Zde je několik problémů s kompatibilitou.
Zaprvé má USART jinak pojmenované registry, dva má dokonce navíc. To je možné obejít tím, že si registry sami nadefinujeme, například takto:
#define UCSRA USR #define UCSRB UCR #define UBRRL UBRR #define UCSRC _SFR_IO8(0x03) #define UBRRH _SFR_IO8(0x02) // UCSRA #define UPE 2 #define U2X 1 // UCSRB #define MPCM 0 #define UCSZ2 2 // UCSRC #define UMSEL 6 #define UPM1 5 #define UPM0 4 #define USBS 3 #define UCSZ1 2 #define UCSZ0 1 #define UCPOL 0
Co se týče vlastního kódu, zůstává vše při starém, až na způsob, jakým USART inicializujeme. Nový způsob může vypadat asi nějak takto:
sbi(UCSRB, TXEN); // UCR -> UCSRB sbi(UCSRB, RXEN); sbi(UCSRC, UCSZ0); // 8bit přenos... sbi(UCSRC, UCSZ1); UBRRH = 0; // 9600 baudu, POZOR, nejdříve je třeba UBRRL = 59; // nastavit UBRRH, potom teprve UBRRL!
Jinou možností, jak zmíněnou nekompatibilitu obejít, je použít jiný jednočip: Konrétně ATmega8 je jen o málo dražší a přitom má daleko lepší parametry, než ATtiny2313. Je však třeba upozornit na to, že některé problémy nalezneme i u toho jednočipu: konkrétně je také nutno vypnout interní oscilátor a stejně tak používá ATmega8 již zmodernizovanou verzi sériového rozhraní.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
). Ale uisp je naprosto v pohodě...tak nevím.
Našel jsem jeden odkaz k věci: zde .-)
Přeji pěkný den, PIC.
Například na HW.cz linuxové věci moc neřeší.
Když už jsme u toho, docela by se hodily i clanky jak v linuxu ovladat napr. USB či LPT port. Článek na ovládání RS232 jsem tady už našel.
Přeji hodně úspěchů nejen s dalšími články .-)
pozor na makra sbi a cbi, boli odstranene z kniznic a ak mate aktualnu verziu, prekladac sa moze tvarit kyslo :] staci si ich nadefinovat odznova, ved su to len makra...Prosim te a jak mam nadefinovat ty makra?
--target=avr.
Instaloval jsem do adresare $HOME/local/avr. Vse krome avr-libc se nainstalovalo (takže počítám, že dobře). Avr-libc mě při make (i ./domake) vyhodil asi tři errory ohledně assembleru (že už nějaké makro bylo definováno nebo co)...Navíc jsem si při konfiguraci všimnul hlášky, že avr-gcc nepodporuje ATtiny2313 (přitom dám-li avr-gcc --target-help, je tam i MCU attiny2313).
Netuším co s tím. Děsně mě to se.... Takovej mamut jako gcc se zkompiluje a malej šmejd avr-libc dělá problémy. Progoogloval jsem snad celou sobotu a stejně jsem s tim nepohnul.
Mohl by mě někdo pls poradit?
Děkuji a PIC.
Včera jsem "zabil" celý den řešením tohoto problému. Měl jsem jediný problém a to při kompilaci avr-libc-1.2.3. Jak bylo uvedeno v návodu, je potřeba nejprve nainstalovat binutils, pak gcc a nakonec avr-libc.
Bohužel avr-libc šlo zkompilovat jen tehdy, pokud jsem měl nainstalovány binutils-2.15 a gcc-3.4.4. (jinak to při překladu hlásilo chybu). Při ./configure jsem si ale všimnul hlášky, že avr-gcc nepodporuje ATtiny2313 a ještě mnoho dalších (novějších). Zkusil jsem i něco přeložit s parametrem attiny2313, ale linker nenašel soubor myslím, že attn2313.o. Opravdu nikde nebyl.
Nastalo otravné hledání kombinace binutils, gcc a následné kompilace avr-libc (vždy instalace binutils ve verzích 2.15, 2.16 a 2.16.1, poté kompilace gcc ve verzích 3.4.4 a 4.0.0 a nakonec zkouška, zda se avr-libc přeloží). Naštěstí, jsem si pomocí checkinstall vytvořil rpm balíčky, takže testování bylo snadnější, ale gcc jsem musel vždy kompilovat pro momentální verzi nainstalovaných binutils. Snad jsem to popsal, tak, že se v tom nezamotáte .-)
Výsledek byl, jak už jsem zmínil, že avr-libc se podařilo přeložit jen při avr-binutils-2.15 a avr-gcc-3.4.4. Podpora ATtiny2313 nebyla k dispozici. To mě opravdu nepotěšilo
Nakonec jsem se rozhodl, že si nainstaluji nejnovější verzi avr-binutils-2.16.1 (už jsem je měl v rpm z předešlého testování) a avr-gcc-4.0.0. Avr-libc by zkompilovat sice nešlo, ale díky tomu, že jsem si už před tím udělal rpm balíček avr-libc-1.2.3 ("postaveného" na avr-binutils-2.15 a avr-gcc-3.4.4) nebyl žádný problém. Soubory se nahrály kam měli
O podpoře ATtiny2313 se mě mohlo jen zdát, neboť nebyl k dispozici soubor attn2313.o
Tak jsem začal pátrat na internetu po tomhle souboru a našel jsem ho v rpm balíčku pro 64-bit SuSE Linux (alespoň myslím, že to byl 64-bit). Poté další hlednání, jak balíček rozbalit, ale neinstalovat. Nakonec jsem se ke kýženému souboru (vlastně souborům) dostal. Vše co nebylo v mém nainstalovaném avr-libc jsem přidal z tohoto balíčku. Mno a teď to vypadá, že vše funguje jak má. Zdroják si přeložím i pro ATtiny2313, slinkuji (nebo jak to nazvat) a vytvořím intel hex. Ten úspěšně nahraji do čipu a ten pracuje jak ma. Uffff to bylo vyčerpávající....jestli jste došli až sem, tak gratuluji .-)
PIC