Konference: Počítač SHARP MZ-800 a emulátory

Od: Jakub Ladman
Datum: 20.10.2013 23:04
Předmět: Re: Stare projekty (Unikarta)


Budu muset najít ten pytlík s encxxx a dalšíma součástkama a unikartu 
doosadit...

Protože tohle opravdu chci vyzkoušet.

Jakub

 
Dne Ne 20. října 2013 22:46:03 Michal Hučík (sharpemu tu byla ta zakroucena vec pandora.cz)
 napsal(a):
> Ahoj,
> 
> odpovim postupne vsem v tomto mailu :)
> 
> Co se tyka pameti, tak to neni zase az tak velika tragedie. Ten kdo do
> Unikarty osadil STM32F101 (asi vetsina), tak tam ma 16 kB. Pokud si
> nekdo krom mne a Vaska osadil STM32F103, tak ma 20 kB. Nicmene aby jsme
> meli kompatibilni firmware, tak je linker nastaven takovym zpusobem, aby
> se zasobnik umistil na adresu 0x4000 v RAM - tedy na hranici tech 16 kB.
> Soucasny kod po kompilaci zabira 9 288 bajtu BSS. To znamena, ze pro
> zasobnik tam ted mame stale jeste skoro 7 kB pameti. Kdysi jsem delal
> nejaky test toho kam az se mi dostal zasobnik a mam pocit, ze jsem mu
> tehdy nameril nejake 4 kB.
> Mam uz take jakousi predstavu jak by se ten stavajici kod mohl
> preorganizovat a tim by se asi usetrili i jakysi ten bajt.
> 
> Co se tyka UDP protokolu, tak ten v unikarte samozrejme budeme
> podporovat. Unikarta vsak umi navazat UDP komunikaci s protistranou
> pouze za takovych podminek, ze uz dopredu vime kdo s nami chce timto
> protokolem mluvit a jaky je jeho odesilaci UDP port.
> Na zaklade stejnych informaci umime vytvorit samozrejme jak TCP, tak i
> UDP socket, nicmene u TCP mame jeste navic moznost naslouchat na nejakem
> konkretnim portu a vytvorit novy socket az v momente, kdy se kdokoliv v
> internetu rozhodne, ze nam do takto vystaveneho portu cvrnkne.
> Automaticky se nam vytvori socket a my se az v tuto chvili dozvime IP
> adresu a odesilaci port protistrany.
> 
> Pokud si chcete vyzkouset stavajici firmware, tak jsem jej umistil sem
> http://duna.ordoz.com/ushell_tcp/
> 
> Najdete tam zdrojak programu pro komunikaci s Ushellem - je to uplne ten
> samy kod, ktery se pouziva pro praci pres RS232. Ovladani zustava
> stejne. V prvnim parametru je uvedena bud cesta k RS232 device, nebo
> tcp:ip_adresa:port.
> 
> RS232:
> # ./ushell /dev/ttyUSB0 readdir /unicard
> 
> TCP:
> # ./usell tcp:192.168.167.80:23  readdir /unicard
> 
> Martine, pokud jej budes upravovat pro windows, tak jsem v tom kodu v
> podstate pouze pridal inicializaci TCP socketu. Pak jsem malinko upravil
> funkci ReadResult(), protoze v RS232 rezimu chodi z Unikarty na konci
> radku kod 0x0d, 0x0a, zatimco v TCP rezimu chodi uz jen 0x0a. A jako
> posledni jsem musel upravit funkci PrintBps(), protoze pres TCP je obcas
> end_time - start_time roven nule :)
> Jeste by to tam chtelo pridat i nejake timeouty, ale momentalne nevim
> jak se to dela :) ... v Unikarte uz jsem nejake timeouty udelal.
> 
> Do adresare /unicard si nahrajte soubor network.cfg, ktery si upravte
> dle vlatnich potreb. Po resetu vam Unikarta posle na USART debug info o
> tom jake hodnoty precetla z konfiguraku, napr:
> 
> cfg_hwaddr=02:00:00:00:00:01
> cfg_ipaddr=192.168.167.80
> cfg_netmask=255.255.255.0
> cfg_gateway=192.168.167.254
> Ushell PORT: 23
> 
> Unicard - USART Shell
> OK:RESET
> 
> V tuto chvili uz by vam to melo odpovedet na ping a mel by vam fungovat
> telnet na tcp port Ushellu. Ve chvili, kdy se pripojite na TCP Ushell,
> tak se ukonci a zablokuje cokoliv co se pripadne prave vykonavalo v
> Ushellu na RS232 - ten TCP ma vyssi prioritu.
> 
> Ushell podporuje jen jedno aktivni spojeni. Pokud prijde nejake dalsi v
> dobe, kdy je uz nekdo pripojen, tak dostane odpoved BUSY a info o tom,
> kdo momentalne tu sluzbu blokuje.
> Pokud na vstup Ushellu neprijde 60 sekund zadny packet, tak se spojeni
> prerusi s hlaskou TIMEOUTED.
> 
> Pro efektivnejsi komunikaci mezi STM32 a ENC29J60 jsem pripojil z ENC
> signal /INT do pinu c.52 v STM32 (PC11).
> GPIO jsem nakonfiguroval tak, aby si STM na tomto vstupu pripojilo
> interni pull-down a tak pokud tam tuto propojku neudelate, tak by vse
> melo fungovat, akorat vam Unikarta bude travit zbytecne moc casu
> kontrolou prichozich packetu. (provoz bez teto propojky vsak nemam
> overeny - zkusite to nekdo?)
> 
> Pokud nemate osazen ENC29J60, nebo pokud z nejakeho duvodu neni funkcni,
> tak se pri inicializaci na USART vypise debugovaci hlaska, ze ENC
> nereaguje a konfiguracni soubor se pak uz ani nezacne zpracovavat.
> (tohle jsem si overil jen tak, ze jsem si nasimuloval chybu v SPI
> komunikaci, zda se to bude chovat korektne s neosazenym ENC to vsak
> zatim neni overeno - zkusite?)
> 
> Toz dejte vedet, zda vam to alespon pinga.
> 
> Pokud se pres TCP prenasi z Ushellu nejake vetsi soubory do Linuxu, tak
> to chvili vypada, ze se nic nedeje (nevysypava se buffer terminalu a tak
> se na obrazovku nevypisuji tecky, ktere jsou viditelne pri RS232
> komunikaci) nicmene spojeni zije a je aktivni, coz je videt na LAN_LED
> 
> Puvodne jsem v Unikarte volal odesilaci rutiny kdykoliv, kdy Unikarta
> zrovna nemela nic jineho na praci, nicmene pri prenosu vetsich souboru z
> Unikarty do PC se mi obcas stalo, ze PC nestihalo ty packety prebirat a
> Unikarta pak zabalila spojeni z duvodu velkeho poctu zadosti o
> retransmit. Jeste jsem nezkoumal jake by mely byt doporucene mezery mezi
> odesilanymi packety. Ted jsem tam nastavil 100 ms a zatim mi zadne
> spojeni nespadlo.
> 
> 
> Michal
> 
> 
> ---
> POZOR! Provoz systému Pandora.cz bude k 30. listopadu 2013 ukončen.
> Více informací: http://goo.gl/b99cI

Ostatní příspěvky vlákna:

 
[2013/1 (17)] [2013/2 (52)] [2013/3 (60)] [2013/4 (68)] [2013/5 (60)] [2013/6 (42)] [2013/7 (9)] [2013/8 (48)] [2013/9 (1)] [2013/10 (40)] [2013/11 (45)]


[1999 (1)] [2000 (168)] [2001 (733)] [2002 (459)] [2003 (654)] [2004 (224)] [2005 (105)] [2006 (182)] [2007 (201)] [2008 (294)] [2009 (363)] [2010 (782)] [2011 (522)] [2012 (642)] [2013 (442)]