Принцип работы процессора
Устройство и основные характеристики процессора. Тактовая частота как самый важный показатель скорости работы процессора. Основные особенности процессора Pentium, принцип его работы. Методы повышения производительности в новых конструкциях процессоров.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | реферат |
Язык | русский |
Дата добавления | 15.06.2012 |
Размер файла | 23,9 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru
Введение
...1949 год был, в общем-то, не слишком примечательным годом в истории человечества. Не считая разве что того примечательного факта, что именно в этом году над американской пустыней сошла со своих небесных трасс знаменитая «летающая тарелка из Нью-Мексико». Та самая, над загадкой которой до сих пор безуспешно ломает голову все прогрессивное человечество. Сегодня выжившие свидетели тех далеких дней утверждают, что при тщательном потрошении сего неопознанного объекта из него были извлечены не только трупы инопланетян, но и некие управляющие устройства, на основе которых и были созданы микропроцессоры...
Допустим, так оно и было. И инопланетяне были (вскрытие оных даже было вроде бы запечатлено на кинопленку и сегодня соответствующий фильм продается едва ли не в каждом киоске), и инопланетные же процессоры. Правда, трудно представить себе НЛО, чьим управлением заведуют устройства, аналогичные первым процессорам Intel-4004.
Но может быть, поэтому и грохнулась тарелочка?
Как бы то ни было, для «копирования» инопланетной техники ученые избрали весьма долгий и извилистый путь. Сначала (для отвода глаз) были изобретены отдельные элементы -- транзисторы, заменившие традиционные электронные лампы в первых компьютерах. Затем через десяток лет хитроумные инженеры, посмеиваясь (Еще бы! Конечный-то результат всех их трудов уже давно лежал в сейфе!), «изобрели» интегральные микросхемы, позволяющие уместить на одном кристалле большое количество транзисторов. И еще только через десяток лет миру явился сам микропроцессор, содержащий уже тысячи и миллионы этих самых транзисторов.
Отдадим должное выдержке и упорству хитрых плагиаторов... и примитивности инопланетной техники.
А теперь серьезно.
Первый микропроцессор Intel 4004 был создан в 1971 году командой во главе с талантливым изобретателем, доктором Тедом Хоффом. Сегодня его имя стоит в ряду с именами величайших изобретателей всех времен и народов... Но вряд ли мудрый доктор знал в то время, во что выльется созданный им «компьютер на одном кристалле». Изначально процессор 4004 предназначался для... микрокалькуляторов и был изготовлен по заказу одной японской фирмы. К счастью для всех нас, фирма эта обанкротилась, так и не дождавшись процессор гипа.сокет» обещанного микропроцессора -- и в результате разработка перешла в собственность не ожидавшей такого счастья Intel. С этого момента и началась эпоха персональных компьютеров, «звездный час» которых настал в начале 80-х. Именно тогда фирмой IBM был выпущен уже ставший легендарным компьютер IBM PC на основе нового микропроцессора все той же фирмы Intel...
Сегодняшние процессоры от Intel быстрее своего прародителя более чем в десять тысяч раз! А любой домашний компьютер обладает мощностью и «сообразительностью» во много раз большей, чем компьютер, управлявший полетом космического корабля «Аполлон» к Луне.
Факт, который автор не постеснялся привести строкой выше, уже давно стал штампом, обязательным в любой рекламе фирмы Intel. Хотя и не стал от этого менее правдивым и красноречивым.
И теперь, в эпоху гигагерцовых скоростей и сверхъестественной «сообразительности» компьютеров, из тени выходит весьма сакраментальный вопрос: а сможет ли человек правильно распорядиться этой внезапно свалившейся на него мощностью?
Процессоров в компьютере много. Помимо центрального процессора, который во всем мире принято обозначать аббревиатурой CPU (Central Processor Unit), схожими микросхемами оборудовано практически каждая компьютерная «железяка».
Главный, центральный процессор с легкой руки журналистов называют «королем» системного блока, единовластно повелевающим всеми его ресурсами. Но уследить абсолютно за всем, что происходит в его «королевстве», даже шустрый процессор не в состоянии -- королевская занятость разбрасываться не позволяет. И тогда на помощь «королю» приходят «наместники» -- специализированные микропроцессоры-чипы по обработке, например, обычной и трехмерной графики, 3D звука, компрессии и декомпрессии... Таких «наместников» в компьютере много и размещаются они на специализированных, дополнительных платах (о них -- речь впереди). И называются они уже не «процессорами», а просто «чипами». С этим термином нам еще частенько придется встретиться на страницах этой книги...
На первый взгляд, процессор -- просто выращенный по специальной технологии кристалл кремния (не зря на жаргоне процессор, именуется «камнем»). Однако камешек этот содержит в себе множество отдельных элементов -- транзисторов, которые в совокупности и наделяют компьютер способностью «думать». Точнее, вычислять, производя определенные математические операции с числами, в которые преображается любая поступающая в компьютер информация. Таких транзисторов в любом микропроцессоре многие миллионы. А в допроцессорную эпоху роль «вычислителей» несли на себе в миллионы раз более громоздкие устройства... Началось все еще в 30-х годах нашего столетия с механических переключателей -- реле, в сороковые им на смену пришли электронные лампы. Только представьте себе -- сотни тысяч электронных ламп, громадное количество аппаратуры размером с хороший дом! Работали такие компьютеры не только медленно, но и крайне недолго -- одна перегоревшая лампа немедленно выводила из строя весь компьютер. Бесперебойная работа в течение 10--15 минут -- вот и все, на что были способны «ламповые» компьютеры.
В 50-х годах на смену капризным лампам пришли компактные «электронные переключатели» -- транзисторы, затем -- интегральные схемы, в которых впервые удалось объединить на одном кристалле кремния сотни крохотных транзисторов. Но все-таки отсчет летоисчисления компьютерной эры ведут с 1971 года, с момента появления первого микропроцессора...
За три десятка лет, прошедших с этого знаменательного дня, процессоры сильно изменились. Сегодняшний процессор -- это не просто скопище транзисторов, а целая система множества важных устройств. На любом процессорном кристалле находятся:
1. Собственно процессор, главное вычислительное устройство, состоящее из миллионов логических элементов -- транзисторов.
2.. Сопроцессор -- специальный блок для операций с «плавающей точкой» (или запятой). Применяется для особо точных и сложных расчетов, а также для работы с рядом графических программотихоньку начинает выхо-3. Кэш-память первого уровня -- небольшая (несколько десятков килобайт) сверхбыстрая память, предназначенная для хранения промежуточных результатов вычислений.
4. Кэш-память второго уровня -- эта память чуть помедленнее, зато больше -- от 128 до 512 кбайт.
Трудно поверить, что все эти устройства размещаются на кристалле площадью не более 4--6 квадратных сантиметров! Только под микроскопом мы можем разглядеть крохотные элементы, из которых состоит микропроцессор, и соединяющие их металлические «дорожки» (для их изготовления сегодня используется алюминий, однако уже через год на смену ему должна прийти медь). Их размер поражает воображение -- десятые доли микрона! Например, в 1999 году большая часть процессоров производилась по 0,25-микронной технологии, в 2000 году ей на смену пришла 0,18- и даже 0,13-микронная. При этом ожидается, что в течение ближайших двух лет плотность расположения элементов на кристалле увеличится еще в 2 раза.
Впрочем, при выборе микропроцессора мы руководствуемся отнюдь не «микронностью» технологии, по которой этот процессор сделан. Существуют другие, гораздо более важные для нас характеристики процессора, которые прямо связаны с его возможностями и скоростью работы.
Тактовая частота. Скорость работы -- конечно же, именно на этот показатель мы обращаем внимание в первую очередь! Хотя лишь немногие пользователи понимают, что, собственно, он означает. Ведь для нас, неспециалистов, важно лишь то, насколько быстро новый процессор может работать с нужными нам программами -- а как, спрашивается, оценить эту скорость?
У специалистов существует своя система измерения скорости процессора. Причем таких скоростей (измеряемых в миллионах операций в секунду -- MIPS) может быть несколько -- скорость работы с трехмерной графикой, скорость работы в офисных приложениях и так далее...
Не слишком удобно. Поэтому большинство пользователей, говоря о скорости процессора, подразумевает совсем другой показатель. А называется он тактовой частотой. Эта величина, измеряемая в мегагерцах (МГц), показывает, сколько инструкций способен выполнить процессор в течение секунды) Тактовая частота обозначается цифрой в названии процессора (например, Pentium 4-1200, то есть процессор поколения Pentium 4 с тактовой частотой 1200 МГц или 1,2 ГГц).
Сегодня наибольшей популярностью на рынке пользуются процессоры с частотой от 800 до 1200 МГц. Однако тем, кто будет читать эту книжку в конце 2001 года, автору придется посоветовать приобретать процессор с частотой не менее 1,5 ГГц. Ведь согласно так называемому «закону Мура», названного в честь одного из изобретателей микропроцессора и нынешнего руководителя корпорации Intel, каждые полтора года частота микропроцессоров увеличивается не менее, чем в два раза...
Тактовая частота -- бесспорно, самый важный показатель скорости работы процессора. Но далеко не единственный. Иначе как объяснить тот странный факт, что процессоры Celeron, Pentium III и Pentium 4 на одной и той же частоте работаюЗдесь вступают в силу новые факторы -- поколение и модификация данного процессора.
Поколения процессоров отличаются друг от друга скоростью работы, архитектурой, исполнением и внешним видом... словом, буквально всем. Причем отличаются не только количественно, но и качественно. Так, при переходе от Pentium к Pentium II и затем -- к Pentium III была значительно расширена система команд (инструкций) процессора.
Бели брать за точку отсчета изделия «королевы» процессорного рынка, корпорации Intel, то за всю 27-летнюю историю процессоров этой фирмы сменилось восемь их поколений: 8088, 286, 386, 486, Pentium, Pentium II, Pentium III, Pentium 4.
Принцип действия процессора
Процессор является главным элементом ЭВМ. Он прямо или косвенно управляет всеми устройствами и процессами, происходящими в ЭВМ.
В конструкции современных процессоров четко просматривается тенденция постоянного увеличения тактовой частоты. Это естественно, чем больше операций выполняет процессор, тем выше его производительность. Предельная тактовая частота во многом определяется существующей технологией производства микросхем (наименьшими достижимыми размерами элементов, которые определяют минимальное время передачи сигналов).
Кроме повышения тактовой частоты, увеличение производительности процессоров достигается разработчиками менее очевидными приемами, связанными с изобретением новых архитектур и алгоритмов обработки информации. Некоторые из них рассмотрим на примере процессора Pentium (P5) и последующих моделей. Перечислим основные особенности процессора Pentium:
* - конвейерная обработка информации;
* - суперскалярная архитектура;
* - наличие раздельных кэш-памятей для команд и данных;
* - наличие блока предсказания адреса перехода;
* - наличие блока вычислений с плавающей точкой;
* - поддержка многопроцессорного режима работы;
* - наличие средства обнаружения ошибок.
Термин «суперскалярная архитектура» означает, что процессор содержит более одного вычислительного блока. Эти вычислительные блоки чаще называют конвейерами. Заметим, что первая суперскалярная архитектура была реализована в отечественной ЭВМ «Эльбрус-1» (1978 г.).
Наличие в процессоре двух конвейеров позволяет ему одновременно выполнять (завершать) две команды (инструкции).
Каждый конвейер разделяет процесс выполнения команды на несколько этапов (например, пять):
* - выборка (считывание) команды из ОЗУ или кэш-памяти;
* - декодирование (дешифрация) команды, т. е. определение кода выполняемой операции;
* - выполнение команды;
* - обращение к памяти;
* - запоминание полученных результатов в памяти.
Для реализации каждого из перечисленных этапов (каждой операции) служит отдельное устройство - ступень. Таким образом, в каждом конвейере процессора Pentium имеется пять ступеней.
При конвейерной обработке на выполнение каждого этапа отводится один такт синхронизирующей (тактовой) частоты. В каждом новом такте заканчивается выполнение одной команды и начинается выполнение новой команды. Такое выполнение команд называют поточной обработкой.
Образно ее можно сравнить с производственным конвейером (потоком), где на каждом участке с разными изделиями выполняют всегда одну и ту же операцию. При этом, когда готовое изделие сходит с конвейера, на него заходит новое, а остальные изделия в это время находятся на разных стадиях готовности. Переход изготавливаемых изделий с участка на участок должен происходить синхронно, по специальным сигналам (в процессоре это такты, формируемые тактовым генератором).
Общее время выполнения одной команды в конвейере с пятью ступенями будет составлять пять периодов тактовой частоты. В каждом такте конвейер будет одновременно обрабатывать (выполнять) пять различных команд. В результате за пять тактов будет выполнено пять команд. Таким образом, конвейеризация увеличивает производительность процессора, но она не сокращает время выполнения отдельной команды. Выигрыш получается за счет того, что обрабатывается сразу несколько команд.
В действительности конвейеризация даже увеличивает время выполнения каждой отдельной команды из-за появления дополнительных расходов, связанных с организацией работы конвейера. При этом тактовая частота ограничивается быстродействием работы самой медленной ступени конвейера.
В качестве примера рассмотрим процесс выполнения команды, у которой длительности выполнения этапов составляют 60, 30, 40, 50 и 20 нc. Примем дополнительные расходы на организацию конвейерной обработки равными 5 нc.
Если бы не было конвейеризации, то на выполнение одной команды потребовалось
60 + 30 + 40 + 50 + 20 = 200 нc.
Если же используется конвейерная организация, то длительность такта должна быть равна длительности самого медленного этапа обработки с добавлением «накладных» расходов, т. е. 60 + 5 = 65 не. Таким образом, полученное в результате конвейеризации сокращение времени выполнения команды составит 200/65 = 3,1 раза.
Заметим, что время выполнения конвейером одной команды составляет 5 ? 65 = 325 нc. Эта величина существенно больше 200 нc - времени выполнения команды без конвейеризации. Но одновременное выполнение сразу пяти команд дает среднее время завершения одной команды 65 нc.
Процессор Pentium имеет две кэш-памяти первого уровня (они расположены внутри процессора). Как известно, кэширование увеличивает производительность процессора за счет уменьшения числа случаев ожидания поступления информации из медленной оперативной памяти. Нужные данные и команды берутся процессором из быстрой кэш-памяти (буфера), куда они заносятся заранее. Наличие одной кэш-памяти в предыдущих конструкциях процессоров приводило к возникновению структурных конфликтов. Две команды, выполнявшиеся конвейером, порой одновременно пытались считать информацию из единственной кэш-памяти. Выполнение раздельного кэширования (буферизации) для команд и данных исключает такие конфликты, давая возможность обеим командам выполняться одновременно.
Развитие вычислительной техники идет непрерывно. Постоянно конструкторы ищут новые пути совершенствования своих изделий. Наиболее ценным ресурсом процессоров является их производительность. По этой причине изобретаются разнообразные приемы повышения производительности процессоров.
Одним из таких приемов является экономия времени за счет предсказания возможных путей выполнения разветвляющегося алгоритма. Это осуществляется с помощью блока предсказания адреса. Идея его работы похожа на идею работы кэш-памяти.
Как известно, существуют линейные, циклические и разветвляющиеся вычислительные процессы. В линейных алгоритмах команды выполняются в порядке их записи в оперативной памяти: последовательно одна за другой. Для таких алгоритмов введенный в процессор блок предсказания адреса перехода не может дать выигрыша.
В разветвляющихся и циклических алгоритмах выбор команды определяется результатами проверки условий ветвлений. Если ждать окончания вычислительного процесса в точке ветвления и затем выбирать из ОЗУ нужную команду, то неизбежно появятся потери времени из-за непроизводительного простоя процессора (считывание команды из ОЗУ идет медленно).
Блок предсказания адреса перехода работает на опережение и пытается заблаговременно предсказать адрес перехода, чтобы заранее перенести нужную команду из медленной оперативной памяти в специальный быстрый буфер перехода ВТВ (Branch Target Buffer).
Когда буфер ВТВ содержит правильное предсказание, переход происходит без задержки. Это напоминает работу кэш-памяти, у которой также бывают промахи. Из-за промахов операнды приходится считывать не из кэшпамяти, а из медленной ОП. Из-за этого происходит потеря времени.
Реализацию идеи предсказания адреса перехода осуществляют в процессоре два независимых буфера предварительной выборки. Они работают совместно с буфером предсказания переходов, причем один из буферов выбирает команды последовательно, а второй - согласно предсказаниям ВТВ.
Процессор Pentium имеет два пятиступенчатых конвейера для выполнения операций с фиксированной точкой. Кроме того, в процессоре имеется конвейер с восьмью ступенями для вычислений с плавающей точкой. Такие вычисления требуются при выполнении математических расчетов, а также для быстрой обработки динамических трехмерных цветных изображений.
Производительность, безусловно, важный показатель работы ЭВМ. Однако не менее важно, чтобы быстрые вычисления происходили при малом числе ошибок.
В процессоре имеется устройство самотестирования, которое автоматически проверяет работоспособность большинства элементов процессора.
Кроме того, выявление сбоев, произошедших внутри процессора, осуществляется с помощью специального формата данных. К каждому операнду добавляется бит четности, в результате чего все циркулирующие внутри процессора числа становятся четными. Появление нечетного числа сигнализирует о случившемся сбое. Наличие нечетного числа - это как бы появление фальшивой банкноты без водяных знаков.
Развитие архитектуры процессоров идет по пути постоянного увеличения объемов кэш-памятей первого и второго уровней. Исключением стал процессор Pentium 4, у которого объем кэш-памяти неожиданно снизился по сравнению с Pentium III.
Для повышения производительности в новых конструкциях процессоров создают две системные шины, работающие с разными тактовыми частотами. Быстрая шина используется для работы с кэш-памятью второго уровня, а медленная - для традиционного обмена информацией с другими устройствами, например ОЗУ. Наличие двух шин исключает конфликты при обмене информацией процессора с основной памятью и кэш-памятью второго уровня, находящейся за пределами кристалла процессора. Следующие за Pentium процессоры содержат большое число ступеней в конвейере. Это уменьшает время выполнения каждой операции в отдельной ступени, а значит, позволяет поднять тактовую частоту процессора.
В процессоре Pentium Pro (P6) применен новый подход к порядку выполнения команд, последовательно расположенных в ОЗУ.
Новый подход (он называется опережающим) заключается в использовании так называемого пула команд. При этом команды могут выполняться в произвольном порядке по мере их готовности (независимо от расположения в ОЗУ). Однако конечный результат формируется всегда в соответствии с исходным порядком команд в программе.
Рассмотрим в качестве примера следующий фрагмент учебной программы, записанной на некотором машинно-ориентированном языке.
Символами r1...r7 обозначены регистры общего назначения (РОН), символом mem[r4] - ячейка памяти ОЗУ.
Прокомментируем записанную программу.
Команда 1: записать в РОН r1 содержимое ячейки памяти ОЗУ, адрес которой указан в РОН r4.
Команда 2: записать в РОН r3 результат сложения содержимого регистров r1 и r2.
Команда 3: прибавить к содержимому регистра r5 единицу.
Команда 4: уменьшить содержимое РОН r6 на содержимое регистра r7.
Предположим, что при выполнении первой команды (загрузка операнда из памяти в регистр общего назначения r1) оказалось, что содержимое ячейки памяти mem [r4] отсутствует в кэш-памяти процессора (произошел промах, нужный операнд не был заранее доставлен в буфер из ОЗУ).
При традиционном подходе процессор перейдет к выполнению команд 2, 3, 4 только после того, как данные из ячейки mem[r4] основной памяти поступят в процессор (точнее, в регистр r1). Так как считывание будет происходить из медленно работающей основной памяти, этот процесс займет достаточно много времени (по меркам процессора). Все время ожидания этого события процессор будет простаивать, не выполняя полезной работы.
В приведенном примере процессор не может выполнить команду 2 до завершения команды 1, так как команда 2 использует результаты выполнения команды 1. В то же время процессор мог бы заранее выполнить команды 3 и 4, которые не зависят от результата выполнения команд 1 и 2.
В подобных случаях процессор Р6 работает иначе.
Процессор Р6 не ждет окончания выполнения команд 1 и 2, а сразу переходит к внеочередному выполнению команд 3 и 4. Результаты опережающего выполнения команд 3 и 4 сохраняются и извлекаются позднее, после выполнения команд 1 и 2. Таким образом, процессор Р6 выполняет команды в соответствии с их готовностью к выполнению, вне зависимости от их первоначального расположения в программе.
Единицами измерения быстродействия процессоров (и ЭВМ) могут служить:
- МИПС (MIPS - Mega Instruction Per Second) - миллион команд (инструкций) над числами с фиксированной точкой за секунду;
- МФЛОПС (MFLOPS - Mega Floating Operation Per Second) - миллион операций над числами с плавающей точкой за секунду;
- ГФЛОПС (GFLOPS - Giga Floating Operation Per Second) - миллиард операций над числами с плавающей точкой за секунду.
Имеются сообщения о самом быстром в мире компьютере ASCI White (корпорация IBM), быстродействие которого достигает 12,3 ТФЛОПС (триллиона операций).
Список литературы
процессор тактовая частота рentium
ПЕРСОНАЛЬНЫЙ КОМПЬЮТЕР 2002 В.П. ЛЕОНТЬЕВ Москва «Олма - пресс»2002 г.
1. Размещено на www.allbest.ru
Подобные документы
Разработка программы на языке Ассемблер для определения типа центрального процессора и его производительности. Основные этапы определения любого существующего Intel-совместимого процессора. Тактовая частота процессора, алгоритм и листинг программы.
курсовая работа [47,6 K], добавлен 26.07.2014Структура процессора Pentium, суперскалярность, основные особенности архитектуры. Организация конвейера команд, правила объединения. Дополнительные режимы работы процессора. Источники аппаратных прерываний. Формат ММХ команды. Процессор Pentium 4, схемы.
лекция [4,0 M], добавлен 14.12.2013Принцип работы процессора, способы его охлаждения, кодовые названия. Шины процессора, разрядность и кэш–память. Технологии расширения и поток команд процессора. Процессорные вентиляторы и их характеристика. Алгоритм и способы разгона процессора.
реферат [38,0 K], добавлен 21.02.2009Понятия и принцип работы процессора. Устройство центрального процессора. Типы архитектур микропроцессоров. Однокристальные микроконтроллеры. Секционные микропроцессоры. Процессоры цифровой обработки сигналов. Эволюция развития микропроцессоров Intel.
реферат [158,8 K], добавлен 25.06.2015История развития центрального процессора. Основные проблемы создания многоядерных процессоров. Проектирование микропроцессорной системы на базе процессора Intel 8080. Разработка принципиальной схемы и блок-схемы алгоритма работы микропроцессорной системы.
курсовая работа [467,6 K], добавлен 11.05.2014История появления и развития первых процессоров для компьютеров. Общая структура центрального процессора. Устройство блока интерфейса. Основные характеристики процессора. Кеш-память разных уровней. Разрядность и количество ядер. Частота и системная шина.
презентация [1,4 M], добавлен 11.04.2019Управление взаимодействием всех устройств ЭВМ. История создания и развития производства процессора. Структура центрального процессора. Регистры общего назначения. Обозначения популярных моделей процессоров Intel и AMD. Команды центрального процессора.
реферат [111,2 K], добавлен 25.02.2015Принцип работы процессора (одномагистральная структура). Временные диаграммы, описывающие выполнение микроопераций для каждой команды. Структурная схема управляющего автомата на основе памяти с одним полем адреса. Описание процессора на языке Active VHDL.
курсовая работа [621,0 K], добавлен 24.09.2010Общие понятия и определения о процессорах. Изучение устройства и принципа работы процессора. Подбор инструментов для сборки и разборки системного блока. Описание процесса обслуживания процессора. Требования к технике безопасности при выполнении работ.
курсовая работа [2,0 M], добавлен 15.02.2015Распараллеливание операций, кэширование памяти и расширение системы команд как способы совершенствования архитектуры и роста производительности компьютеров. Внутренняя структура конвейера центрального процессора Pentium i486. Корпус и колодки ЦП Intel.
презентация [281,2 K], добавлен 27.08.2013