1 / 38

مقدمه

درس معماری کامپیوتر فصل هفتم کنترل ریزبرنامه ریزی شده Micro-programmed Control تهیه شده توسط حسین امیرخانی. مقدمه. یادآوری: Micro-operation : ریزعمل Macro-operation یا Instruction : دستورالعمل دنباله‌ای از ریزعملیات. وظیفه‌ی واحد کنترل:

eliana-odom
Download Presentation

مقدمه

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. درس معماری کامپیوترفصل هفتمکنترل ریزبرنامه ریزی شدهMicro-programmed Controlتهیه شده توسط حسین امیرخانی

  2. مقدمه • یادآوری: • Micro-operation: ریزعمل • Macro-operation یا Instruction: دستورالعمل • دنباله‌ای از ریزعملیات. • وظیفه‌ی واحد کنترل: • راه اندازی دنباله‌ای از ریزعملیات برای اجرای دستورالعمل‌های کاربر. حافظه‌ی اصلی واحد کنترل دستورالعمل اجرای ریزعملیات

  3. انواع واحد کنترل 1. واحد کنترل سخت افزاری یا سیم بندی شده (Hardwired) 2. واحد کنترل ریزبرنامه ریزی شده (Mircro-programmed)

  4. واحد کنترل سخت افزاری • واحد کنترل کامپیوتر پایه‌ی فصل 5 به این طریق طراحی شد. • ریزعملیات مربوط به کلیه‌ی دستورالعمل‌ها تحلیل شده و از طریق تکنیک‌های مدارهای منطقی رایج، سخت افزار مربوطه طراحی می‌شود. • مثال: برای ثبات AR

  5. واحد کنترل سخت افزاری • افزودن دستورالعمل در واحد کنترل سخت افزاری: • بسیار مشکل. • راه حل جایگزین: • واحد کنترل ریزبرنامه ریزی شده.

  6. واحد کنترل ریزبرنامه ریزی شده • ابتدا از طریق تکنیک‌های سخت افزاری، واحدی طراحی می‌شود که قابلیت اجرای ریزعملیات مختلف را دارد. • برای اجرای هر دستورالعمل، کافی است ریزعملیات مربوطه را به واحد فوق بدهیم. • ریزعملیات مربوط به هر دستورالعمل در حافظه‌ای خاص به نام حافظه‌ی کنترلی ذخیره می‌شود. واحدی با قابلیت اجرای ریزعملیات ریزعمل اجرای ریزعمل

  7. مقایسه‌ی واحدهای کنترل واحد کنترل ریزبرنامه ریزی شده حافظه‌ی اصلی اجرای ریزعملیات واحدی با قابلیت اجرای ریزعملیات حافظه‌ی کنترل دستورالعمل ریزعملیات حافظه‌ی اصلی واحد کنترل سخت افزاری دستورالعمل اجرای ریزعملیات

  8. مقایسه‌ی واحدهای کنترل • واحد کنترل سخت افزاری: • تغییر در آن مشکل است. • می‌توان سخت افزار بهینه طراحی کرد: سرعت بالاتر. • واحد کنترل ریزبرنامه ریزی شده: • تغییر در آن ساده است: تغییر در محتویات حافظه‌ی کنترل بدون نیاز به تغییر در سخت افزار.

  9. اصطلاحات • به هر کلمه در حافظه‌ی کنترل یک ریزدستورالعمل گویند (Micro-instruction). • هر ریزدستورالعمل، یک کلمه‌ی کنترل (control word) است که مشخص می‌کند چه ریزعملیاتی اجرا شوند و چه ریزعملیاتی راکد باشند. • به مجموعه‌ای از ریزدستورالعمل‌ها یک ریزبرنامه (micro-program) گویند.

  10. بنابراین، در کنترل ریزبرنامه ریزی شده، دو حافظه در سیستم داریم: • حافظه‌ی اصلی • در اختیار کاربر برای ذخیره‌ی برنامه‌ها و داده‌ها. • در حین اجرای برنامه ممکن است تغییر کند. • حافظه‌ی کنترل • در اختیار طراح برای ذخیره‌ی ریزبرنامه‌ها. • محتوای آن در حین اجرای برنامه ثابت است. • هریک از دستورالعمل و ریزدستورالعمل، در کدام حافظه قرار دارند؟

  11. حافظه‌ی کنترلی • می‌تواند از نوع فقط خواندنی (ROM) باشد یا قابلیت نوشتن هم داشته باشد (RAM). • اگر از RAM استفاده شود به آن ریزبرنامه‌نویسی پویا (dynamic microprogramming) گویند. • معمولاً ROM استفاده می‌شود: • ارزانتر و سریع‌تر از RAM، • کاربر معمولی نمی‌تواند محتوای آن‌را تغییر دهد.

  12. آدرس دهی حافظه‌ی کنترلی • حافظه‌ی کنترلی نیاز به ثباتی برای مشخص کردن آدرس ریزدستورالعمل دارد: • Control Address Register (CAR) • همین‌طور مداری برای تولید آدرس بعدی حافظه‌ی کنترلی مورد نیاز است: • Next Address Generator یا Sequencer (توالی‌گر).

  13. توالی‌گر آدرس • در حافظه‌ی کنترل، برای هر دستورالعمل، یک روال (routine) خاص شامل مجموعه‌ای از ریزدستورالعمل‌ها وجود دارد. • به فرآیند تبدیل بیت‌های کد دستورالعمل به آدرس روال مربوط به آن دستورالعمل در حافظه‌ی کنترلی، نگاشت (mapping) گوییم. • توالی‌گر آدرس باید قابلیت افزایش مقدار CAR را داشته باشد تا کلیه‌ی ریزدستورالعمل‌های روال مربوط به یک دستورالعمل را آدرس دهی نماید.

  14. توالی‌گر آدرس • لازم است برای ساده کردن ریزبرنامه نویسی، امکان فراخوانی و بازگشت از زیرروال و همچنین امکان پرش‌های شرطی و غیرشرطی فراهم شود. • بنابراین، قابلیت‌های مورد نیاز توالی‌گر آدرس عبارتند از: • نگاشت. • افزایش CAR. • پرش شرطی و غیرشرطی. • فراخوانی و بازگشت از زیرروال.

  15. بیت‌هایی از وضعیت سیستم بازگشت از زیرروال شرط پرش محل پرش

  16. عملیات نگاشت (Mapping) • مثالی از یک نوع نگاشت: • فرض: حافظه‌ی کنترل دارای 128 کلمه است. • در نگاشت فوق، برای هر دستورالعمل می‌توان یک روال ریزبرنامه با ظرفیت چهار ریزدستورالعمل داشت. • اگر روال به بیش از چهار ریزدستورالعمل نیاز داشت، می‌توان از آدرس‌های 1000000 تا 1111111 استفاده نمود.

  17. مثالی از طراحی واحد کنترل ریزبرنامه ریزی شده انتقال اطلاعات از طریق مولتی پلکسر انجام می‌شود و نه باس تنها ثباتی که با حافظه ارتباط مستقیم دارد: DR ثبات‌های واحد کنترل ALU برروی DR و AC عملیات را انجام داده و حاصل را در AC قرار می‌دهد.

  18. فرمت دستورالعمل‌های کامپیوتر مثال فوق برای سادگی

  19. فرمت ریزدستورالعمل‌ها برای هر ریزدستور نمی‌توان بیش از سه ریزعمل انتخاب نمود. اگر کمتر از سه ریزعمل مورد نیاز بود، از کد 000 با سمبول NOP استفاده می‌کنیم. آیا F1=010 و F2=001 و F3=000 معتبر است؟ خیر! عملیات متضاد.

  20. فرمت ریزدستورالعمل‌ها نوع پرش آدرس پرش شرط پرش (condition) مستقل از AD و CD

  21. ریزبرنامه نویسی • هر سطر از حافظه‌ی کنترلی: یک ریزدستورالعمل • به‌صورت سمبولیک (اسمبلی) دارای 5 بخش است: Label: F1,F2,F3 CD BR AD • یکی از این سه مورد: • 1. یک برچسب • 2. سمبول NEXT: آدرس بعدی • 3. اگر BR برابر RET یا MAP • بود، AD خالی گذاشته می‌شود. برای آدرس دهی. می‌تواند خالی باشد. اگر یک یا دو سمبول، NOP بودند، آن‌ها را نمی‌نویسیم. اگر هر سه سمبول NOP بودند، NOP را می‌نویسیم.

  22. روال برداشت (Fetch Routine) • روالی برای تولید ریزعملیات مربوط به فاز برداشت.

  23. روال برداشت (Fetch Routine)

  24. روال برداشت (Fetch Routine) • روال برداشت دارای سه ریزدستورالعمل است که در آدرس‌های 64، 65 و 66 قرار می‌دهیم. • باید در بخشی از 64 کلمه‌ی آخر حافظه‌ی کنترل قرار گیرد، زیرا 64 کلمه‌ی اول مربوط به روال‌های 16 دستورالعمل است.

  25. روال محاسبه‌ی آدرس مؤثر • ریزدستورالعمل‌هایی برای تولید ریزعملیات مربوط به محاسبه‌ی آدرس مؤثر. • روش آدرس دهی غیرمستقیم (indirect) در همه‌ی دستورات حافظه‌ای می‌تواند به‌کار رود. • آن‌را به‌صورت یک روال ذخیره می‌کنیم.

  26. روال محاسبه‌ی آدرس مؤثر

  27. روال محاسبه‌ی آدرس مؤثر • در خانه‌ی 67 و 68 حافظه‌ی کنترلی:

  28. ریزبرنامه‌ی مربوط به دستورالعمل ADD

  29. ریزبرنامه‌ی مربوط به دستورالعمل BRANCH

  30. ریزبرنامه‌ی مربوط به دستورالعمل STORE

  31. ریزبرنامه‌ی مربوط به دستورالعمل EXCHANGE چون حساس به لبه (edge triggered) هستند امکان پذیر است

  32. ریزبرنامه‌ی باینری ریزبرنامه‌ی سمبولیک اسمبلر ریزبرنامه‌ی باینری

  33. ریزبرنامه‌ی باینری پرش بدون شرط به روال برداشت

  34. طراحی بخش سخت افزاری واحد کنترل • یک بار طراحی شده و بعد از آن بدون تغییر باقی می‌ماند. • تغییرات فقط در محتوای حافظه‌ی کنترلی انجام می‌شود. واحد کنترل ریزبرنامه ریزی شده ریزعملیات حافظه‌ی اصلی اجرای ریزعملیات واحدی با قابلیت اجرای ریزعملیات حافظه‌ی کنترل دستورالعمل استخراج ریزعملیات از ریزدستورالعمل انتخاب آدرس بعدی

  35. طراحی بخش سخت افزاری واحد کنترل استخراج ریزعملیات از ریزدستورالعمل و اجرای ریزعملیات

  36. طراحی بخش سخت افزاری واحد کنترل مدار انتخاب آدرس بعدی (توالی‌گر)

  37. مثال

  38. طراحی بخش سخت افزاری واحد کنترل مدار انتخاب آدرس بعدی (توالی‌گر) ورودی و خروجی 7 بیتی امکان فراخوانی تا یک سطح

More Related