AVR vs 32b (Začínáme s Atmel Studiem - kontrola)

Pavel Hudecek edizon na seznam.cz
Pátek Únor 5 17:48:23 CET 2021


Těch 5 V je ve skutečnosti značná výhoda. Dnes má každej doma hromadu 5 V adaptérů, takže stačí připojit. Nebo připojit Li-ionku. Těch mají děti taky dost, ze starých NTB, nebo telefonů.

Jinak zásadně učím děti, že jde spoustu věcí, ale je vždy potřeba řešit, zda je to dobrý nápad a co to obnáší. Takže ano, MOSFET přes Rg rovnou na pin procesoru. Ale ještě předtím najít takový MOSFET, aby ho šlo 5V spolehlivě otvírat a proud, který si dle DS od MCU lze dovolit stačil na dostatečně rychlé nabíjení a vybíjení jeho kapacity. Při tom se hned dá ukázat, jak do toho kecá kapacita zpětnovazební. No a samozřejmě jsou věci, kde se hodí, aby MCU jen ovládal nějakej zdrojovej šváb a řešit, do jaký míry mu do toho kecat. Takových 300 kHz se sice dá vytáhnout z AVR i z STM32, ale obojí bude mít nepoužitelně malé rozlišení na regulaci. Ovšem v obojím případě stačí třeba na nastavení deadtime.

Stejně tak lze třeba LED displej připojit přímo na port a jen společné konce spínat tranzistorama. Dá se moc hezky ukázat, co se děje, když se to udělá špatně a jak to udělat správně, takže pak hodiny jdou přesně a ADC měří normálně. A že to je jednodušší, pokud se na port segmentů dají odpory, ale za cenu nutnosti použít různá napětí dle barvy displeje to jde i bez nich.

Ale zpátky k rozdílům  v SW: Na ARMy se normálně používá rozsáhlej ekosystém s hromadou .h souborů a udělat něco bez toho je dost složitý. Zajímavý je, že třeba na LPC to je celkem hezký a dá se v tom snadno zorientovat, podobně je na tom o hodně mohutnější AM335, ale na STM32 mají všechno na můj vkus hodně komplikovaný, takže mnohem radši použiju LPC než STM.

A jsou samozřejmě situace, kdy je 32b jasná volba, třeba grafické displeje. Když na 100nohej LPC připojím displej tak, že má na jednom portu 0-17 paralelní data a na dalších bitech i řídící signály, lze přenášet řádově desítky MPx/s (reálně míň, protože ty data taky nějak vznikaj, což zabere většinu času). Na 8bitu se lze dohadovat, zda je rychlejší SPI, nebo paralel 8bit. Jelikož jsem na obojím zkoušel osciloskop 320x240, vím o čem píšu:-)

PH

Od: Miroslav Mraz
Těch 5V je asi jediná výhoda. Co se týče hodin, když procesor spustíte, 
má nějaké hodiny nastaveny - musí minimálně umět spustit kód z flash. 
Když se s tím spokojíte, můžete se na clock tree v zásadě vykašlat. 
Periferie mají zdánlivě hodně bitů k nastavení, ale většinou stačí 
nastavit jich jen minimum, aby to fungovalo.
Co se týká návrhu desky a její realizace, začátečníci stejně použijí 
nějaký modul a pokročilí s tím nemají zase takový problém. SWD/USB 
adaptér seženete za pár šupů nebo si můžete udělat klon Blackmagic a 
velká výhoda je, že debug s ním vám přímo ukáže, co se v CPU děje. 
Prostě setrvávat u 8-bitů už nemá moc velký smysl.
Ostatně učit děti, že MOSFET jde budit přímo pinem procesoru asi také 
není úplně nejlepší nápad. Měly by si zvykat, že svět elektroniky je 
poměrně složitý a součástky nají bohužel i vlastnosti, které se moc 
nehodí, ale je nutné s nimi počítat.

Mrazík

Dne 05. 02. 21 v 3:27 Pavel Hudecek napsal(a):
> Konkrétně AVRka mají výhodu, že mají silné výstupy a 5 V. Pokud to někdo 
> nezkazí tak jako zde v tématu s Arduinem a motorem, není problém z AVR 
> řídit MOSFET a to i třeba na pár desítek kHz.
> 
> Menší náročnost na návrh desky.
> 
> Žádné složitosti u generování hodin. Nerad bych vysvětloval dětem clock 
> controller v STM32:-)
> 
> Další věc jsou dražší programovací prostředky na 32bity.
> 
> A teda abych pravdu řek, na AVR jsem schopen jen podle koukání do 
> „register description“ napsat prakticky všechno, na ARM zpravidla začnu 
> od předgenerovaného projektu, kde je mnoho věcí, které všechny 
> prozkoumat by zabralo moc času.
------------- další část ---------------
HTML příloha byla odstraněna...
URL: <http://list.hw.cz/pipermail/hw-list/attachments/20210205/7d01b952/attachment.html>


Další informace o konferenci Hw-list