**Digital Systems** 

## Computer Assignment 4-5

State Machines and Basic RTL

Mana Mohammadi 810100207



روش کار مدار به این صورت است که ابتدا در state: NoData منتظر 0 شدن serln می مانیم؛ هنگامی که ورودی از 1 به 0 تغییر کرد وارد state: PortNum می شویم، در این استیت یک کانتر 1 بیتی و یک رجیستر 2 بیتی را enable میکنیم، هنگامی که کانتر 2 کلاک را بشمارد، carry out آن 1 میشود، در این حالت کنترلر استیت را به state: ByteNum تغییر میدهد. در این استیت هم شبیه به استیت قبل یک کانتر 2 بیتی و یک رجیستر 4 بیتی را enable میکنیم و کانتر بعد از شمردن 4 کلاک، 2 carry out = 1 میکند که به واسطه آن، کنترلر استیت را به b serln عنیر میدهد. در استیت میدا که به واسطه آن، کنترلر استیت را به b bata تغییر میدهد. در استیت میداد که به واسطه آن، کنترلر استیت را به Data تغییر میدهد. در استیت و nable میکنیم که هر گاه شمارش کلاک آن برابر با خروجی مورد نظر ما انتقال میدهد. همینطور یک counter / comparator را enable میکنیم که هر گاه شمارش کلاک آن برابر با تعداد بیت مورد نظر ما شد، Co یک تحویل دهد (به عنوان ورودی به این کامپوننت، تعداد بایت های ذخیره شده در رجیستر 4 بیتی ضربدر 8 تحویل میدهیم؛ یعنی 3 بار به چپ شیفت میدهیم.) بعد از 1 شدن carry out کانتر، به state: NoData می رویم.

## 👃 خروجی های دیگر مدار :

- d : همان PortNum است.
- outValid : هنگامی که در استیت Data هستیم 1 میشود تا یوزر بداند که در حال انتقال دیتای مورد نظر هستیم.
- ps : Data و ps : Data و ns : NoData و ns : NoData و ps : Data وقتى انتقال دیتا تمام شده، اگر serIn=0 باشد، ارور یک میماند.



- مشاهده می شود که پس از 0 شدن serIn به اندازه 6 کلاک (60ns) طول میکشد تا مقداری روی پورت خروجی برود، یا outValid برای ByteNum است.
- دفعه دوم و سوم مشاهده میشود که serln پس از مبادله داده و تمام شدن دیتا ها 1 نشده و در نتیجه ارور 1 میشود و 6 کلاک پس از 0 شدن آن (1 شدن 1) خروجی روی پورت مورد نظر دیده میشود.
- همینطور در عکس ها دیده میشود که تبادل داده ها دفعه اول و دوم به ترتیب 1200ns و 960ns طول کشیده که همان 120 کلاک و 96 کلاک هستند که برابر با BitNum هر تبادلند.