زبان توصيف سختافزار

**Hardware Description Language** 

## زبانها

#### VHDL

- یادگیری حداقل یک زبان به طور کامل
- − یادگیری ناقص و سعی و خطا ← سخت شدن توصیف و اشکالزدایی

- − اصول یکسان − ساختارهای نحوی متفاوت
  - (1980 اوايل دههٔ VHSIC HDL
    - مبتنی بر زبان ADA

- کاربردها:
- □ مستندسازی:
- به جای توصیف زبان طبیعی:
  - نادقیق (برداشتهای مختلف)
    - غير قابل پردازش

## • کاربردها:

مدلسازی:

## مراحل اولیهٔ طراحی:

- عملکرد و رفتار کلی مشخص است
- توصیف الگوریتم با دستورهای رفتاری
  - كمك به فهم صورت مسأله
- جلوگیری از سرایت اشکالات به سطوح پایین طراحی

**کاربردها:**مدلسازی:
- مثال: کنترلکنندهٔ آسانسور

```
while (true)
  begin
      . . .
      if (REQUEST = true) then
         if (REQUEST FLOOR > CURRENT FLOOR) then
            MOVE UP (CURRENT FLOOR, ...);
         else
            MOVE DOWN (CURRENT FLOOR, ...);
         end if;
      end if;
      . . .
   end;
```

## كاربردها:

- تولید خودکار مدار از توصیف
  - زيرمجموعهٔ قابل سنتز
  - لزوم آشنایی با این زیرمجموعه
- portable code ← تفاوت ابزارها
  - کد غیر قابل سنتز برای دیگری
    - مدار متفاوت
      - كليات يكسان

### **–** این درس:

- − موارد کلی مشترک
- تحوهٔ کدنویسی مناسب

## کاربردها:

- درستیسنجی
- محیط درستی سنجی: testbench
  - عناصر اصلى:
  - طرح مورد آزمون
  - تولید و اعمال بردارهای ورودی
    - مشاهده و تحلیل خروجیها

## كاربردها:

- درستیسنجی
- تولید بردارهای ورودی:
  - **1.** تصادفی
  - 2. انتخاب هوشمندانه
- 3. الگوريتمهاي توليد خود كار بردارهاي آزمون (ATPG)
  - نیاز به توصیف با کد VHDL
    - برنامەنويسى روالى
      - حواندن از فایل

- مثال:
   − سختافزار محاسبهٔ 1/2 (x² + y²)
   − مقایسه با نتیجهٔ رفتاری

```
1
          L1 : L MODULE(X,Y,L);
11
          LL : process (···)
12
          begin
          for X in 0 to 63 loop
13
                      for Y in 0 to 63 loop
14
15
                     begin
16
                                L BEHAVE := (X**2 + Y**2)**0.5;
17
                                 if(L != L BEHAVE)
18
                                           ERROR SIG <= '1';</pre>
19
                                end if;
20
                     end for;
21
          end for;
22
          end process LL;
. . .
```

# (Levels of Abstraction) سطوح تجرید

# رفتارى:



- توصیف عملکرد مطلوب (الگوریتمی)
  - بدون پرداختن به مدار
  - همهٔ امکانات VHDL

# سطوح تجريد



