Web - Amazon

We provide Linux to the World


We support WINRAR [What is this] - [Download .exe file(s) for Windows]

CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
SITEMAP
Audiobooks by Valerio Di Stefano: Single Download - Complete Download [TAR] [WIM] [ZIP] [RAR] - Alphabetical Download  [TAR] [WIM] [ZIP] [RAR] - Download Instructions

Make a donation: IBAN: IT36M0708677020000000008016 - BIC/SWIFT:  ICRAITRRU60 - VALERIO DI STEFANO or
Privacy Policy Cookie Policy Terms and Conditions
Mikroprogram - Wikipedia, wolna encyklopedia

Mikroprogram

Z Wikipedii

Mikroprogram (mikrokod) - program implementujący listę rozkazów CPU. Podobnie jak język wysokiego poziomu jest kompilowany do kodu maszynowego, tak każda instrukcja kodu maszynowego ma postać ciągu mikroinstrukcji nazywanego 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ę przedrostek mikro-: mikroprogram, mikrokod, mikroinstrukcja, mikroasembler, itp.

Mikroprogramy są szczegółowo dopracowywane i optymalizowane pod kątem jak najszybszego wykonania. Zaniedbanie na tym poziomie grozi dużym spowolnieniem programów działających na procesorze. Mikroprogramista musi posiadać gruntowną wiedzę na temat obwodów elektrycznych komputera, ponieważ na nich właśnie operuje mikrokod. Mikroprogram jest pisany przez twórców CPU w fazie projektowania.

W większości komputerów korzystających z mikrokodu, mikroprogram nie znajduje się w pamięci operacyjnej, lecz w specjalnej szybkiej pamięci zwanej pamięcią sterującą (ang. control store). Może być to pamięć tylko do odczytu lub pamięć o dostępie swobodnym. W drugim przypadku mikrokod jest ładowany do pamięci sterującej z innego urządzenia pamięci podczas inicjacji CPU. Wtedy też możliwe jest modyfikowanie mikrokodu w celu usunięcia błędów lub dodania nowych instrukcji. Mikrokod może również pozwalać na emulację innej, zwykle bardziej złożonej, architektury komputerowej.

[edytuj] Początki mikroprogramowania

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, kopiowaniu słó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ów implementować 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 CPU 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ą. W latach 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 (ang. Directly Executable High Level Language), gdzie każde wyrażenie języka wysokiego poziomu takiego jak PL/I mogło być bezpośrednio wykonane przez mikrokod sprzętu z pominięciem kompilacji. Przykładami tego podejścia były IBM Future Systems i Data General Fountainhead Project.

Mikroprogramowanie pozwoliło również uporać się z problemem przepustowości pamięci. W latach 70. prędkość procesorów rosła dużo szybciej niż prędkość pamięci. Stosowano wtedy różne techniki akceleracji, takie jak przesyłanie bloków pamięci, czytanie z wyprzedzeniem czy wielopoziomowe pamięci podręczne. Instrukcje maszynowe wysokiego poziomu (implementowane w mikrokodzie) pozwoliły dodatkowo odciążyć pamięć. Na przykład całe operacje na łańcuchach znaków mogły być wykonane dzięki pojedynczej instrukcji procesora i nie wymagały wielokrotnego uciekania się do pamięci w celu pobrania kolejnej instrukcji programu.

Do architektur korzystających z wysokopoziomowych instrukcji procesora należą IBM System/360 i DEC VAX. Podejście polegające na używaniu wysoce złożonych instrukcji procesora implementowanych przy pomocy mikrokodu zostało później nazwane CISC.


Zalążek artykułu To jest tylko zalążek artykułu związanego z informatyką. Jeśli potrafisz, rozbuduj go.

Our "Network":

Project Gutenberg
https://gutenberg.classicistranieri.com

Encyclopaedia Britannica 1911
https://encyclopaediabritannica.classicistranieri.com

Librivox Audiobooks
https://librivox.classicistranieri.com

Linux Distributions
https://old.classicistranieri.com

Magnatune (MP3 Music)
https://magnatune.classicistranieri.com

Static Wikipedia (June 2008)
https://wikipedia.classicistranieri.com

Static Wikipedia (March 2008)
https://wikipedia2007.classicistranieri.com/mar2008/

Static Wikipedia (2007)
https://wikipedia2007.classicistranieri.com

Static Wikipedia (2006)
https://wikipedia2006.classicistranieri.com

Liber Liber
https://liberliber.classicistranieri.com

ZIM Files for Kiwix
https://zim.classicistranieri.com


Other Websites:

Bach - Goldberg Variations
https://www.goldbergvariations.org

Lazarillo de Tormes
https://www.lazarillodetormes.org

Madame Bovary
https://www.madamebovary.org

Il Fu Mattia Pascal
https://www.mattiapascal.it

The Voice in the Desert
https://www.thevoiceinthedesert.org

Confessione d'un amore fascista
https://www.amorefascista.it

Malinverno
https://www.malinverno.org

Debito formativo
https://www.debitoformativo.it

Adina Spire
https://www.adinaspire.com