वीएलएसआई डिज़ाइन - वीएचडीएल परिचय

VHDL का अर्थ है बहुत उच्च गति वाला एकीकृत सर्किट हार्डवेयर विवरण भाषा। यह एक प्रोग्रामिंग भाषा है जिसका उपयोग मॉडलिंग के डेटाफ्लो, व्यवहार और संरचनात्मक शैली द्वारा एक डिजिटल प्रणाली को मॉडल करने के लिए किया जाता है। यह भाषा पहली बार VHSIC कार्यक्रम के तहत रक्षा विभाग (DoD) के लिए 1981 में शुरू की गई थी।

एक डिजाइन का वर्णन

VHDL में एक हार्डवेयर मॉड्यूल का वर्णन करने के लिए एक इकाई का उपयोग किया जाता है। एक इकाई का उपयोग करके वर्णित किया जा सकता है,

  • इकाई घोषणा
  • Architecture
  • Configuration
  • पैकेज की घोषणा
  • पैकेज बॉडी

आइये देखते हैं ये क्या हैं?

इकाई घोषणा

यह एक हार्डवेयर मॉड्यूल के नाम, इनपुट आउटपुट सिग्नल और मोड को परिभाषित करता है।

Syntax -

entity entity_name is
   Port declaration;
end entity_name;

एक इकाई घोषणा 'इकाई' से शुरू होनी चाहिए और 'अंत' कीवर्ड के साथ समाप्त होनी चाहिए। दिशा इनपुट, आउटपुट या इनऑउट होगी।

में पोर्ट पढ़ा जा सकता है
बाहर पोर्ट लिखा जा सकता है
अंदर बाहर पोर्ट को पढ़ा और लिखा जा सकता है
बफर पोर्ट को पढ़ा और लिखा जा सकता है, इसका केवल एक स्रोत हो सकता है।

Architecture -

वास्तुकला को संरचनात्मक, डेटाफ़्लो, व्यवहार या मिश्रित शैली का उपयोग करके वर्णित किया जा सकता है।

Syntax -

architecture architecture_name of entity_name 
architecture_declarative_part;

begin
   Statements;
end architecture_name;

यहां, हमें उस इकाई का नाम निर्दिष्ट करना चाहिए जिसके लिए हम आर्किटेक्चर बॉडी लिख रहे हैं। आर्किटेक्चर स्टेटमेंट 'शुरू ’और'nd’ कीवर्ड के अंदर होना चाहिए। आर्किटेक्चर घोषणात्मक भाग में चर, स्थिरांक या घटक घोषणा हो सकती है।

डेटा प्रवाह मॉडलिंग

इस मॉडलिंग शैली में, इकाई के माध्यम से डेटा का प्रवाह समवर्ती (समानांतर) सिग्नल का उपयोग करके व्यक्त किया जाता है। वीएचडीएल में समवर्ती स्टेटमेंट WHEN और GENERATE हैं।

उनके अलावा, कोड के निर्माण के लिए केवल ऑपरेटरों (और, नहीं, +, *, sll, आदि) का उपयोग करने वाले असाइनमेंट का भी उपयोग किया जा सकता है।

अंत में, एक विशेष प्रकार का असाइनमेंट, जिसे BLOCK कहा जाता है, को भी इस तरह के कोड में नियोजित किया जा सकता है।

समवर्ती कोड में, निम्नलिखित का उपयोग किया जा सकता है -

  • Operators
  • WHEN स्टेटमेंट (WHEN / ELSE या साथ / SELECT / WHEN);
  • सामान्य कथन;
  • ब्लॉक बयान

व्यवहार मॉडलिंग

इस मॉडलिंग शैली में, बयान के सेट के रूप में एक इकाई के व्यवहार को निर्दिष्ट क्रम में क्रमिक रूप से निष्पादित किया जाता है। केवल एक प्रक्रिया, समारोह, या प्रक्रिया के अंदर रखे गए बयान क्रमिक हैं।

प्रक्रियाएँ, फ़ंक्शंस और प्रक्रियाएँ कोड के एकमात्र खंड हैं जिन्हें क्रमिक रूप से निष्पादित किया जाता है।

हालाँकि, एक पूरे के रूप में, इनमें से कोई भी ब्लॉक अभी भी समवर्ती है, इसके बाहर किसी भी अन्य विवरण के साथ।

