VHDL və Verilogda sadə bir VGA nəzarətçisinin dizaynı: 5 addım
VHDL və Verilogda sadə bir VGA nəzarətçisinin dizaynı: 5 addım
Anonim
VHDL və Verilogda sadə bir VGA nəzarətçisinin dizaynı
VHDL və Verilogda sadə bir VGA nəzarətçisinin dizaynı

Bu təlimatda RTL -də sadə bir VGA Controller dizayn edəcəyik. VGA Controller, VGA displeylərini idarə etmək üçün hazırlanmış rəqəmsal bir sxemdir. Görüntülən çərçivəni təmsil edən Çərçivə Tamponundan (VGA Yaddaş) oxuyur və görüntü məqsədi ilə lazımi məlumatları və sinxronizasiya siqnallarını yaradır.

Verilog/Sistem verilog kodu axtarırsınızsa: Verilogdakı blogum VGA Controller və Video Sistemini ziyarət edin.

Addım 1: VGA nəzarətçisinin interfeysi

VGA nəzarətçisindəki əsas interfeys siqnalları aşağıda verilmişdir

  • Pixel Saat və ya VGA Saatı
  • HSYNC və VSYNC siqnalları

Seçilmiş VGA ekranı üçün əvvəlcə onu idarə etmək üçün lazım olan Pixel Clock tezliyini hesablamalısınız. 3 parametrdən asılıdır: Ümumi Yatay Piksellər, Ümumi Şaquli Piksellər, Ekran Yeniləmə Hızı.

Tipik olaraq, F = THP * TVP * Yeniləmə Hızı

Əlavə edilmiş RAR -da müxtəlif VGA ekranları üçün lazım olan piksel saat sənədlərini tapın.

HSYNC və VSYNC siqnalları Pixel saatından yaradılır. HSYNC və VSYNC siqnallarının vaxtı parametrlərin sayından asılıdır: Üfüqi və Şaquli Cəbhə, Üfüqi və Şaquli Aralıq, Yatay və Şaquli Ekran Pikselləri, Yatay və Şaquli Sinx Pulse Genişlikləri və Qütbləri.

Bu parametrlər seçilmiş VGA ekranı üçün standartlaşdırılmışdır. Bu sənədləri əlavə edilmiş RAR -da tapın.

Bu parametrlər VGA Controller IP -də konfiqurasiya edilə bilən parametrlərdir.

Addım 2: VGA Nəzarətçisini VGA Ekranı ilə birləşdirin

VGA Nəzarətçisini VGA Ekranı ilə birləşdirmək
VGA Nəzarətçisini VGA Ekranı ilə birləşdirmək

Şəkil VGA Controller -in VGA ekranı ilə necə birləşdiriləcəyini göstərir. Sistemi tamamlamaq üçün daha iki komponentə ehtiyacınız var:

  • Çərçivə Tamponu: Görüntülən çərçivəni tutan yaddaş.
  • Video DAC: RGB rəqəmsal məlumatlarını çevirən və uyğun gərginlik səviyyəsində RGB analoq siqnalları ilə VGA Ekranı idarə edən DAC.

Ən sadə və populyar Video DAC -lərdən biri ADV7125 -dir. RGB rəqəmsal sözlərini 0-0.7 V analog siqnallarına çevirən və VGA displeyini idarə edən 8 bitlik DAC-dır.

Addım 3: Çərçivə Tampon Dizaynı

Göstəriləcək görüntünü 'saxlayan' yaddaşdır. Adətən bir RAM və ya bəzən bir ROMdur. Bir görüntünü təmsil etmək üçün bir çərçivə tamponunun necə dizayn ediləcəyini müzakirə edəcəyik. Çərçivə tamponu bu rəqəmsal məlumatı VGA Controller -in əmri ilə Video DAC -a ötürür.

Əvvəlcə lazım olan piksel dərinliyinə qərar verməliyik. Görüntünün keyfiyyətinə, bir pikselin təmsil edə biləcəyi rənglərin müxtəlifliyinə qərar verir. 8 bitlik DAC üçün bir pikselin əsas rəng komponentlərini təmsil etməliyik: R, G və B hər birini 8 bitdə. Bir pikselin 24 bit olması deməkdir.

Hər piksel Frame Buffer yaddaş yerlərində bitişik şəkildə saxlanılır.

Tutaq ki, göstəriləcək şəkil 800x600 pikseldir.

Buna görə Frame Buffer 800x600 = 480000 x 24 bit yaddaşa ehtiyac duyur

Yaddaşın ümumi ölçüsü təxminən 800x600x24 = 1400 kB -dir.

Qara və ağ şəkil varsa, 800x600x1 = 60 kB təxminən.

Blok RAM -lər, bəlkə də Xilinx FPGA -da bir Çərçivə Tamponunu təmsil etmək üçün istifadə olunur.

Addım 4: Qeydlər

  • Seçilmiş DAC -dan asılı olaraq VGA Controller -də əlavə siqnallara ehtiyac var. ADV7125 istifadə etdim.
  • VGA ekranı sürməzdən əvvəl VSYNC və HSYNC-də flip-floplar vasitəsilə dövr gecikmələri əlavə edin. Bunun səbəbi DAC və Yaddaş gecikmələridir. Piksel siqnalları HSYNC və VSYNC ilə sinxronlaşdırılmalıdır. Mənim vəziyyətimdə 2 dövr gecikmə idi.
  • Verilən ölçüdə Çərçivə Tamponu blok ölçüsünün məhdudlaşdırılması səbəbindən FPGA üzərində tərtib edilə bilmirsə, görüntünü əks etdirmək üçün daha kiçik yaddaşdan istifadə edin və kodu tam çərçivənin deyil, mövcud yaddaşın hüdudunda gəzmək üçün kodu düzəldin. Bu, eyni görüntünü bütün ekran boyunca dəfələrlə təkrarlayacaq. Başqa bir üsul, hər bir görüntünün daha az qətnamə ilə bütün görüntünü tam ekranda göstərmək üçün təkrarlandığı piksel ölçüsüdür. Bu, koddakı ünvan artım məntiqini düzəltməklə edilə bilər.
  • IP bütün FPGA-lar arasında tamamilə portativdir və Virtex-4 FPGA-da 100 MHz-ə qədər təsdiqlənmiş vaxtdır.

Addım 5: Əlavə edilmiş fayllar

RAR ehtiva edir:

  • VGA nəzarətçi kodu
  • PDF formatında VGA.

Tövsiyə: