الگوریتم توماسولو

از ویکی‌پدیا، دانشنامهٔ آزاد

الگوریتم توماسولو یک الگوریتم سخت‌افزاری معماری کامپیوتر برای زمان‌بندی پویا دستورالعمل‌ها است که امکان اجرای خارج از نظم را می‌دهد و استفاده کارآمدتر از واحدهای اجرایی متعدد را ممکن می‌سازد. این الگوریتم توسط رابرت توماسولو در IBM در سال 1967 توسعه یافت و برای اولین بار در واحد ممیز شناور IBM System/360 Model 91 پیاده سازی شد. [۱]

نوآوری‌های اصلی الگوریتم توماسولو شامل تغییر نام رجیستر در سخت‌افزار، ایستگاه‌های رزرو برای همه واحدهای اجرایی، و یک گذرگاه داده مشترک (CDB) است که مقادیر محاسبه‌شده بر روی آن به تمام ایستگاه‌های رزروی که ممکن است به آنها نیاز داشته باشند، پخش می‌شود. این پیشرفت‌ها امکان اجرای موازی بهتر دستورالعمل‌ها را فراهم می‌آورد که در غیر این صورت در الگوریتم اسکوربوردینگ یا الگوریتم های قدیمی تر باعث متوقف شدن خط لوله پردازنده می شدند.

رابرت توماسولو در سال 1997 جایزه اکرت-ماچلی را برای کارش بر روی این الگوریتم دریافت کرد. [۲]

مفاهیم پیاده سازی[ویرایش]

واحد ممیز شناور توماسولو

در این قسمت مفاهیم لازم برای اجرای الگوریتم توماسولو آمده است:

گذرگاه مشترک داده[ویرایش]

گذرگاه مشترک داده (CDB) ایستگاه های رزرو را مستقیماً به واحدهای عملکردی متصل می کند. به گفته توماسولو این گذرگاه "اولویت را حفظ می کند در حالی که همزمانی را تشویق می کند". [۱] : 33 این دو اثر مهم دارد:

  1. واحدهای عملکردی می‌توانند به نتیجه هر عملیاتی بدون درگیر کردن یک ثبات ممیز شناور دسترسی داشته باشند، و به واحدهای متعددی که در انتظار نتیجه هستند اجازه می‌دهند بدون انتظار برای حل اختلاف برای دسترسی به پورت‌های خواندن فایل ثبات، ادامه دهند.
  2. تشخیص هازارد و کنترل اجرا توزیع شده است. ایستگاه های رزرو زمان اجرای یک دستورالعمل را به جای یک واحد تشخیص هازارد اختصاصی کنترل می کنند.

دستور دستورالعمل[ویرایش]

دستورالعمل‌ها به‌طور متوالی صادر می‌شوند تا تأثیرات دنباله‌ای از دستورالعمل‌ها، مانند استثنائات مطرح‌شده توسط این دستورالعمل‌ها، به همان ترتیبی که بر روی یک پردازنده به ترتیب رخ می‌دهد، بدون توجه به این واقعیت که آنها خارج از نظم اجرا می‌شوند، رخ می‌دهند.

تغییر نام ثبات ها[ویرایش]

الگوریتم توماسولو از تغییر نام ثبات برای اجرای صحیح اجرای خارج از نظم استفاده می کند. همه ثبات های ایستگاه‌های رزرو و ثبات های همه منظوره دارای یک مقدار واقعی یا یک مقدار جانشین هستند. اگر در مرحله صدور، مقدار واقعی برای ثبات مقصد در دسترس نباشد، در ابتدا از مقدار جانشین استفاده می شود. مقدار جانشین برچسبی است که نشان می دهد کدام ایستگاه رزرو مقدار واقعی را تولید می کند. هنگامی که کار واحد به پایان رسید و نتیجه را در CDB پخش کرد، مکان جانشین با مقدار واقعی جایگزین می شود.

هر واحد کاربردی دارای یک ایستگاه رزرو واحد است. ایستگاه های رزرو اطلاعات مورد نیاز برای اجرای یک تک دستور، از جمله عملیات و عملوندها را در خود نگهداری می کنند. واحد عملکردی زمانی که آزاد باشد و زمانی که تمام عملوندهای منبع مورد نیاز برای یک دستورالعمل واقعی هستند، پردازش را آغاز می کند.

استثناها[ویرایش]

از نظر عملی، ممکن است استثناهایی وجود داشته باشد که اطلاعات وضعیت کافی در مورد یک استثنا در دسترس نباشد، در این صورت پردازنده ممکن است استثنای خاصی را مطرح کند که به آن استثنا "غیر دقیق" می‌گویند. استثناهای نادقیق نمی توانند در پیاده سازی های به ترتیب رخ دهند، زیرا وضعیت پردازنده فقط به ترتیب برنامه تغییر می کند (به استثناهای خط لوله RISC مراجعه کنید).

برنامه‌هایی که استثناهای «دقیق» را تجربه می‌کنند، زمانی که دستورالعمل خاصی که استثنا را می‌توان تعیین کرد، می‌توانند در نقطه ای که استثنا صادر شده است دوباره راه‌اندازی یا دوباره اجرا شوند. با این حال، مواردی که استثناهای «غیر دقیق» را تجربه می‌کنند، معمولاً نمی‌توانند مجدداً راه‌اندازی یا اجرا شوند، زیرا سیستم نمی‌تواند دستورالعمل خاصی را که استثنا را به وجود آورده است، تعیین کند.

همچنین ببینید[ویرایش]

منابع[ویرایش]

  1. ۱٫۰ ۱٫۱ Tomasulo, Robert Marco (Jan 1967). "An Efficient Algorithm for Exploiting Multiple Arithmetic Units". IBM Journal of Research and Development. IBM. 11 (1): 25–33. doi:10.1147/rd.111.0025. ISSN 0018-8646. خطای یادکرد: برچسب <ref> نامعتبر؛ نام «tomasulo» چندین بار با محتوای متفاوت تعریف شده است. (صفحهٔ راهنما را مطالعه کنید.).
  2. "Robert Tomasulo – Award Winner". ACM Awards. ACM. Retrieved 8 December 2014.

مطالعه بیشتر[ویرایش]

پیوند به بیرون[ویرایش]