Mikroprogram
Mikroprogram,mikrokod–programimplementującylistę rozkazów procesora.Podobnie jakjęzyk wysokiego poziomujestkompilowanydokodu maszynowego,tak każdyrozkazkodu maszynowego ma postać ciągumikroinstrukcjinazywanego mikroprogramem lub mikrokodem.
Elementy tworzące mikroprogram znajdują się na pojęciowo niższym poziomie niż instrukcje języka maszynowego (asemblera). Aby więc odróżnić je od elementów programowania niskopoziomowego, stosuje się przedrostekmikro-:mikroprogram, mikrokod, mikroinstrukcja, mikroasembler.
Mikroprogramy są szczegółowo dopracowywane i optymalizowane pod kątem jak najszybszego wykonania. Zaniedbanie na tym poziomie grozi dużym spowolnieniem programów, które będą uruchamiane na tym procesorze. Mikroprogramista musi posiadać gruntowną wiedzę na temat obwodów elektrycznych danego typu komputera, ponieważ na nich właśnie operuje mikrokod. Mikroprogram jest pisany przez twórców procesorów w fazie projektowania.
W większości procesorów korzystających z mikrokodu, mikroprogram nie znajduje się wpamięci operacyjnej,lecz w specjalnej szybkiej pamięci zwanej pamięcią sterującą (ang.control store). Może być topamięć tylko do odczytulubpamięć o dostępie swobodnym.W drugim przypadku mikrokod jest ładowany do pamięci sterującej, z innego urządzenia pamięci, podczas inicjacji procesora. Wtedy też możliwe jest modyfikowanie mikrokodu w celu usunięcia błędów lub dodania nowych instrukcji. Mikrokod może również pozwalać naemulacjęinnej, zwykle bardziej złożonej,architektury komputerowej.
Początki mikroprogramowania
[edytuj|edytuj kod]Mikrokod został stworzony, by uprościć proces programowania maszyny. Początkowo lista rozkazów procesora była na sztywno wbudowana w fizyczną architekturę komputera. Każdej elementarnej instrukcji (dodawaniu, przesuwaniu, kopiowaniusłów) odpowiadałukład elektroniczny.Zapewniało to wprawdzie bardzo szybkie wykonanie programu, jednak listy rozkazów stawały się coraz bardziej złożone, a ich projektowanie i testowanie w postaci fizycznych obwodów elektrycznych coraz trudniejsze.
Mikroprogramowanie zminimalizowało ten problem pozwalając projektantom procesorówimplementowaćlistę instrukcji jako mikroprogram, a nie zespół obwodów elektrycznych. W przeciwieństwie do wbudowanych instrukcji, nawet w zaawansowanej fazie projektowania mikrokod mógł być łatwo zmieniony. W ten sposób projektowanie procesorów zostało znacznie ułatwione i pozwoliło na dalsze rozbudowywanie list rozkazów procesora.
Możliwość znacznego rozbudowania listy rozkazów procesora była istotną zaletą. Od lat 60. aż do późnych lat 70. znaczna część programowania odbywała się za pomocą języków asemblera, czyli symbolicznych odpowiedników rozkazów maszynowych. Większa abstrakcyjność (wysokopoziomowość) instrukcji oznaczała większą produktywność programisty. Doprowadziło to do projektów opartych o bezpośrednio wykonywalne języki wysokiego poziomu, gdzie każde wyrażenie języka wysokiego poziomu takiego jakPL/Imogło być bezpośrednio wykonane przez mikrokod sprzętu z pominięciem kompilacji. Przykładami tego podejścia byłyIBM Future SystemsiFountainhead Project(firmyData General).
Mikroprogramowanie pozwoliło również uporać się z problemem przepustowości pamięci. W latach 70. wydajność procesorów rosła dużo szybciej niż przepustowość pamięci, więc stosowano różne techniki akceleracji, takie jak przesyłanie bloków pamięci, czytanie z wyprzedzeniem czy wielopoziomowepamięci podręczne.Instrukcje maszynowe wysokiego poziomu (implementowane w mikrokodzie) pozwalały dodatkowo odciążać pamięć. Na przykład całe operacje na łańcuchach znaków mogły być wykonywane dzięki pojedynczej instrukcji procesora i nie wymagały wielokrotnego uciekania się do pamięci w celu pobrania kolejnych instrukcji programu.
Do architektur korzystających z wysokopoziomowych instrukcji procesora należąIBM System/360iVAX.Podejście polegające na używaniu wysoce złożonych instrukcji procesora implementowanych przy pomocy mikrokodu zostało później nazwaneCISC.Pierwszym procesorem w architekturzex86(wykorzystywanym wkomputerach PC), w którym pojawiła się możliwość aktualizacji mikrokodu byłPentium Proz 1995 r, a aktualizacja ta mogła być wykonywana przez systemBIOSbądź też przez dowolnysystem operacyjny[1].
Zobacz też
[edytuj|edytuj kod]Przypisy
[edytuj|edytuj kod]- ↑Andreas Stiller, Matthias Paul.Prozessorgeflüster.„c't – magazin für computertechnik”, 1996-05-12. Heise Verlag.(niem.).
Bibliografia
[edytuj|edytuj kod]- M.Morris Mano:Architektura komputerów.WNT, 1988.ISBN83-204-0888-1.