For english version http://dincaysroom.blogspot.com (Not complete yet)

30 Temmuz 2010 Cuma

Yeni Kit: Altera DE0

Bozulan S3E kitimin yerine Altera DE0 kitiniz aldim. Cizgi Tagem'den 220 liraya aldim. 3 gun icinde elime ulasti. Baska herhangi bir karti bu kadar hizli teslim alamazdim.

Kutunun icinden FPGA karti, adaptoru, priz icin cevirici, usb kablosu, metal ayaklari icin plastik kiliflar ve bir iki ufak kablo cikiyor. Adaptorun ufak olmasi guzel. Hem adaptor kablosu hem de usb kablosu yeterince uzun. Kartin onunde koruma amacli seffaf plastik bir levha var. Bu levha isigi engeller, kart soluk gorunur diye dusunuyordum ama levha seffaf. Kart yine capcanli gozukuyor. Baski devre uzerindeki mavi renkli yalitim kaplamasi da kartin guzel gosteriyor. Kart, S3E karti gibi icinde test programi yuklu geliyor.

Karttaki cevre birimlerine gelince: SDRAM, flash bellek, VGA, PS/2, RS232, SD kart okuyucu, 10 anahtar, 3 pushbutton, 8 basamakli 7 segment LED, 10 yesil led var. LCD icin yer yapmislar ama LCD'yi kullanicinin takmasi gerekiyor. Genisleme yuvasi standart 0.1 inc 2x40 pin soket seklinde. S3E kiti icin aldigim hirose konnektorlu genisleme kartini bir iki degisiklikle DE0'da da kullanabilirim gibi. Genisleme kartini kullanmak istiyorum cunku bir suru PMOD kartim var.

DE0 kitinin kullanim kilavuzu ne yazik ki S3E Starter kitin kullanim kilavuzu kadar kapsamli degil. Ornek programlar da S3E kitine gore cok daha az. Altera, Altera Universite programi cercevesinde pek cok universitelere bu kitten bir suru dagitti. Ornek programlari cogaltirsa kitin okullarda kullanimini kolaylastirir.

Xilinx'ten farkli olarak Altera'nin tek tip mikroislemci yapisi var. Yani picoblaze ve microblaze gibi iki mikroislemci modulu yerine ikisini de kapsayan Nios isimli mikroislemci modulu var. Nios'un belli kisimlari ucretsiz. Kullanimi Picoblaze'in kullanimi kadar kolay degil. Bu benim gibi hobiciler icin kotu bir sey.

Altera FPGA'leri programlamak icin Quartus yazilimi gerekiyor. Tipki ISE gibi Quartus'un da ucretsiz surumu ve Linux destegi var. Quartus'u kurmak ISE'yi kurmaktan biraz daha kolay. Quartus'tan edindigim izlenim, Quartus'un ISE'den daha derli toplu bir program oldugu yonunde. ISE'nin aksine her yaptigim is icin yeni bir program calistirmiyorum. Quartus'un bir kotu yani, cok fazla penceresi oldugundan netbook'umun ekrarina sigmamasi. Anca netbook'a monitor baglayip iki monitorlu kullanabiliyorum.

Quartus'u kurma kismi kolay. Zor kisim, Linux'ta usb suruculerini kullanmak icin biraz numara cekmek gerekmesi. Bunun ilac gibi cozumu http://gunluk.muuzoo.gen.tr/2009/06/17/vhdl-bolum-1 adresinde veriliyor.

Kitin resmi sitesi:
http://www.terasic.com.tw/cgi-bin/page/archive.pl?Language=English&No=364

13 Temmuz 2010 Salı

Spartan 3E Kit Bozuk

