Předělání switche na 10Mbit-FD: Porovnání verzí
m (Stránka PÅ™edÄ›lánà switche na 10Mbit-FD přemístěna na stránku Předělání switche na 10Mbit-FD) |
|||
(Není zobrazeno 45 mezilehlých verzí od 5 dalších uživatelů.) | |||
Řádek 1: | Řádek 1: | ||
+ | 1. způsob dal dohromady Cipis, cipis[at]cipis[dot]net, včetně poskytnutí fotografií jím sesmoleného switche. | ||
+ | |||
+ | Autorem 2. způsobu je Jaroslav Pajskr. jarda[dot]pajskr[at]tiscali[dot]cz pro případné dotazy. | ||
==Obecně== | ==Obecně== | ||
− | 2 způsoby jak nastavit port na 10Mbit-FD u switche. Využitelné např. pro připojeni ronji. | + | 2 způsoby jak nastavit port na 10Mbit-FD u switche. Využitelné např. pro připojeni ronji (pozn. některé provedení ronji vyžadují, nastavení MDI/MDI-X switche). |
− | * 1. způsob - Spojení nožiček | + | * 1. způsob - Spojení nožiček chipu byl převzat z fóra CZF a news HKF (funguje jen s chipem RTL8305SB nebo SC = 5port switch) |
− | * 2. způsob - | + | * 2. způsob - Změna hodnot interních konfiguračních registrů chipu pomocí externího procesr (mel by fungovat i s jiným chipem = i vetší než 5-port switch) |
− | |||
− | ==1 | + | ==Způsob 1 - Spojení nožiček chipu== |
* pouze s chipem RTL8305SB (SC) | * pouze s chipem RTL8305SB (SC) | ||
− | * např. Edimax ES-3105P (pouze 5port) | + | * např. Edimax ES-3105P (pouze 5port) nebo Genius GS4050 mini (5-port) |
* datasheet [http://www.realtek.com.tw/downloads/downloads1-3.aspx?spec=True&compamodel=RTL8305SB RTL8305SB] a [http://www.realtek.com.tw/downloads/downloads1-3.aspx?spec=True&compamodel=RTL8305SC RTL8305SC] | * datasheet [http://www.realtek.com.tw/downloads/downloads1-3.aspx?spec=True&compamodel=RTL8305SB RTL8305SB] a [http://www.realtek.com.tw/downloads/downloads1-3.aspx?spec=True&compamodel=RTL8305SC RTL8305SC] | ||
* default je 1, 0 je slus na zem | * default je 1, 0 je slus na zem | ||
+ | [[Soubor:Rtl8305sb.JPG|thumb|předělaný switch]] | ||
+ | * výtah z datasheetu: | ||
− | + | <bash> | |
− | pin 95: 1 - skupina x - port 0 | + | pin 95: |
− | + | 1 - skupina x - port 0, skupina y - port 1, 2 a 3 | |
− | skupina y - port 1, 2 a 3 | + | 0 - skupina x - port 0 a 1, skupina y - port 2 a 3 |
− | |||
− | 0 - skupina x - port 0 a 1 | ||
− | |||
− | skupina y - port 2 a 3 | ||
− | port0 je na 3, 4, 127, 128 (u | + | port0 je na 3, 4, 127, 128 (u růžku s klíčem) |
port1 je na 7, 8, 11, 12 | port1 je na 7, 8, 11, 12 | ||
Řádek 29: | Řádek 29: | ||
port3 je na 23, 24, 27, 28 | port3 je na 23, 24, 27, 28 | ||
− | port4 je na 31, 32, 35, 36 (port4 je | + | port4 je na 31, 32, 35, 36 (port4 je special, měl by zůstat auto) |
Řádek 49: | Řádek 49: | ||
pin 110: 1 - enable FullDuplex skupiny y | pin 110: 1 - enable FullDuplex skupiny y | ||
0 - disable | 0 - disable | ||
+ | </bash> | ||
+ | |||
+ | * Když nohy 104,105,107,108 vyzkratujete na zem, tak bude mít switch jeden 100Mbit port a 4x 10Mbit-FD porty. | ||
+ | * Pozor na vedlejší efekt, budou svítit neustále diody. | ||
+ | |||
+ | ==Způsob 2 - Přeprogramovaní chipu pomocí externího procesoru== | ||
+ | Chip se může také kofigurovat pomocí SMI sběrnice. Pravidla komunikace po této sběrnici jsou uvedeny v katalogovém listu chipu na '''str119'''. Tuto sběrnici mají i více portové switche a ty lze je tímto způsobem také konfigurovat. To znamená, že i u 8 portového switche lze předělat do reřimu 10Mbit-FD libovolný počet portů. | ||
+ | |||
+ | Co je protřeba: | ||
+ | * procesor + 2 odpory 1,5kOhm | ||
+ | * programátor | ||
+ | * software [http://www.lancos.com/ppwin95.html Ponyprog] pro naprogramování procesoru a [http://www.atmel.com/dyn/products/tools_card.asp?tool_id=2725 AVR Studio] pro případnou změnu nastavení | ||
+ | |||
+ | |||
+ | Po SMI sběrnici se mohou data z obvodu číst nebo zapisovat. Jestli se bude zapisovat nebo číst se rozliší v úvodu vysílaných dat. Taky se zde musí uvést číslo banky registrů - '''PHY0-PHY5''' a číslo registru '''0 - 31''', se kterým se bude pracovat. | ||
+ | |||
+ | Aby se upravil PORT4 na 10Base FD musí se v bance registrů 4 - PHY4 s binárním kódem 00100: | ||
− | * | + | v registru 0 - '''str53''', binární kód registru je 00000 |
+ | * vypnout autonegotiation - znulovat 12tý bit | ||
+ | * povolit 10MB - znulovat 13tý bit | ||
+ | * zapnout full duplex - nastavit 8 bit. | ||
+ | |||
+ | v registru 4 - '''str55''', binární kód registru je 00100 | ||
+ | * povolit pouze 10Base FD znulovat 5,7,8 bit | ||
+ | * nastavit 6 bit | ||
− | |||
− | + | Bylo by dobré neměnit ostatní bity, proto se nejprave data z chipu přečtou, pozmění a pak zpátky zapíší. | |
+ | V katalogovém listu chipu na '''str119''' je uvedeno uspořádání posílaných dat. Prvních 32 taktů jsou 1. poslání adresy registru 0 by se dalo binárně zapsat: | ||
− | + | <bash> | |
− | + | CH CL | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
pro čtení 01100010 00000010 | pro čtení 01100010 00000010 | ||
pro zápis 01010010 00000010 | pro zápis 01010010 00000010 | ||
− | - 4 -- 0 | + | - 4 -- 0 - |
+ | </bash> | ||
+ | |||
dalších 16 taktů se posílají data. | dalších 16 taktů se posílají data. | ||
− | Nejjednodušší způsob, jak data poslat do IO, je pomocí naprogramovaného procesoru. Já jsem se zabýval programováním procesorů ATMEL AVR, proto jsem vytvořil program pro zápis dat i čtení pro procesor této řady. Svým vybavením plně vyhovuje procesor ATtiny12L, ale může se použít skoro jakýkoliv. Procesor se vyrábí v provedení SMD | + | |
− | Program procesoru je napsaný v assembleru. Pro čtení a zápis jsou vytvořeny 2 funkce – nacti a uloz. Funkce delay je pouze určité zpoždění mezi jednotlivými operacemi. Původně to sloužilo ke zpožděné konfiguraci po připojení napájení, ale v programu je tato funkce provedena mezi jednotlivými operacemi. Práce s funkcemi je velmi jednoduchá. Před vykonáním funkce se musí nejprve zapsat adresa do registrů CL, CH a poté vykonat funkce. Adresa CL a CH nemusí obsahovat informaci o tom, jestli se zapíší data nebo se budou číst. Funkce zapíší sekvence pro čtení a zápis. Nejvyšší 4 bity CH jsou ignorovány. | + | |
− | Po přečtení dat z IO se musí provést nastavení. Vynulování bitů se provede instrukcí CBR podle masky a nastavení bitů se provede instrukcí SBR podle masky. Doufám, že funkce těchto dvou instrukcí jsou dostatečně zřejmé ze samotného programu. | + | Nejjednodušší způsob, jak data poslat do IO, je pomocí naprogramovaného procesoru. Já jsem se zabýval programováním procesorů ''ATMEL AVR'', proto jsem vytvořil program pro zápis dat i čtení pro procesor této řady. Svým vybavením plně vyhovuje procesor ''ATtiny12L'', ale může se použít skoro jakýkoliv. Cena procesoru ATtiny12L je v GMku 28kč |
+ | |||
+ | Procesor se vyrábí v provedení DIL8 i v SMD provedení. Procesor V SMD provedení je možné přiletovat místo EEPROMky, se kterou je na desce switche počítáno, ale nebývá osazena. Pro připojení procesoru jsou nutné 4 vývody – z toho 2 jsou napájení a 2 pro přenos dat. | ||
+ | |||
+ | |||
+ | Program procesoru je napsaný v assembleru. Pro čtení a zápis jsou vytvořeny 2 funkce – ''nacti'' a ''uloz''. Funkce ''delay'' je pouze určité zpoždění mezi jednotlivými operacemi. Původně to sloužilo ke zpožděné konfiguraci po připojení napájení, ale v programu je tato funkce provedena mezi jednotlivými operacemi. Práce s funkcemi je velmi jednoduchá. | ||
+ | |||
+ | Před vykonáním funkce se musí nejprve zapsat adresa do registrů ''CL'', ''CH'' a poté vykonat funkce. Adresa ''CL'' a ''CH'' nemusí obsahovat informaci o tom, jestli se zapíší data nebo se budou číst. Funkce zapíší sekvence pro čtení a zápis. Nejvyšší 4 bity ''CH'' jsou ignorovány. | ||
+ | |||
+ | |||
+ | Po přečtení dat z IO se musí provést nastavení. Vynulování bitů se provede instrukcí ''CBR'' podle masky a nastavení bitů se provede instrukcí ''SBR'' podle masky. Doufám, že funkce těchto dvou instrukcí jsou dostatečně zřejmé ze samotného programu. | ||
Po zápisu posledního byte do registrů program skočí do nekonečné smyčky. | Po zápisu posledního byte do registrů program skočí do nekonečné smyčky. | ||
+ | |||
+ | |||
Poslední část programu nazvaná kontrola se v běžném režimu nepoužívá. Slouží pro kontrolu zapsaných dat do IO. Na nevyužitých dvou vývodech se začne periodicky vysílat sériově přečtená data. Na dvoukanálovém osciloskopu se pak může na tyto data podívat. | Poslední část programu nazvaná kontrola se v běžném režimu nepoužívá. Slouží pro kontrolu zapsaných dat do IO. Na nevyužitých dvou vývodech se začne periodicky vysílat sériově přečtená data. Na dvoukanálovém osciloskopu se pak může na tyto data podívat. | ||
+ | |||
+ | '''Připojení procesoru k IO''' | ||
+ | |||
+ | [[Soubor:Pripojeni procesoru.png|připojení procesoru]] | ||
+ | |||
+ | |||
+ | '''Detail''' | ||
+ | |||
+ | [[Soubor:Pripojeni_detail.png|připojení procesoru]] | ||
+ | |||
+ | |||
+ | V případě, že bude použit procesor v provedení ''SMD'' musí se zamezit spojení vývodu ''1'' procesoru s deskou switche a tento volný vývod procesoru připojit na napájení – vývod ''8'' procesoru. | ||
+ | |||
+ | Když by byl procesor použit v provedení ''DIL8'', je dobré přiletovat patici ''DIL8'' k desce switche pomocí drátků a procesor pouze dát do patice – když by bylo potřeba procesor přeprogramovat lze pak procesor z patice snadno vydloubnout. | ||
+ | |||
+ | |||
+ | === Programátor === | ||
+ | |||
+ | ---- | ||
+ | |||
+ | [[Soubor:Dil81.png|thumb|procesor v DIL8]] | ||
+ | |||
+ | [[Soubor:Dil82.png|thumb|procesor v DIL8]] | ||
+ | |||
+ | [[Soubor:Smd1.png|thumb|procesor v SMD]] | ||
+ | |||
+ | [[Soubor:Smd2.png|thumb|procesor v SMD]] | ||
+ | |||
+ | [[Soubor:Programator1.jpg|thumb|výsledek]] | ||
+ | |||
+ | |||
+ | * Programátor lze vyrobit vzdušné konstrukce. Když by byl potřeba naprogramovat procesor v SMD provedení, pak by byl problém připojit procesor k programátoru. Je možné vyrobit PCB. | ||
+ | |||
+ | |||
+ | Návrh desky je vytvořen v programu [http://www.cadsoft.de/cgi-bin/download.pl?page=/home/cadsoft/html_public/download.htm.en&dir=eagle/program/4.1 Eagle V4.15 light] | ||
+ | |||
+ | |||
+ | * Verze pro procesor v DIL8 | ||
+ | |||
+ | [http://lide.hkfree.org/~reaper/ronja/switch/programator_ATtiny12.brd programator ATtiny12.brd] | ||
+ | |||
+ | [http://lide.hkfree.org/~reaper/ronja/switch/programator_ATtiny12.brd programator ATtiny12.sch] | ||
+ | |||
+ | |||
+ | *Nebo pro procesor v SMD provedení | ||
+ | |||
+ | [http://lide.hkfree.org/~reaper/ronja/switch/programator_ATtiny12.brd programator ATtiny12SMD.brd] | ||
+ | |||
+ | [http://lide.hkfree.org/~reaper/ronja/switch/programator_ATtiny12.brd programator ATtiny12SMD.sch] | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | '''Schéma programátoru''' | ||
+ | |||
+ | [[Soubor:Programator.png]] | ||
+ | |||
+ | === Software === | ||
+ | ---- | ||
+ | |||
+ | |||
+ | ==== ''Programování procesoru'' ==== | ||
+ | |||
+ | * Procesor je možné naprogramovat pomocí programu [http://www.lancos.com/ppwin95.html Ponyprog] | ||
+ | |||
+ | [http://lide.hkfree.org/~reaper/ronja/switch/konfsw.hex konfigurační soubor] | ||
+ | |||
+ | Tento program je odzkoušen v 5-ti portovém switchi a předělá PORT4 chipu do režimu 10MBit FD. | ||
+ | |||
+ | pozn. PORT4 chipu nemusí být stejně označen na switchi. U předělaného switche se změnil port na switchi označený jako 1. | ||
+ | |||
+ | Pro snadné určení předělaného portu stačí zkusit krajové porty - jeden by to měl být. | ||
+ | |||
+ | |||
+ | Po nainstalování je potřeba zvolit port COM1 v ''setup->interface setup'' | ||
+ | |||
+ | [[Soubor:Pony1.png]] | ||
+ | |||
+ | |||
+ | |||
+ | Dále je potřeba zvolit procesor – ''device->AVR micro->ATtiny12'' | ||
+ | Poté se může načíst HEX soubor – ''file->open program file'', zvolit ''HEX''. | ||
+ | Když by se programování nepovedlo na poprvé, případně bylo potřeba procesor přeprogramovat musí se před programováním procesor vymazat – ''command->erase'' a pak až procesor naprogramovat. | ||
+ | |||
+ | [[Soubor:Pony2.png]] | ||
+ | |||
+ | |||
+ | |||
+ | Procesor se pak naprogramuje – ''command->write program'' | ||
+ | Nyní by měl být program v procesoru. Další věc, co není nutná, ale bylo by dobré ji nastavit, je zapnutí ochrany proti malému napětí. Procesor se pak sám restartuje když klesne napětí pod určitou mez. Je to určitá ochrana proti zkolabování programu. Tato ochrana se zapne v nabídce ''command->security'' and ''configuration bits'', zde se nejprve zvolí ''read'', pak se ''BODLEVEL'' a ''BODEN'' vynulují a opět pomocí ''write'' zapíše | ||
+ | |||
+ | [[Soubor:Pony3.png]] | ||
+ | |||
+ | ==== ''Změna nastavení'' ==== | ||
+ | |||
+ | * Pokud by chtěl někdo změnit nastavení, musí přepsat program v assembleru. program se poté musí zkompilovat – převést do HEX souboru. Já používám [http://www.atmel.com/dyn/products/tools_card.asp?tool_id=2725 AVR Studio]. | ||
+ | |||
+ | [http://lide.hkfree.org/~reaper/ronja/switch/konfsw.asm konfigurační soubor] | ||
+ | |||
+ | |||
+ | Zde se musí nejprve vytvořit projekt a poté vložit program v assembleru do vytvořeného projektu. | ||
+ | |||
+ | [[Soubor:Avr1.png]] | ||
+ | |||
+ | |||
+ | Nazvat projekt | ||
+ | |||
+ | [[Soubor:Avr2.png]] | ||
+ | |||
+ | |||
+ | Vybrat procesor a kliknout na ''finish'' | ||
+ | |||
+ | [[Soubor:Avr3.png]] | ||
+ | |||
+ | |||
+ | Dále se objeví prázdné okno, do kterého se píše program a kam se může jednoduše zkopírovat zdrojový program | ||
+ | |||
+ | [[Soubor:Avr4.png]] | ||
+ | |||
+ | |||
+ | Po úpravě se program přeloží – ''build->build''. právně zkompilovaný program vypadá takto | ||
+ | |||
+ | [[Soubor:Avr5.png]] | ||
+ | |||
+ | |||
+ | |||
+ | == Výsledek == | ||
+ | [[Soubor:Final1.jpg|thumb|výsledek]] |
Aktuální verze z 17. 1. 2009, 17:50
1. způsob dal dohromady Cipis, cipis[at]cipis[dot]net, včetně poskytnutí fotografií jím sesmoleného switche.
Autorem 2. způsobu je Jaroslav Pajskr. jarda[dot]pajskr[at]tiscali[dot]cz pro případné dotazy.
Obsah
Obecně
2 způsoby jak nastavit port na 10Mbit-FD u switche. Využitelné např. pro připojeni ronji (pozn. některé provedení ronji vyžadují, nastavení MDI/MDI-X switche).
- 1. způsob - Spojení nožiček chipu byl převzat z fóra CZF a news HKF (funguje jen s chipem RTL8305SB nebo SC = 5port switch)
- 2. způsob - Změna hodnot interních konfiguračních registrů chipu pomocí externího procesr (mel by fungovat i s jiným chipem = i vetší než 5-port switch)
Způsob 1 - Spojení nožiček chipu
- pouze s chipem RTL8305SB (SC)
- např. Edimax ES-3105P (pouze 5port) nebo Genius GS4050 mini (5-port)
- datasheet RTL8305SB a RTL8305SC
- default je 1, 0 je slus na zem
- výtah z datasheetu:
<bash> pin 95: 1 - skupina x - port 0, skupina y - port 1, 2 a 3 0 - skupina x - port 0 a 1, skupina y - port 2 a 3
port0 je na 3, 4, 127, 128 (u růžku s klíčem)
port1 je na 7, 8, 11, 12
port2 je na 15, 16, 19, 20
port3 je na 23, 24, 27, 28
port4 je na 31, 32, 35, 36 (port4 je special, měl by zůstat auto)
pin 104: 1 - enable auto-negotiation skupiny x
0 - disable
pin 105: 1 - enable auto-negotiation skupiny y 0 - disable
pin 107: 1 - enable 100Mbps skupiny x 0 - disable
pin 108: 1 - enable 100Mbps skupiny y 0 - disable
pin 109: 1 - enable FullDuplex skupiny x 0 - disable
pin 110: 1 - enable FullDuplex skupiny y 0 - disable </bash>
- Když nohy 104,105,107,108 vyzkratujete na zem, tak bude mít switch jeden 100Mbit port a 4x 10Mbit-FD porty.
- Pozor na vedlejší efekt, budou svítit neustále diody.
Způsob 2 - Přeprogramovaní chipu pomocí externího procesoru
Chip se může také kofigurovat pomocí SMI sběrnice. Pravidla komunikace po této sběrnici jsou uvedeny v katalogovém listu chipu na str119. Tuto sběrnici mají i více portové switche a ty lze je tímto způsobem také konfigurovat. To znamená, že i u 8 portového switche lze předělat do reřimu 10Mbit-FD libovolný počet portů.
Co je protřeba:
- procesor + 2 odpory 1,5kOhm
- programátor
- software Ponyprog pro naprogramování procesoru a AVR Studio pro případnou změnu nastavení
Po SMI sběrnici se mohou data z obvodu číst nebo zapisovat. Jestli se bude zapisovat nebo číst se rozliší v úvodu vysílaných dat. Taky se zde musí uvést číslo banky registrů - PHY0-PHY5 a číslo registru 0 - 31, se kterým se bude pracovat.
Aby se upravil PORT4 na 10Base FD musí se v bance registrů 4 - PHY4 s binárním kódem 00100:
v registru 0 - str53, binární kód registru je 00000
- vypnout autonegotiation - znulovat 12tý bit
- povolit 10MB - znulovat 13tý bit
- zapnout full duplex - nastavit 8 bit.
v registru 4 - str55, binární kód registru je 00100
- povolit pouze 10Base FD znulovat 5,7,8 bit
- nastavit 6 bit
Bylo by dobré neměnit ostatní bity, proto se nejprave data z chipu přečtou, pozmění a pak zpátky zapíší.
V katalogovém listu chipu na str119 je uvedeno uspořádání posílaných dat. Prvních 32 taktů jsou 1. poslání adresy registru 0 by se dalo binárně zapsat:
<bash>
CH CL
pro čtení 01100010 00000010 pro zápis 01010010 00000010
- 4 -- 0 -
</bash>
dalších 16 taktů se posílají data.
Nejjednodušší způsob, jak data poslat do IO, je pomocí naprogramovaného procesoru. Já jsem se zabýval programováním procesorů ATMEL AVR, proto jsem vytvořil program pro zápis dat i čtení pro procesor této řady. Svým vybavením plně vyhovuje procesor ATtiny12L, ale může se použít skoro jakýkoliv. Cena procesoru ATtiny12L je v GMku 28kč
Procesor se vyrábí v provedení DIL8 i v SMD provedení. Procesor V SMD provedení je možné přiletovat místo EEPROMky, se kterou je na desce switche počítáno, ale nebývá osazena. Pro připojení procesoru jsou nutné 4 vývody – z toho 2 jsou napájení a 2 pro přenos dat.
Program procesoru je napsaný v assembleru. Pro čtení a zápis jsou vytvořeny 2 funkce – nacti a uloz. Funkce delay je pouze určité zpoždění mezi jednotlivými operacemi. Původně to sloužilo ke zpožděné konfiguraci po připojení napájení, ale v programu je tato funkce provedena mezi jednotlivými operacemi. Práce s funkcemi je velmi jednoduchá.
Před vykonáním funkce se musí nejprve zapsat adresa do registrů CL, CH a poté vykonat funkce. Adresa CL a CH nemusí obsahovat informaci o tom, jestli se zapíší data nebo se budou číst. Funkce zapíší sekvence pro čtení a zápis. Nejvyšší 4 bity CH jsou ignorovány.
Po přečtení dat z IO se musí provést nastavení. Vynulování bitů se provede instrukcí CBR podle masky a nastavení bitů se provede instrukcí SBR podle masky. Doufám, že funkce těchto dvou instrukcí jsou dostatečně zřejmé ze samotného programu.
Po zápisu posledního byte do registrů program skočí do nekonečné smyčky.
Poslední část programu nazvaná kontrola se v běžném režimu nepoužívá. Slouží pro kontrolu zapsaných dat do IO. Na nevyužitých dvou vývodech se začne periodicky vysílat sériově přečtená data. Na dvoukanálovém osciloskopu se pak může na tyto data podívat.
Připojení procesoru k IO
Detail
V případě, že bude použit procesor v provedení SMD musí se zamezit spojení vývodu 1 procesoru s deskou switche a tento volný vývod procesoru připojit na napájení – vývod 8 procesoru.
Když by byl procesor použit v provedení DIL8, je dobré přiletovat patici DIL8 k desce switche pomocí drátků a procesor pouze dát do patice – když by bylo potřeba procesor přeprogramovat lze pak procesor z patice snadno vydloubnout.
Programátor
- Programátor lze vyrobit vzdušné konstrukce. Když by byl potřeba naprogramovat procesor v SMD provedení, pak by byl problém připojit procesor k programátoru. Je možné vyrobit PCB.
Návrh desky je vytvořen v programu Eagle V4.15 light
- Verze pro procesor v DIL8
- Nebo pro procesor v SMD provedení
Schéma programátoru
Software
Programování procesoru
- Procesor je možné naprogramovat pomocí programu Ponyprog
Tento program je odzkoušen v 5-ti portovém switchi a předělá PORT4 chipu do režimu 10MBit FD.
pozn. PORT4 chipu nemusí být stejně označen na switchi. U předělaného switche se změnil port na switchi označený jako 1.
Pro snadné určení předělaného portu stačí zkusit krajové porty - jeden by to měl být.
Po nainstalování je potřeba zvolit port COM1 v setup->interface setup
Dále je potřeba zvolit procesor – device->AVR micro->ATtiny12 Poté se může načíst HEX soubor – file->open program file, zvolit HEX. Když by se programování nepovedlo na poprvé, případně bylo potřeba procesor přeprogramovat musí se před programováním procesor vymazat – command->erase a pak až procesor naprogramovat.
Procesor se pak naprogramuje – command->write program Nyní by měl být program v procesoru. Další věc, co není nutná, ale bylo by dobré ji nastavit, je zapnutí ochrany proti malému napětí. Procesor se pak sám restartuje když klesne napětí pod určitou mez. Je to určitá ochrana proti zkolabování programu. Tato ochrana se zapne v nabídce command->security and configuration bits, zde se nejprve zvolí read, pak se BODLEVEL a BODEN vynulují a opět pomocí write zapíše
Změna nastavení
- Pokud by chtěl někdo změnit nastavení, musí přepsat program v assembleru. program se poté musí zkompilovat – převést do HEX souboru. Já používám AVR Studio.
Zde se musí nejprve vytvořit projekt a poté vložit program v assembleru do vytvořeného projektu.
Nazvat projekt
Vybrat procesor a kliknout na finish
Dále se objeví prázdné okno, do kterého se píše program a kam se může jednoduše zkopírovat zdrojový program
Po úpravě se program přeloží – build->build. právně zkompilovaný program vypadá takto