VHDL ile ROM BLOGU OLUŞTURMAK (2)

.....

ROM'ler(READ ONLY MEMORY-SADECE OKUNABİLİR HAFIZA) sadece okunabilen verilerin saklanması için kullanılan depolama birimidir.

ekte şekilde N\*M bitlik ROM gösterimi verilmiştir.görülecegi üzere in\_ROM\_aktif giriş portunun aktif olması ile birilkte ROM'dan in\_data\_addr adresindeki data out out\_data çıkı portuna aktarılmaktadır.

Bazı terimler ve kullanımlar:

veri\_uzunlugu: hafıza biriminin veri yolu genişligini bildirmektedir örnegin bu deger 8 ise , tasarlanan hafıza elemanı her bir adreste 8 bit uzunlugunda veri saklıyor demektir.

ROM\_Derinligi: bu tanımlama ile tasarladıgımız hafıza elemanının kaç adet veri saklayabilecegi beliritlmektedir.bu adrres aynı zamanda dogrudan adreslme hattının uzunlugununda belirlenmesini saglmaktadır.

örnegin: 30 adet veri saklamak istersek rom\_derinligi tanımlamasının degerinin 30 olması gerekmektedir. 30 adet veriyi adreslemek için gereken adress yolu genişligi ise ceil (log2 30) n-> 5 bit olur. örnegimizde bu işlem paket içinde log2\_int fonksiyonu tarafından yapılmaktadır.

örnek kodumuza gelirsek,

ROM datalarını dosyadan okuyan bir vhdl kodumuz var.

generic bildirimi ve port bildiriminde ise 1bitlik saat darbesi

giriş portu,1 bitlik ROM aktif giriş portu, generic ROM\_DERİNLİĞİ paramtresine baglı olarak hesaplanan adres giriş portu ve okunan adresteli datanın ROM dışına cıkarılması için veri\_uzunlugu uzunlugunda çıkış portu mevcuttur.

ROM Adress uzunlugunun belirlenmesi için kullanılacak olan log2\_int fonksiyonu satıda tanımlanan ornekler\_paket paketi içersinde tanımlanmıştır.

ve satıda veri\_uzunlugu genişligine sahip Rom\_derinligi derinliginde tip

tanımlama işlemi yapılmıştır. ve baska bir satırda ROM\_DATA\_YUKLE procedure tanımlaması ile sinus örneklerinin bulundugu dosyadan datalar alınmaktadır. procedure sonunda ise procedure çagrılarak dosyadan okunan datalar ROM'a yüklenmektedir.buradan ROM datası in\_data\_addr bilgisine göre out\_data cıkışına oradanda üst modül out\_data\_rom\_dosya ile out cıkış vermektedir.

benzetim sonuclarımız projemizi ve kodumuzu dogrulamaktadır.