व्यवहार कोड का एक महत्वपूर्ण पहलू यह है कि यह अनुक्रमिक तर्क तक सीमित नहीं है। दरअसल, इसके साथ, हम अनुक्रमिक सर्किट और साथ ही साथ कॉम्बिनेशन सर्किट बना सकते हैं।

व्यवहार कथन IF, WAIT, CASE और LOOP हैं। VARIABLES भी प्रतिबंधित हैं और इन्हें केवल अनुक्रमिक कोड में उपयोग किया जाना चाहिए। VARIABLE कभी भी वैश्विक नहीं हो सकता है, इसलिए इसके मूल्य को सीधे पारित नहीं किया जा सकता है।

स्ट्रक्चरल मॉडलिंग

इस मॉडलिंग में, एक इकाई को परस्पर जुड़े घटकों के एक सेट के रूप में वर्णित किया गया है। एक घटक तात्कालिकता बयान एक समवर्ती बयान है। इसलिए, इन कथनों का क्रम महत्वपूर्ण नहीं है। मॉडलिंग की संरचनात्मक शैली केवल घटकों के एक अंतरसंबंध (काली बक्से के रूप में देखी गई) का वर्णन करती है, घटकों के किसी भी व्यवहार को लागू किए बिना और न ही उस इकाई का जो वे सामूहिक रूप से प्रतिनिधित्व करती हैं।

स्ट्रक्चरल मॉडलिंग में, आर्किटेक्चर बॉडी दो भागों से बना है - डिक्लेक्टिव पार्ट (कीवर्ड शुरू होने से पहले) और स्टेटमेंट पार्ट (कीवर्ड शुरू होने के बाद)।

तर्क संचालन - और गेट

एक्स Y जेड
0 0 0
0 1 0
1 0 0
1 1 1

VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;

entity and1 is
   port(x,y:in bit ; z:out bit);
end and1;

architecture virat of and1 is
begin
   z<=x and y; 
end virat;

waveforms

लॉजिक ऑपरेशन - या गेट

एक्स Y जेड
0 0 0
0 1 1
1 0 1
1 1 1

VHDL Code: 
Library ieee; 
use ieee.std_logic_1164.all;  

entity or1 is
   port(x,y:in bit ; z:out bit); 
end or1; 
 
architecture virat of or1 is
begin
   z<=x or y; 
end virat;

waveforms

लॉजिक ऑपरेशन - गेट नहीं

एक्स Y
0 1
1 0

VHDL Code:
  
Library ieee; 
use ieee.std_logic_1164.all; 
 
entity not1 is
   port(x:in bit ; y:out bit); 
end not1; 
 
architecture virat of not1 is
begin
   y<=not x;
end virat;

waveforms

लॉजिक ऑपरेशन - NAND गेट

एक्स Y जेड
0 0 1
0 1 1
1 0 1
1 1 0

VHDL Code:
  
Library ieee; 
use ieee.std_logic_1164.all; 

entity nand1 is
   port(a,b:in bit ; c:out bit); 
end nand1; 
 
architecture virat of nand1 is
begin
   c<=a nand b; 
end virat;

waveforms

लॉजिक ऑपरेशन - NOR गेट

एक्स Y जेड
0 0 1
0 1 0
1 0 0
1 1 0

VHDL Code: 
 
Library ieee; 
use ieee.std_logic_1164.all; 
 
entity nor1 is
   port(a,b:in bit ; c:out bit); 
end nor1; 
 
architecture virat of nor1 is
begin
   c<=a nor b;
end virat;

waveforms

लॉजिक ऑपरेशन - XOR गेट

एक्स Y जेड
0 0 1
0 1 1
1 0 1
1 1 0

VHDL Code: 
 
Library ieee; 
use ieee.std_logic_1164.all;
  
entity xor1 is
   port(a,b:in bit ; c:out bit); 
end xor1;
  
architecture virat of xor1 is
begin
   c<=a xor b; 
end virat;

waveforms

लॉजिक ऑपरेशन - X-NOR गेट

एक्स Y जेड
0 0 1
0 1 1
1 0 1
1 1 0

VHDL Code: 
 
Library ieee; 
use ieee.std_logic_1164.all; 

entity xnor1 is
   port(a,b:in bit ; c:out bit); 
end xnor1; 
 
architecture virat of xnor1 is
begin
   c<=not(a xor b); 
end virat;

waveforms