Spartan 3E kitimin tamamen bozuk oldugunu anladim. Kartin derve semalarina baktigimda regulatorlerin yandigina karar vermistim. Harici bir guc kaynagi ile regulatorleri devre disi birakarak, karta regulatorlerin vermesi gereken voltajlari verdigimde FPGA'in kendisi cok akim cekiyor ve cok isiniyor. Bu durumda FPGA'in kendisinin bozulmus oldugunu anliyorum. Guzelim kart, bir defaligina yanlis adaptor bagladigim icin kullanilamaz oldu :(

2 Haziran 2010 Çarşamba

Verilog ile PID Kontrol

Verilog'da yazılmış ve doğrudan FPGA'de çalışan bir PID kontrol bloğu yaptım. Bir PID kontrol bloğunu çalıştırmak doğru çalışan bir programa ek olarak için P, I ve D katsayılarını doğru belirlemek gerekiyor. İnternette PID anlatan bir sürü belge var ama düzgün çalışan bir kat sayı seti bulamadım. Deneme yanılma ile ISE'de simulasyonda çalıştığı görülebilecek şekilde katsayıları belirledim. Normalde PID kontrol şeması aşağıdaki resimdeki gibi oluyor.


Benim durumumda dış elektronik hiç kullanmadığım için geri besleme FPGA'in içinden oluyor. Genel bir şey olmasını istediğim için de kontrol edilecek blok (resimde plant) "Çıkış=Giriş" olan bir blok.

Kullandığım PID denklemini http://www.atlantixeng.com/pdf-files/PID_Controller_in_FPGA.pdf adresindeki belgeden aldım.

Programın 8 bit girişi ve 8 bit çıkışı var. Program kodlarına buradan erişilebilir.

16 Şubat 2010 Salı

FTDI ve ncurses ile Hazifa Oyunu

Ftdi cipi ile kontrol edebildigim 4 led ile bir hafiza oyunu yaptim. Oyun soyle
  • Oyun rastgele sirayla yanan ledlerin hangi sira ile yandigini programa girmek uzerine kurulu.
  • Oyunda tur/level mantigi var. Ledler yaniyor, sirasi giriliyor, ledler yaniyor sirasi giriliyor ... seklinde.
  • Ayni anda sadece 1 led yaniyor. Birden fazla led ayni anda yanmiyor.
  • Her turda, o turun sayisi kadar led yaniyor. 1. turda 1 led, 2. turda 2 led, 7. turda 7 led yaniyor.
  • Led sirasi soyle belirleniyor: Onceki turdaki led sirasi + rastgele bir led.
Bu kurallara gore yazacagim programda olmasini istedigim bir ozellik her sayiya basilinca enter tusuna basma zorunlulugu olmamasiydi. Bunun icin girdiyi getch() fonksiyonu ile okumak gerekiyor. Getch() Windows'ta conio.h'in icinde, fakat Linux'ta bu kutuphane yok. Getch()'in oldugu kutuphane ncurses.h. N on eki new den geliyor. Curses ogrenmeye getch() kullanmak istedigim icin basladim.

Netten arastirdigimda curses'in aslinda cok kullanilan bir kutuphane oldugunu ve en basit konsol uygulamalari icin bile kullanilmasinin buyuk kolaylik oldugunu ogrendim. Ncurses'i kurmak icin

sudo apt-get install libncurses5-dev

komutunu girmek lazim. Daha sonra c kodunun basina #include satirini eklemeli, gcc ile derlerken de -lncurses bayragini eklemek gerekiyor.

Ncurses kutuphanesinden kullandigim fonksiyonlarin aciklamalarini koda ekledim. Ncurses hakkinda daha ayrintili bilgiye http://tldp.org/HOWTO/NCURSES-Programming-HOWTO/ adresinden ulasilabilir. Kutuphanede tanimli sabitler ve fonksiyonlarin listesi http://www.opengroup.org/onlinepubs/007908799/xcurses/curses.h.html adresinde var.

Programi yazarken en cok zorlandigim yer, getch() fonksiyonunun klavyeden bir girdi beklemeden -1 donmesiydi. Bunu halletmek icin programda nodelay modunu kapatmak gerekiyormus. Ikinci en cok zorlandigim nokta da ekranin kaydirma modunun kapali olmasindan dolayi ekrana sigmayacak satirlarin en son satira arka arkaya yazilmasi oldu. Bu sorunu cozmek icin scroll modunu acmak gerekiyormus. Aklima takilan diger noktalari ustteki iki linkten ve manuellerden hallettim.

Program maalesef sadece linux'ta calisiyor, windowsta calismiyor. Windows'ta calisan versiyonu icin linux kodunu biraz degistirmek yeterli. Yapilmasi gereken conio.h'in eklenmesi, ncurses fonksiyonlarinin cikarilmasi, usleep fonksiyonunun degistirilmesi ve printw fonksiyonlarini printf ile degistirilmesi.

Oyun duzenegi bir onceki yazimda fotografta gosterilen duzenegin aynisi. FTDI donusturucu ve ucuna baglanmis 4 tane led.

Program koduna buradan erisilebilir.

4 Şubat 2010 Perşembe

FTDI Programi

FTDI cipini bitbang modda calistirip, 4 cikis pinini kontrol eden programi yazdim. Program 1-4 arasinda bir sayi girince ona karsilik gelen LED'in durumunu degistiriyor. Ayni zamanda LED'lerin durumunu ekranda da gosteriyor.

Programi calistirmak icin admin olmak gerekiyor. Aksi takdirde USB cipine ulasilamiyor. Program icin gereken kutuphaneleri ve programin nasil derlenecegini onceki yazida anlattim. Donusturucunun 6 cikisindan ikisi VDD ve GND. Geri kalan 4 pinin her biri 1 LED'e bagli. Donusturucunun hangi renk pinlerinin ne oldugu datasheette yaziyor. Bu resimden de bakilabilir.


Burada kullandigim FTDI donusturucu ve Digilent LED karti var. FTDI'nin kablolarini Digilent'e gore siralayip LED'lere bagladim.


Duzenek oldukca basit


FTDI ve 4 LED'i kullanarak bir oyun yazacagim. Bunun icin curses.h kutuphansini kullanmam gerekiyor. Sonraki yazimda curses.h kutuphanesini anlatacagim. Linux'ta temel bir kutuphaneymis.

Program kodlarina buradan erisilebilir.

FTDI USB - RS232 Donusturucu

Bilgisayarla FPGA'i konusturmayi uzun suredir dusunuyordum. Bunun icin en kolay yol RS232 portunu kullanmak. Fakat artik bilgisayarlarin RS232 portu yok. Onun yerine USB-RS232 donusturucusu kullanmak gerekiyor. Bu donusturuculerin yaninda gelen program ile bilgisayarda sanal COM portu olusturuluyor. Isletim sisteminin COM porta yolladigini sandigi veriyi donusturucu surucusu donusturucuden kullanilan cipe uygun bicimde USB'ye yolluyor. Cip de bu datayi RS232 standartlarin uygun hale getirip disari veriyor. Temel mantik bu.

Bilgisayarla FPGA'i konusturmak icin bilgisayarda COM portunu kontrol edebilmek gerekiyor. Windows'ta COM portu sadece Hyper Terminal ile kontrol edilebiliyor. Windows'ta calisan herhangi bir COM port kutuphanesi yok. Hyper Terminal ise oldukca hantal bir program. Linux'ta ise COM portu kontrol eden kutuphaneler var. Biraz dolambaclilar ama yine de calisiyorlar. Bu yuzden bu isi Linux'ta yapmaya karar verdim.

USB hakkinda iyi olan iki firma biliyorum, Cypress ve FTDI. Cypress bu konuda daha tecrubeli ve yetenekli gozukuyor. Cypress'in urunleri daha kapsamli. FTDI'nin cipleri ise daha basit islerde kullanilacak turden. Basit olmasi benim icin daha iyi. Ayrida FTDI'in Turkiye distributoru var. Az bir kargo ucreti ile siparis verebiliyorum. Bu yuzden FTDI almaya karar verdim.

FTDI'in sitesinde 2 surucu var. Bir tanesi anlattigim gibi sanal COM portu olusturuyor. Digeri ise sanal COM portu olusturmadan dogrudan USB portunu kontrol ediyor. Ikinci yontem cok daha kolay. Aslinda ikinci yontem surucu degil, bir C kutuphanesi. Kutuphanedeki fonksiyonlari kullanarak bir C programi ile cip kontrol edilebiliyor. Bu tam istedigim sey.

Bu kutuphaneyi incelerken FTDI ciplerinin baska bir ozelliginin oldugunu ogrendim. Normalde RS232 ile seri iletisim en az 2 pin ile (Rx ve Tx) gerceklesiyor. FTDI ciplerinde 1'er tane de handshaking icin pin var. Toplam 4 pin, 2'si giris, 2'si cikis. Ayrica cikis pinlerinin degeri de RS232 protokolune gore belirleniyor. Fakat bitbang denilen modda bu 4 pin sanki mikroislemci pini gibi giris ve cikis olarak programlanabiliyor ve mikroislemcilerdeki gibi degerleri istenildigi gibi degistirilip istenildigi zaman okunabiliyor. Yani bilgisayardan kontrol edilen, bilgisayarda yazilan c programina gore calisan 4 pinli bir mikroislemci gibi davranabiliyor. Bu da harika bir ozellik. RS232 standartina bagli kalma zorunlulugu yok.

FTDI'in sitesinden 2 kart siparis ettim. Bir tanesi FPGA kartinin RS232 portuna baglayabilecegim, arada voltaj kaydiricinin oldugu EVAL_232R karti, digeri ise dogrudan FPGA pinlerine baglayabilecegim sekilde olan TTL-232R karti. Bunu ucu ciplak kablo olan modelini aldim. Pinleri, Digilent'in PMOD kartlarina uygun sekilde kendim dizip FPGA kartina kolayca baglayabilecegim.

FTDI cipleri icin iki farkli kutuphane var. Bunlardan D2XX kutuphanesi FTDI'nin yazdigi kutuphane. Kaynak kodlari acik degil. Ikincisi ise libftdi kutuphanesi. Bu acik kaynak kodlu. libftdi'yi Linux'ta kurmak

sudo apt-get install libftdi

komutu ile oluyor. libftdi hakkinda daha fazla bilgi http://www.intra2net.com/en/developer/libftdi/index.php adresinden edinilebilir. http://hackaday.com/2009/09/22/introduction-to-ftdi-bitbang-mode/ adresinde de cok guzel bir program ornegi var. Ayni zamanda bitbang modu anlatiliyor. C programi icin herhangi bir metin editorune yazilan program

gcc -lftdi -o main main.c

komutu ile derleniyor. -lftdi bayragi ftdi kutuphanesini eklemek icin yaziliyor. Programin icine yazilan #inlclude yetmiyor. Niye boyle oldugunu bilmiyorum. Bu cozumu de internette buldum.

Yazdigim programi bir sonraki yazida anlatacagim.

21 Ocak 2010 Perşembe

Kart yandi !!!

Karti yaktim. Uzun sureden sonra veriloga geri donmek istedim. Yanlislikla ayni girisli fakat voltaj degeri farkli olan bir adaptoru bagladim. Aninda yandi kart. Iyi haber FPGA'e muhtemelen bir sey olmadi. Cok buyuk ihtimalle voltaj regulatorleri yandi. User manuel'de karta guc veren iki regulator oldugunu soyluyor. Biri Texas Instruments'in 1.2, 2,5 ve 3.3V ureten regulatoru, digeri Lineer Devices'in 2.4 V ureten regulatoru. User manuel sayfa 141'de regulatorlerin semalari var. Lineer'in regulatorunun yandigina eminim, Texas'in regulatorunun durumunu bilmiyorum. Iyi haber Lineer'in regulatoru sadece DRAM'i besliyor. Yani yanan sadece Lineer'in regulatoru ise onu sokup FPGA'i kullanmaya devam edebilirim, DRAM'i kullanmasamda olur. Eger Texas da yandiysa durum kotu. Ustelik Lineer'in paketi SOIC. Yani havya ile lehimlenebilir. Texas'in paketinde ise padler paketin altinda, havya ile lehimlemem imkansiza yakin. En kisa zamanda karti okuldaki laba goturup hangi entegrelerin yandigina bakacagim. Yanan entegreleri de www.tr.farnell.com adresinden getirtecegim. 100 avronun altindaki alimlarda 15 avro ek ucret odeniyor. 100 avroluk bir seyler almaya calisacagim.