Автор работы: Пользователь скрыл имя, 09 Сентября 2013 в 19:05, курсовая работа
В первой главе данной курсовой работы описана структура процессора и почему необходимо развивать вычислительную мощность. Структура многоядерной архитектуры ее достоинства и недостатки.
Во второй главе курсовой работы описаны особенности реализации многоядерной архитектуры: параллельные вычисления, программное обеспечение. В подразделе «Программное обеспечение» описан инструментарий для разработки многопоточных приложений (компиляторы, программные и аппаратные отладчики) поддержку многопоточности на уровне ОС (операционной системы).
И в последней главе работы описаны новейшие классификации и перспективы развития многоядерных процессоров, по мнению крупнейших производителей процессоров.
Введение
1.Структура многоядерных вычислительных комплексов
1.1 Структура процессора
1.2 Структура многоядерных процессоров
1.3 Основные проблемы создания многоядерных процессоров
1.4 Преимущества многоядерных систем
1.5 Недостатки многоядерных систем
2. Программное обеспеченье многоядерных ОС
2.1 Особенности перехода к параллельным вычислениям
2.2 Инструментальные средства разработки ПО
3. Перспективы развития
Заключение
Список литературы
Можно упомянуть
об исследованиях Intel, посвященных динамическому
регулированию интенсивности
2.2 Инструментальные средства многоядерных систем
Для обеспечения многопоточности используют следующие инструменты: компиляторы, аппаратные отладчики, программные отладчики, поддержка многопоточности на уровне ОС.
Компиляторы
Чтобы получить максимальную
выгоду от использования многоядерной
архитектуры требуется
Благодаря поддержке стандарта OpenMP компилятор Microsoft Visual C++ 2005 обеспечивает параллельную многопоточную обработку. Для этого требуется либо указать параметр компилятора "/openmp", либо установить в конфигурации флаг "OpenMP Support". С ноября 2005 года компилятор gcc для языков Cи, C++ и Фортран 95 поддерживает OpenMP с помощью опции "-fopenmp". Следует упомянуть и набор компиляторов EKOPath компании PathScale, предназначенных для 64-разрядных систем на базе Linux (AMD64 и EM64T).
Программные отладчики
Программисты хорошо
знают, как трудно отлаживать многопоточные
приложения. При аварийном завершении
программы зачастую требуется проанализировать
стек вызовов функций во всех потоках,
но обычный отладчик показывает только
стек потока, на котором произошло
аварийное завершение программы. Например,
стандартные средства gdb плохо приспособлены
для отладки многопоточных
Одна из таких
реализаций отладчик компании Etnus TotalView,
предназначенный для платформ Linux,
Unix и LynxOS. Он поддерживает многопоточность,
MPI, OpenMP, языки программирования Cи/C++
и Фортран, а также смешанные
коды с использованием разных языков
программирования. Полезным средством
оптимизации и отладки
Аппаратные отладчики
Для работы с виртуальными машинами аппаратный отладчик должен поддерживать ряд специальных функций (в частности, определять, к какой виртуальной машине относятся те или иные процессы и нити). Их обеспечивает, например, TRACE32 компании Lauterbach. Благодаря полной поддержке встроенных аппаратных блоков управления памятью можно одновременно отлаживать процессы на нескольких виртуальных машинах и даже два варианта одного процесса на разных виртуальных машинах. В частности, Lauterbach объявила о выпуске программного инструментария интегрированной поддержки ядра (kernel awareness) для операционной системы LynxOS-178. Чтобы получить доступ ко всем функциями TRACE32, не нужно изменять прикладные программы или ядро (применять заплаты, перехватчики, инструментальные "довески" и др.). Отлаживается именно то приложение, которое будет действовать в конечном продукте, что очень важно для его сертификации.
Среди других аппаратных отладчиков, поддерживающих работу с многоядерными конфигурациями, назовем Green Hills Probe и SuperTrace компании Green Hills, WindPower ICE компании Wind River, RealView ICE от ARM.
При разработке параллельных
программ используются специализированные
библиотеки и системы параллельного
программирования PVM, LAM, CHMP и др. Три
основных подхода к реализации этих
систем различаются методами взаимодействия
параллельных задач. Первый подход базируется
на концепции обмена сообщениями, второй
- на использовании разделяемой
Наиболее известным представителем первой группы является спецификация MPI (Message Passing Interface) для языков Cи и Фортран, первый вариант которой появился в 1994 году. MPI обеспечивает примерно 200 функций, охватывает множество компиляторов и операционных систем. Среди наиболее распространенных ее реализаций библиотека MPICH. Кроме того, предлагаются несколько коммерческих реализаций MPI, например MPI/Pro компании Verari Systems Software. MPI/Pro оптимизирует время работы параллельных приложений и поддерживает их масштабируемость за счет балансировки параметров производительности и использования ресурсов. Verari предлагает версии MPI/Pro для разных операционных систем, в том числе Windows, Linux, Mac OS X, LynxOS, и таких коммуникационных сред, как Gigabit Ethernet, Myrinet и InfiniBand.
Ко второй группе относится спецификация OpenMP (Open specifications for Multi-Processing). Ее первая версия (www.openmp.org), которая была выпущена в 1997 году, предназначалась для языка Фортран. К появлению OpenMP "приложили руку" компании IBM, Intel, Sun Microsystems и Hewlett-Packard. В 1998 году были созданы варианты OpenMP для языков Cи/C++, а последней является версия 2.5. Поддержка спецификации OpenMP обеспечена во всех компиляторах Intel начиная с шестой версии, в Microsoft Cи/C++ начиная с Visual Studio 2005, а также в GCC.
OpenMP - это набор
специальных директив
В третью группу входит спецификация POSIX (Portable Operating System interface for unIX), первое описание которой было опубликовано в 1986 году (www.pasc.org). Основная спецификация разработана как IEEE 1003.1 и одобрена как международный стандарт ISO/IEC 9945-1:1990. С точки зрения организации параллельных вычислений наибольший интерес представляют три части стандарта 1003.1a (OS Definition), 1003.1b (Realtime Extensions) и 1003.1c (Threads). В рамках POSIX можно реализовать параллельные вычисления на основе обмена сообщениями (аналогично MPI) или разделяемой памяти (как в OpenMP). Естественно, в POSIX допустима и любая комбинация этих методов. В наибольшей степени стандарту POSIX соответствуют (и соответствующим образом сертифицированы) операционные системы реального времени LynxOS и Integrity.
Поддержка на уровне ОС
Многоядерные процессоры
потребуют от операционных систем поддержки
разных архитектур многопроцессорной
обработки. Компания QNX Software Systems объявила
о выпуске комплекта
Поддержку многоядерных
систем на базе процессоров AMD64, Sun UltraSPARC
T1 и Intel обеспечивает ОС Solaris 10. Например,
встроенная система виртуализации
и защиты информации Solaris Containers позволяет
системному администратору организовывать
в рамках единой операционной системы
несколько виртуальных
Появление многоядерных процессоров даст мощный дополнительный толчок массовому внедрению технологий виртуализации. Назовем некоторые из известных подходов[5]. ARINC-653 (Avionics Application Software Standard Interface). Стандартный интерфейс, разработанный компанией ARINC в 1997 году, вводит концепцию изолированных разделов на основе универсального программного интерфейса APEX (Application/Executive) между операционной системой и прикладным программным обеспечением[5]. Требования интерфейса определены так, чтобы разрешить приложениям контролировать диспетчеризацию, связь и состояние внутренних обрабатываемых элементов.
В 2003 году принята
новая редакция ARINC-653, в которой
введена концепция
Рис. 2. Реализация ARINC-653 в LynxOS-178
UML ОС Linux в пользовательском
режиме -самый универсальный эмулятор,
позволяющий создавать
Программные среды виртуальных машин. Наиболее популярными из них являются Microsoft Virtual PC и группа программных продуктов VMware. Система виртуальных машин позволяет запускать на компьютере сразу несколько разных операционных систем и переключаться с одной на другую без перезапуска компьютера. На компьютере, работающем под управлением основной (базовой) операционной системы, создаются один или несколько виртуальных компьютеров, на каждом из которых можно запустить "гостевую" ОС.
VMWare Workstation позволяет
запустить несколько
Технология виртуализации Intel. VT, компонент многоядерной технологии поддержки виртуализации на аппаратном уровне [3], обеспечивает поддержку виртуальных машин на уровне процессора с помощью нового режима VMX (Virtual Machine Extensions) и десяти команд vmptrld, vmptrst, vmclear, vmread, vmwrite, vmcall, vmlauch, vmresume, vmxoff и vmxon. При этом повышаются как надежность и производительность работы приложений, так и уровень общей безопасности.
Архитектура VT поддерживает два класса ПО: монитор виртуальной машины VMM и "гостевое" программное обеспечение. Используются два режима работы root operation и non-root operation. Как правило, VMM работает в первом режиме, а "гостевые" программы во втором. Поддержку технологии виртуализации Intel намерены организовать такие производители операционных систем, как RedHat, SuSe и MontaVista. Она будет обеспечена и в других программных средствах виртуализации, например в Vmware.Появление многоядерных процессоров вызвало опасения, что пользователям придется платить гораздо больше (пропорционально числу ядер) за лицензии на программное обеспечение. В частности, до недавнего времени такую позицию занимала корпорация Oracle. Недавно произошли позитивные изменения: стоимость лицензий на продукты Oracle для многоядерных процессоров AMD и Intel начали рассчитывать путем умножения числа ядер на коэффициент 0,5, для микропроцессоров UltraSPARC T1 на 0,25, а для многоядерных процессоров других производителей (в том числе, IBM) на 0,75. При лицензировании своих программных продуктов IBM считает двухъядерные процессоры AMD и Intel одним процессором, но продолжает рассматривать каждое ядро процессоров POWER как отдельный процессор. Понимая сложность задач массового перехода на многоядерные решения, основные поставщики аппаратных и программных средств организовали ассоциацию Multicore .Ее цель - создание промышленных стандартов для многоядерных систем. Сейчас Multicore работает над четырьмя самостоятельными, но взаимосвязанными стандартами: Resource Management (RAPI), Communication API (CAPI), Debug API и Transparent interprocess communication (TIPC). В рабочих встречах принимают участие представители компаний Xilinx, Express Logic, Wind River, Freescale, ARC, MIPS Technologies, Synopsys и PolyCore Software.
Несомненно, распространение многоядерных процессоров будет зависеть от реализации соответствующего программного обеспечения. Если она окажется эффективной, существенно вырастет инсталляционная база многоядерных систем.
Раздел 3. Перспективы развития многоядерных архитектур процессоров
В корпорации Intel уже говорят не о «Мультиядерности» (Multi-Core) процессоров, как это делается в отношении 2-, 4-, 8-, 16- или даже 32-ядерных решений, а о «Многоядерности» (Many-Core), говоря о размещении сотнях ядер на одном киристале.