VHDL-da to'rt tomonlama oddiy assotsiativ kesh tekshirgichining dizayni: 4 qadam
VHDL-da to'rt tomonlama oddiy assotsiativ kesh tekshirgichining dizayni: 4 qadam
Anonim
VHDL-da to'rt tomonlama oddiy assotsiativ kesh boshqaruvchisini loyihalash
VHDL-da to'rt tomonlama oddiy assotsiativ kesh boshqaruvchisini loyihalash

Oldingi ko'rsatmamizda biz to'g'ridan -to'g'ri xaritali keshni boshqarish moslamasini qanday yaratishni ko'rdik. Bu safar biz bir qadam oldinga siljiymiz. Biz to'rt tomonlama oddiy assotsiativ kesh tekshirgichini loyihalashtiramiz. Afzallikmi? Kamroq o'tkazib yuborish tezligi, lekin ishlash bahosiga ko'ra, xuddi oldingi blogimda bo'lgani kabi, biz ham butun protsessorni, asosiy xotirani va kesh muhitini kesh tekshirgichini sinab ko'rish uchun taqlid qilardik. Umid qilamanki, siz buni kelajakda kontseptsiyalarni tushunish va o'zingizning kesh tekshirgichlaringizni loyihalash uchun foydali ma'lumot sifatida topasiz. Protsessor (test stoli) va asosiy xotira tizimi oldingi blogim bilan bir xil bo'lgani uchun, men ularni boshqa tushuntirmayman. Bu haqda batafsil ma'lumot olish uchun avvalgi ko'rsatmaga murojaat qiling.

1 -qadam: Xususiyatlar

Xususiyatlar
Xususiyatlar

Bu erda taqdim etilgan kesh tekshirgichining texnik xususiyatlarini tezda ko'rib chiqing:

  • To'rt tomonlama assotsiativ kesh tekshirgichi (agar to'g'ridan-to'g'ri xaritali kesh boshqaruvchisini qidirsangiz, ushbu havolaga o'ting).
  • Yagona bankli, blokirovka qiluvchi kesh.
  • Xit yozish bo'yicha yozish siyosati.
  • Yozuvlarni o'tkazib yuborish siyosati.
  • Tree Pseudo-LRU (pLRU) almashtirish siyosati.
  • Tekshirgich ichidagi qatorni belgilang.
  • Sozlanishi mumkin bo'lgan parametrlar.

Kesh xotirasi va asosiy xotira uchun standart ko'rsatkichlar oldingi ko'rsatmalarim bilan bir xil. Iltimos, ularga murojaat qiling.

2 -qadam: Butun tizimning RTL ko'rinishi

Butun tizimning RTL ko'rinishi
Butun tizimning RTL ko'rinishi

Yuqori modulning to'liq RTL ko'rinishi rasmda ko'rsatilgan (protsessordan tashqari). Avtobuslar uchun standart ko'rsatkichlar:

  • Barcha ma'lumotlar avtobuslari 32 bitli avtobuslar.
  • Manzil avtobusi = 32 bitli avtobus (lekin bu erda faqat 10 bitli xotira mavjud).
  • Ma'lumotlar bloki = 128 bit (o'qish uchun keng tarmoqli kengligi).
  • Barcha komponentlar bir xil soat bilan boshqariladi.

3 -qadam: test natijalari

Yuqori modul, xuddi oxirgi ko'rsatmada bo'lgani kabi, oddiy quvurli bo'lmagan protsessorni sinovdan o'tkazadigan dastgoh yordamida sinovdan o'tkazildi. Sinov dastgohi xotiraga tez -tez ma'lumotlarni o'qish/yozish so'rovlarini beradi. Bu protsessor tomonidan bajariladigan barcha dasturlarda uchraydigan odatdagi "Yuklash" va "Do'kon" ko'rsatmalarini masxara qiladi.

Sinov natijalari keshni boshqarish moslamasini muvaffaqiyatli tekshirdi. Quyida kuzatilgan test statistikasi keltirilgan:

  • O'qish/yozish bo'yicha barcha Miss va Xit signallari to'g'ri yaratilgan.
  • Ma'lumotlarni o'qish/yozish bo'yicha barcha operatsiyalar to'rt jihatdan ham muvaffaqiyatli o'tdi.
  • pLRU algoritmi kesh satrlarini almashtirish uchun muvaffaqiyatli tasdiqlangan.
  • Ma'lumotlarning nomuvofiqligi/nomuvofiqlik muammosi aniqlanmadi.
  • Dizayn Maxm uchun muvaffaqiyatli tasdiqlandi. Ish chastotasi = Xilinx Virtex-4 ML-403 platasida 100 MGts (butun tizim), 110 MGts faqat kesh tekshiruvi uchun.
  • Asosiy xotira uchun blokli RAMlar taxmin qilingan. Boshqa barcha massivlar LUT -larda amalga oshirildi.

4 -qadam: biriktirilgan fayllar

Bu blogga quyidagi fayllar biriktirilgan:

  • . VHD fayllari kesh tekshirgichi, ma'lumotlar keshi, asosiy xotira tizimi.
  • Sinov dastgohi.
  • Hujjatlar kesh tekshiruvi.

Eslatmalar:

  • Bu erda taqdim etilgan kesh tekshirgichining texnik xususiyatlarini to'liq tushunish uchun hujjatlarni ko'rib chiqing.
  • Koddagi har qanday o'zgarishlar boshqa modullarga bog'liq. Shunday qilib, o'zgarishlar oqilona bo'lishi kerak.
  • Men bergan barcha sharhlar va sarlavhalarga e'tibor bering.
  • Agar biron sababga ko'ra, Operativ xotira bloklari asosiy xotira uchun hisoblanmasa, xotira hajmini kamaytiring, so'ngra fayllar bo'yicha manzil shinalari kengligi o'zgaradi va hokazo. Shunday qilib, xuddi shu xotira LUT yoki tarqatilgan RAMda amalga oshirilishi mumkin. Bu yo'nalish vaqtini va resurslarini tejaydi. Yoki maxsus FPGA hujjatlariga o'ting va RAMni blokirovka qilish uchun mos keladigan kodni toping va shunga mos ravishda kodni tahrir qiling va bir xil manzillar shinasi kengligi spetsifikatsiyalaridan foydalaning. Altera FPGA -lar uchun ham xuddi shunday usul.