Область техники, к которой относится изобретение
Настоящее изобретение относится к сфере обработки в вычислительной среде. В частности, изобретение относится к сфере сбора сведений о ходе выполнения команд программы в вычислительной среде.
Уровень техники
Процессоры компьютеров выполняют транзакции с использованием непрерывно усложняющейся логики предсказания ветвлений и кэширования (т.е. буферизации) команд. Эти приемы применяются для повышения скорости выполнения команд, благодаря чему повышается производительность вычислительных систем. Применение предсказания ветвлений и кэширования для повышения производительности затрудняет достоверное предсказание того, как именно процессором компьютера будет выполняться конкретная программа-приложение. При разработке программного обеспечения часто существует баланс между функциональностью и производительностью. Программное обеспечение выполняется на одном или более уровнях абстрагирования от применяемого в вычислительной системе аппаратного обеспечения, на котором выполняется программное обеспечение. И если аппаратное обеспечение виртуализируется, то вводится еще один уровень абстракции. С введением указанной логики, повышающей производительность, а также различных уровней абстракции становится сложно сформировать целостное понимание того, что в действительности происходит на уровне аппаратного обеспечения при выполнении программного обеспечения. При отсутствии этих сведений разработчики программного обеспечения для оптимизации программ-приложений применяют более абстрактные методы, например увеличивают продолжительность выполнения, изменяют режим использования запоминающего устройства, число потоков и т.п.
Раскрытие изобретения
Техническая проблема
Если специфическая информация на уровне аппаратного обеспечения доступна, то она обычно предоставляется разработчику постфактум и в совокупности, на высоком уровне и/или вперемешку со сведениями об активности других программ и операционной системы, что затрудняет идентификацию потенциальных проблем, которые могут повлиять на эффективность и точность программы-приложения.
Решение технической проблемы
Варианты осуществления содержат компьютерный программный продукт, способ и систему для сбора сведений о ходе вычислений. Процессор выполняет поток команд (т.е. непрерывную последовательность команд). Процессором собирается информация о ходе выполнения вычислений, характеризующая выполнение потока команд. На основе указанных зафиксированных сведений о ходе вычислений создаются записи о ходе вычислений. В процессоре выявляется точка (т.е. момент) выборки средства сбора сведений о ходе вычислений для выполняемой последовательности команд, сохраняется отчетная группа записей в программном буфере средства сбора сведений о ходе вычислений. Сохранение основывается на выявленной точке выборки средства сбора сведений о ходе вычислений и включает: определение текущего адреса программного буфера средства сбора сведений о ходе вычислений, причем определение зависит от доступных командам управляющих параметров средства сбора сведений о ходе вычислений; запись отчетной группы в программный буфер средства сбора сведений о ходе вычислений на основе начального адреса и текущего адреса программного буфера средства сбора сведений о ходе вычислений, причем отчетная группа содержит созданные записи о ходе вычислений.
С помощью приемов, составляющих сущность настоящего изобретения, реализуются дополнительные особенности и преимущества. В данной заявке подробно описываются прочие варианты осуществления и аспекты настоящего изобретения, они рассматриваются как часть настоящего изобретения. Для лучшего понимания сущности изобретения, его преимуществ и особенностей приводится описание и чертежи.
Краткое описание чертежей
В формуле изобретения, следующей за описанием, сформулированы и заявлены объекты изобретения. Вышеупомянутые и прочие объекты, особенности и преимущества настоящего изобретения раскрываются в последующем подробном описании, которое сопровождается чертежами. На чертежах показано:
на фиг. 1А - схема примера хост-компьютерной системы согласно варианту осуществления изобретения,
на фиг. 1Б - схема примера хост-компьютерной системы с эмуляцией согласно варианту осуществления изобретения,
на фиг. 1B - схема примера компьютерной системы согласно варианту осуществления изобретения,
на фиг. 2 - схема примера компьютерной сети согласно варианту осуществления изобретения,
на фиг. 3 - схема элементов компьютерной системы согласно варианту осуществления изобретения,
на фиг. 4А - схема фрагмента компьютерной системы с детализацией элементов согласно варианту осуществления изобретения,
на фиг. 4Б - схема фрагмента компьютерной системы с детализацией элементов согласно варианту осуществления изобретения,
на фиг. 4B - схема фрагмента компьютерной системы с детализацией элементов согласно варианту осуществления изобретения,
на фиг. 5 - схема примера системы для сбора сведений о ходе вычислений в процессоре согласно варианту осуществления изобретения,
на фиг. 6 - схема фрагмента управляющего блока управляющих параметров средства сбора сведений о ходе вычислений (от англ.: Run-time-instrumentation Controls Control Block, аббревиатура RICCB) согласно варианту осуществления изобретения, содержащая управляющие параметры, значение которых может устанавливаться в привилегированном режиме,
на фиг. 7 - схема фрагмента блока параметров RICCB согласно варианту осуществления изобретения в случае, когда значение разряда "К" режима частичных привилегий установлено равным единице,
на фиг. 8 - схема накопительного буфера согласно варианту осуществления изобретения,
на фиг. 9 - схема отчетной группы согласно варианту осуществления изобретения,
на фиг. 10 - схема варианта осуществления записи типа начало в отчетной группе,
на фиг. 11 - схема варианта осуществления записи типа отметка времени в отчетной группе,
на фиг. 12 - схемы вариантов осуществления записи типа извлечение в отчетной группе,
на фиг. 13 - схемы вариантов осуществления записи типа останов в отчетной группе,
на фиг. 14 - схемы вариантов осуществления записей типа вызов в отчетной группе,
на фиг. 15 - схема варианта осуществления записи типа заполнитель в отчетной группе,
на фиг. 16 - схемы вариантов осуществления записей типа команда в отчетной группе,
на фиг. 17 - схема алгоритма сбора сведений о ходе вычислений согласно варианту осуществления изобретения,
на фиг. 18 - графическое представление компьютерного программного продукта согласно варианту осуществления изобретения.
Осуществление изобретения
Вариант осуществления настоящего изобретения представляет собой основанное на аппаратном обеспечении средство сбора сведений о ходе вычислений для сред выполнения задач. В данном случае термин "среда выполнения задач" относится к среде, которая инкапсулирует состояние и управляет ресурсами, используемыми для выполнения программы или приложения (например, виртуальная машина Java®, операционная система, программное обеспечение промежуточного слоя и т.д.). Варианты осуществления средства сбора сведений о ходе вычислений позволяют некоторой программе собирать информацию о ходе выполнения команд программного обеспечения, в том числе собирать данные центрального процессорного устройства (ЦПУ). Собранная информация позволяет программе отслеживать внутренние процессы, связанные с исполняемым программным обеспечением. Варианты осуществления средства сбора сведений о ходе вычислений содержат аппаратное средство для сбора сведений о последовательностях событий (например, переходы при ветвлениях, значения регистров и т.д.) в накопительном буфере. Содержимое накопительного буфера (или части накопительного буфера, содержащей наиболее свежие записи) копируется в программный буфер в пространстве адресов приложения (например, в пространстве адресов виртуальной машины Java) при возникновении программируемого набора типовых инициирующих событий, таких как (но не ограничиваясь): директива программного обеспечения в форме команды, вставленной в поток команд; завершение выполнения некоторого числа команд; окончание заданного интервала времени после последней выборки; заданное событие в аппаратном обеспечении, такое как возникновение промаха кэш-памяти данных или промаха кэш-памяти команд (т.е. отсутствие требуемых данных или команд в кэш-памяти).
Данные, регистрируемые в каждой точке выборки, сохраняются как набор реляционных записей, для обозначения которого в данной заявке используется термин "отчетная группа". Отчетная группа сохраняется в программном буфере, местоположение которого определяется по значениям управляющих параметров средства сбора сведений о ходе вычислений. Таким образом, данные о ходе вычислений, хранящиеся в виде отчетной группы в программном буфере, доступны программе для анализа при постобработке или даже для более агрессивного анализа во время действия средства сбора сведений о состоянии вычислительной системы.
Информацию о ходе вычислений, например собранную основанным на аппаратном обеспечении средством сбора сведений о ходе вычислений, описанным в настоящей заявке, могут использовать динамические компиляторы для оптимизации в реальном масштабе времени на основе обратной связи с программой. Например, динамическим компилятором для выполнения оптимизации, которая делает код специализированным или создает версию (т.е. вариант) кода, определяет потоки, меняет порядок следования выполняемых фрагментов и корректирует ветвления, может использоваться информация о следовании важным ветвям выполнения, о профильных величинах и предпочтительных направлениях ветвления. Варианты осуществления, описанные в настоящей заявке, не ограничиваются использованием компиляторами и могут применяться в различных задачах, например (но не ограничиваясь) для управления другими средствами выполнения программ. Например, сведения о событиях кэш-памяти данных могут использоваться для содействия процедуре определения ненужных данных в принятии решений о совместно размещенных или размещенных раздельно объектах, что позволяет добиться лучшего размещения данных или позволяет избежать мнимых проблем совместного использования данных.
На фиг. 1А показаны характерные компоненты хост-компьютерной системы 50 согласно варианту осуществления изобретения. В компьютерной системе могут также использоваться другие варианты конфигурации компонентов. Пример хост-компьютерной системы 50 содержит один или более процессоров 1, связанных с главным запоминающим устройством 2 компьютера (компьютерной памятью), а также через интерфейсы ввода-вывода с запоминающими устройствами 11 и сетями 10 для обмена информацией с другими компьютерами или сетями хранения данных и т.п. Процессор 1 совместим с архитектурой, имеющей собственный набор команд и собственную функциональность. Процессор 1 может использовать динамическую трансляцию адресов для преобразования программных адресов (виртуальных адресов) в реальные адреса запоминающего устройства. Как правило, средство 3 динамической трансляции адресов (СДТА) содержит буфер 7 быстрого преобразования адреса (БПА) для кэширования преобразований, благодаря чему последние обращения к запоминающему устройству 2 не приводят к задержке, вызываемой трансляцией адреса. Как правило, между запоминающим устройством 2 и процессором 1 размещается кэш-память (быстродействующее буферное запоминающее устройство) 9.
Кэш-память 9 может быть организована по иерархическому принципу, т.е. содержать больший объем кэш-памяти, доступный для двух и более ЦПУ, и также меньшие, более быстродействующие (низкоуровневые) объемы кэш-памяти, размещенные между большим объемом кэш-памяти и каждым ЦПУ. В некоторых вариантах осуществления кэш-память низкого уровня разделяется на низкоуровневую кэш-память для выборки команд и низкоуровневую кэш-память для обращения к данным. Согласно варианту осуществления изобретения команда выбирается из запоминающего устройства 2 устройством 4 выборки команд через кэш-память 9. Команда декодируется в устройстве 6 декодирования команд и направляется (в некоторых вариантах осуществления - совместно с другими командами) в устройства 8 выполнения команд. Как правило, используются различные типы устройств 8 выполнения команд, например арифметическое выполняющее устройство, устройство выполнения команд с плавающей запятой и устройство выполнения команд ветвления. Команда выполняется устройством 8 выполнения команд, обращаясь при необходимости к операндам, находящимся в определяемых командой регистрах или в запоминающем устройстве 2 компьютера. Если требуется доступ к операнду (загруженному или хранящемуся) из запоминающего устройства 2 компьютера, то доступ контролируется устройством 5 загрузки-хранения под управлением выполняемой команды. Команды могут выполняться в схемах аппаратного обеспечения или во внутреннем микрокоде (входящем в состав встроенного программного обеспечения) или комбинацией указанных способов.
На фиг. 1Б показана схема хост-компьютерной системы 21 с эмуляцией, которая эмулирует хост-компьютерную систему, построенную по хост-архитектуре, такую как хост-компьютерная система 50, схема которой показана на фиг. 1А. В хост-компьютерной системе 21 с эмуляцией хост-процессор (ЦПУ) 1 является эмулируемым хост-процессором 29 (или виртуальным хост-процессором), в его состав входит собственный процессор 27, построенный по архитектуре с собственным набором команд, отличной от архитектуры процессора 1 хост-компьютерной системы 50. Эмулируемая хост-компьютерная система 21 обладает запоминающим устройством 22, доступным собственному процессору 27. В варианте осуществления запоминающее устройство 22 разделено на части: часть, служащую запоминающим устройством 2 компьютера, и часть, служащую запоминающим устройством 23 процедур эмуляции. В соответствии с архитектурой хост-компьютера, запоминающее устройство 2 компьютера доступно программам эмулируемой хост-компьютерной системы 21.
Собственный процессор 27 выполняет собственные команды из набора команд собственной архитектуры, отличной от архитектуры эмулируемого процессора 29, причем собственные команды поступают из запоминающего устройства 23 процедур эмуляции. Собственный процессор 27 может обратиться к хост-команде из состава программы, располагающейся в запоминающем устройстве 2 компьютера, для ее исполнения путем выполнения одной или более команд, получаемых подряд, а также с использованием процедуры доступа-декодирования, которая может декодировать хост-команду (хост-команды), к которым происходит обращение, для определения процедуры в рамках собственной архитектуры для выполнения хост-команды и эмулирования функций хост-команды, к которой происходит обращение. Собственными процедурами могут эмулироваться другие возможности, определенные для архитектуры хост-компьютерной системы 50, например, такие как регистры общего назначения, управляющие регистры, динамическая трансляция адресов, поддержка подсистемы ввода-вывода и кэш-память процессора.
Для повышения производительности процедуры эмуляции могут также пользоваться преимуществами функций, предоставляемыми хост-процессором 27, такими как регистры общего назначения и динамическая трансляция виртуальных адресов. Для содействия процессору 27 в эмуляции функций хост-компьютерной системы 50 могут предоставляться специальные аппаратные и разгружающие вычислительные ядра.
Команды, присущие архитектуре компьютеров-мейнфреймов, часто используются программистами (в настоящее время, как правило, пользующимися языком программирования "С") через приложения-компиляторы. Указанные команды, хранящиеся в среде хранения информации, могут выполняться в собственной вычислительной среде на сервере, построенном по архитектуре корпорации IBM® z/Architecture, или же на вычислительных машинах, построенных по другим архитектурам. Эти команды могут эмулироваться на существующих и на будущих серверах-мейнфреймах корпорации IBM и на других вычислительных машинах IBM (например, на серверах типа pSeries® и xSystem®). Указанные команды могут выполняться на вычислительных машинах, работающих под управлением операционной системы Linux, и на обширном множестве вычислительных машин, использующих аппаратное обеспечение производства предприятий IBM®, Intel®, AMD™, Sun Microsystems и др. Помимо указанного аппаратного обеспечения с архитектурой z/Architecture, могут применяться вычислительные машины на основе операционной системы Linux, а также вычислительные машины с эмуляторами Hercules (программный эмулятор мейнфреймов IBM и совместимых), UMX, FSI (от англ. - Fundamental Software, Inc.), PSI (от англ. - Platform Solutions, Inc.), при этом выполнение обычно осуществляется в режиме эмуляции. В режиме эмуляции программа-эмулятор выполняется собственным (физическим) процессором вычислительной системы и имитирует архитектуру эмулируемого процессора.
Один или более компонентов эмулируемой хост-компьютерной системы 21 подробно описан в публикации IBM "z/Architecture Principles of Operation" (от англ. - "Принцип действия архитектуры z/Architecture", публикация IBM № SA22-7832-08, 9-е издание, август 2010 г. ), которая в качестве ссылки включена в настоящую заявку. IBM является зарегистрированным товарным знаком корпорации International Business Machines Corporation, Армонк, штат Нью-Йорк, США. Прочие наименования, используемые в настоящей заявке, могут также являться зарегистрированными или незарегистрированными товарными знаками или наименованиями товаров корпорации International Business Machines Corporation или других компаний.
Как правило, собственный процессор 27 выполняет программное обеспечение-эмулятор, хранящееся в запоминающем устройстве 23 процедур эмуляции. В состав указанного программного обеспечения-эмулятора входят программы из постоянного запоминающего устройства (ПЗУ) или собственная операционная система, необходимые для имитации эмулируемого процессора. Для архитектуры эмулируемого процессора программное обеспечение-эмулятор отвечает за выборку и выполнение команд. Программное обеспечение-эмулятор поддерживает эмулируемый программный счетчик для отслеживания границ команд. Программное обеспечение-эмулятор может в один момент времени выбирать одну или более команд в формате эмулируемой вычислительной машины и преобразовывать указанные одну или более команд в соответствующую группу команд в собственном формате хост-вычислительной машины для выполнения собственным процессором 27. Указанные преобразованные команды могут кэшироваться, благодаря чему преобразование может выполняться более быстро. Программное обеспечение-эмулятор поддерживает правила архитектуры эмулируемой процессорной архитектуры, чтобы обеспечить корректность выполнения операционной системы и приложений, предназначенных для эмулируемого процессора. Более того, программное обеспечение-эмулятор предоставляет вычислительные ресурсы, понятные для эмулируемой процессорной архитектуры, в том числе (но не ограничиваясь) управляющие регистры, регистры общего назначения, регистры с плавающей запятой, функцию динамической трансляции адресов (включая, например, таблицы сегментов и таблицы страниц), механизмы прерываний, механизмы переключения задач, часы времени суток, интерфейсы к подсистемам ввода-вывода, благодаря чему операционная система или прикладная программа, разработанные для выполнения на эмулируемом процессоре 29, могут быть выполнены на собственном (физическом) процессоре 27, оснащенном программным обеспечением-эмулятором.
Конкретная эмулируемая команда декодируется, и для выполнения функции конкретной отдельной команды вызывается соответствующая подпрограмма. Для имитации эмулируемого 29 процессора применяется функция программного обеспечения-эмулятора, например, в виде подпрограммы, написанной на языке программирования "С", либо программа-драйвер, либо используется иной способ осуществления драйвера конкретного аппаратного обеспечения, о чем специалистам в данной области станет ясно после изучения описания предпочтительного варианта осуществления.
Согласно варианту осуществления изобретения изобретение может быть осуществлено программным обеспечением (иногда называемым лицензионным внутренним кодом, содержимым ПЗУ, микрокодом, милликодом, пикокодом и т.п., причем каждый из терминов может относиться к одному или более аспектам настоящего изобретения). На фиг. 1А процессор 1 (ЦПУ) хост-компьютерной системы 50 может обращаться к коду программного обеспечения, содержащему настоящее изобретение и хранящемуся в запоминающем устройстве, таком как долговременное запоминающее устройство, привод CD-ROM (от англ. Compact Disc Read Only Memory - постоянное запоминающее устройство на компакт-диске), привод ленточного накопителя, накопитель на жестких дисках. Программный код может располагаться на любой из множества известных машиночитаемых сред, предназначенных для использования в системе обработки данных, таких как гибкий диск, накопитель на жестких дисках или CD-ROM. Код может распространяться на подобной машиночитаемой среде или поставляться пользователям из запоминающего устройства 2 компьютера или из запоминающего устройства одного компьютера через сеть 10 другим компьютерным системам для их пользователей.
Согласно другому варианту осуществления программный код может находиться в запоминающем устройстве 2 компьютера, и доступ процессора 1 к нему может осуществляться по шине процессора (на чертеже шина процессора не показана). Подобный программный код содержит операционную систему, которая управляет функционированием и взаимодействием различных компонентов компьютера и одной или более прикладных программ. Программный код обычно передается из запоминающего устройства 11 большой емкости в запоминающее устройство 2 компьютера, из которого код доступен процессору 1 для обработки. Приемы и способы размещения кода программного обеспечения в пространстве памяти запоминающего устройства, на физической машиночитаемой среде и/или передача кода программного обеспечения через сети передачи данных достаточно хорошо известны и в настоящей заявке далее обсуждаться не будут. Программный код, созданный и размещенный на материальном носителе, в том числе (но не ограничиваясь) на электронных модулях памяти [в оперативном запоминающем устройстве (ОЗУ)], запоминающих устройствах флеш-памяти, CD-ROM, DVD-ROM (от англ. Digital Video Disc Read-Only Memory - постоянное запоминающее устройство на цифровом видеодиске), магнитной ленте и т.п. часто называют компьютерным программным продуктом. Информация со среды-носителя компьютерного программного продукта обычно считывается схемой обработки предпочтительно в компьютерной системе с целью выполнения программного кода схемой обработки.
На фиг. 1B показана схема примера рабочей станции или аппаратной части сервера, в которых может быть осуществлено настоящее изобретения. На фиг. 1B система 100 содержит типичную основную компьютерную систему 101, например персональный компьютер, рабочую станцию или сервер, в состав которой, в свою очередь, могут входить периферийные устройства. Основная компьютерная система 101 содержит один или более процессоров 106 и шину передачи данных (на чертеже не показана), используемую для подключения и осуществления соединения между одним или более процессорами 106 и другими компонентами основной компьютерной системы 101 по хорошо известной методике. Шина соединяет процессор 106 с запоминающим устройством 105 и запоминающим устройством 107 длительного хранения, которое может содержать, например, дисковый накопитель (в том числе, например, любые магнитные среды хранения данных, CD-ROM, DVD-ROM или устройства флеш-памяти) или ленточный накопитель. Основная компьютерная система 101 может также содержать адаптер интерфейса пользователя, который соединяет один или более процессоров 106 через шину с одним или более интерфейсными устройствами, такими как клавиатура 104, мышь 103, принтер и/или сканер 110 и/или с устройствами интерфейса пользователя других типов, такими как сенсорный экран, устройство цифрового координатного ввода планшетного типа и т.п. Шина также обеспечивает подключение устройства 102 отображения, такого как жидкокристаллический экран или монитор, к одному или более процессорам 106 через адаптер дисплея.
Основная компьютерная система 101 может обмениваться данными с другими компьютерами или сетями компьютеров с помощью сетевого адаптера, способного осуществлять соединение 108 с сетью 109 передачи данных. Примерами сетевых адаптеров являются адаптеры сетей типа Token Ring (от англ. - маркерное кольцо) и Ethernet, а также модемы.
Согласно другому варианту осуществления, основная компьютерная система 101 может обмениваться данными с использованием беспроводного интерфейса, такого как адаптер CDPD (от англ. Cellular Digital Packet Data - цифровая пакетная передача данных по сети сотовой связи). Основная компьютерная система 101 может быть соединена с другими компьютерами в локальную вычислительную сеть (ЛВС) или в глобальную вычислительную сеть, либо система 101 может выступать в качестве клиента в системе клиент-сервер вместе с другим компьютером и т.д.
На фиг. 2 показана схема сети 200 обработки данных, в которой может быть осуществлено настоящее изобретение. Сеть 200 обработки данных может содержать набор индивидуальных сетей, таких как беспроводные и проводные сети, в состав каждой из которых может входить множество индивидуальных рабочих станций 201, 202, 203, 204 и/или основная компьютерная система 101 (см. фиг. 1B). Кроме того, специалисты в данной области техники должны понимать, что может быть задействована одна или более ЛВС, причем ЛВС может содержать набор рабочих станций, соединенных с хост-процессором.
Код 111 программного обеспечения может располагаться в запоминающем устройстве 105, и процессор 106 может обращаться к этому коду по шине процессора. Такой код программного обеспечения содержит операционную систему, которая управляет функционированием и взаимодействием различных компонентов компьютера и одной или более прикладных программ 112. Код программного обеспечения обычно передается из запоминающего устройства 107 длительного хранения в быстродействующее запоминающее устройство 105, из которого этот код доступен процессору 106 для обработки. Приемы и способы размещения кода программного обеспечения в пространстве памяти запоминающего устройства, на физической машиночитаемой среде и/или передачи кода программного обеспечения через сети передачи данных достаточно хорошо известны и в настоящей заявке далее обсуждаться не будут. Программный код, созданный и размещенный на материальном носителе, в том числе (но не ограничиваясь) на электронных модулях памяти (ОЗУ), запоминающих устройствах флеш-памяти, CD-ROM, DVD-ROM, магнитной ленте и т.п., часто называют компьютерным программным продуктом. Информация со среды-носителя компьютерного программного продукта обычно считывается схемой обработки, предпочтительно в компьютерной системе, с целью выполнения схемой обработки.
Процессору наиболее доступна кэш-память низшего уровня (т.е. первого уровня; обозначение первого уровня - L1), которая обычно обладает наибольшим быстродействием н меньшим объемом по сравнению с процессорной кэш-памятью других уровней. Уровень основного запоминающего устройства считается наивысшим (уровень 3, обозначение L3, если всего предусмотрено три уровня). Кэш-память низшего уровня часто разделяется на кэш-память команд 1-кэш (от англ. Instructions cache - кэш-память команд) для хранения предназначенных для исполнения команд и кэш-память данных D-кэш (от англ. Data cache - кэш-память данных), предназначенную для хранения операндов.
На фиг. 2 сети могут также содержать компьютеры-мейнфреймы или серверы, такие как компьютер-шлюз (клиентский сервер) 206 или сервер приложений (удаленный сервер) 208, который может обращаться к хранилищу данных и к которому может также осуществляться доступ непосредственно с рабочей станции 205. Компьютер-шлюз 206 служит точкой доступа в каждую индивидуальную сеть 207. Шлюз требуется при переходе от одного сетевого протокола на другой. Компьютер-шлюз 206 предпочтительно может быть подключен к другой сети (например, к сети 207 Интернет) с помощью канала передачи данных. Компьютер-шлюз 206 также может быть непосредственно соединен с одной или более рабочими станциями 101, 201, 202, 203 и 204 с использованием канала передачи данных. Компьютер-шлюз может быть реализован на основе сервера IBM eServer™ zSeries® z9®, предлагаемого корпорацией International Business Machines Corporation.
Согласно варианту осуществления изобретения процессор 106 основной компьютерной системы 101 может обращаться к коду программного обеспечения, в котором может быть осуществлено настоящее изобретение и который располагается на запоминающем устройстве долговременного хранения, таком как запоминающее устройство 107 долговременного хранения, схема которого показана на фиг. 1B. Код программного обеспечения для его использования системой обработки данных может располагаться на любой из множества известных машиночитаемых сред, таких как гибкий диск, накопитель на жестких дисках или CD-ROM. Код может предоставляться на такой машиночитаемой среде или может предоставляться пользователям 210 и 211 компьютерных систем по сети передачи данных из запоминающих устройств другой компьютерной системы.
На фиг. 3 показан пример осуществления процессора 106. Как правило, для буферизации блоков информации запоминающего устройства используется одноуровневая или многоуровневая кэш-память 303, что позволяет увеличить производительность процессора 106. Кэш-память 303 представляет собой быстродействующее буферное запоминающее устройство, хранящее строки данных основного запоминающего устройства, которые, вероятно, должны использоваться в будущем. Как правило, длина строк данных в кэш-памяти составляет 64, 128 или 256 байтов. Согласно варианту осуществления изобретения часто применяются отдельные функциональные узлы кэш-памяти для буферизации команд и данных. Для поддержания когерентности содержимого кэш-памяти (т.е. для синхронизации копий строк данных в основном запоминающем устройстве и в кэш-памяти) часто применяются различные хорошо известные снуп-алгоритмы (от англ. Snoop algorithm, специальный алгоритм поиска необходимых данных в кэш-памяти). Главное запоминающее устройство, такое как запоминающее устройство 105 вычислительной системы, часто также рассматривается как кэш-память. В вычислительной системе с четырьмя уровнями кэш-памяти 303 запоминающее устройство 105 иногда рассматривается как кэш-память пятого уровня (L5), поскольку оно обычно обладает более высоким быстродействием по сравнению с быстродействием большинства доступных вычислительной системе энергонезависимых запоминающих устройств (запоминающих устройств с прямым доступом, ленточных запоминающих устройств с последовательным доступом и т.п.) и хранит только часть данных указанных устройств. Основное запоминающее устройство 105 "кэширует" (буферизирует) страницы данных, которые загружаются и выгружаются из него операционной системой.
Программный счетчик (счетчик команд) 311 отслеживает адрес текущей подлежащей исполнению команды. Программный счетчик в процессоре, построенном по архитектуре z/Architecture, является 64-разрядным, его длина может быть сокращена до 31 или до 24 разрядов для поддержки предыдущих ограничений на длину адреса. Как правило, программный счетчик реализован в слове состояния программы (ССП) компьютера, так что при переключении задач его содержимое сохраняется. Так, выполнение программы при некотором значении программного счетчика может быть прервано, например, операционной системой (текущий "контекст" переключается от окружения программы к окружению операционной системы). В то время, пока программа неактивна, значение счетчика программ сохраняется в ССП программы, и при выполнении задачи операционной системы используется счетчик программ ССП операционной системы. Согласно варианту осуществления изобретения программный счетчик увеличивается на величину, равную длине в байтах исполняемой в данный момент команды. Команды типа RISC (от англ. Reduced Instruction Set Computing - вычисления с сокращенным набором команд), как правило, имеют фиксированную длину, в то время как команды типа CISC (от англ. Complex Instruction Set Computing - вычисления со сложным набором команд), как правило, имеют переменную длину. Команды в архитектуре IBM z/Architecture относятся к типу CISC, их длина составляет два, четыре или шесть байтов. Значение в программном счетчике 311 изменяется либо операцией переключения задач, либо при выполнении операции ветвления, например, по команде ветвления. При операции переключения задачи текущее значение программного счетчика сохраняется в ССП вместе с другой информацией о состоянии выполнявшейся программы (такой как коды состояния), после чего загружается новое значение программного счетчика, указывающее на команду нового программного модуля, подлежащего исполнению. Операция ветвления, используемая в программе при принятии решений или выполнении циклов, исполняется путем загрузки в программный счетчик 311 результата команды ветвления.
Согласно варианту осуществления изобретения для выборки команд по указанию процессора 106 применяется устройство 305 выборки команд. Устройство 305 выборки команд либо выбирает команду в порядке следования, либо команду, на которую указывает команда ветвления, либо по указанию о переключении задачи - первые команды программы. Согласно варианту осуществления изобретения в устройстве 305 выборки команд применяются упреждающие методы для спекулятивной выборки команд, основанные на гипотезе о том, что заблаговременно выбранные команды могут потребоваться в будущем. Например, устройство 305 выборки может загрузить 16 байтов команд, в число которых входят следующая по очереди команда и, кроме того, байты команд, следующих за ней.
Затем выбранные команды выполняются процессором 106. Согласно варианту осуществления изобретения выбранная команда (команды) передаются на устройство 306 декодирования-диспетчеризации устройства 305 выборки команд. Устройство декодирования-диспетчеризации 306 декодирует команду (команды) и передает информацию о декодированной команде (командах) на соответствующие устройства 307, 308 и/или 310. Исполнительный блок 307 принимает информацию о декодированных арифметических операциях от устройства 305 выборки команд и выполняет арифметические операции над операндами согласно коду операции команды. Операнды передаются в исполнительное устройство 307 либо из запоминающего устройства 105, либо из собственных регистров 309, либо извлекаются из внутреннего поля выполняемой команды. Результаты выполнения команды, требующие сохранения, сохраняются либо в запоминающем устройстве 105, либо в собственных регистрах 309, либо в ином аппаратном обеспечении вычислительной системы (например, в управляющих регистрах, регистрах ССП и т.п.).
Как правило, процессор 106 снабжен одним или более исполнительными устройствами 307, 308 и 310, предназначенными для выполнения указанной командой функции. На схеме, показанной на фиг. 4А, исполнительное устройство 307 может обмениваться информацией с собственными регистрами 309 общего назначения, устройством 306 декодирования-диспетчеризации, устройством 310 загрузки-хранения и другими устройствами 401 процессора с помощью интерфейсной логики 407. В исполнительном устройстве 307 могут применяться различные схемы 403, 404 и 405 регистров для временного хранения информации, предназначенной для обработки арифметическо-логическим устройством (АЛУ) 402. АЛУ 402 выполняет арифметические операции, такие как сложение, вычитание, умножение и деление, а также логические операции, такие как конъюнкция, дизъюнкция, сложение по модулю 2, сдвиг, циклический сдвиг. Согласно варианту осуществления изобретения АЛУ поддерживает специализированные операции, зависящие от особенностей архитектуры. Прочие схемы могут реализовывать другие предусмотренные архитектурой процессора средства, в том числе например, работу с кодами условий и логику поддержки восстановления. Как правило, результат операции, выполненной АЛУ, сохраняется в схеме 406 выходного регистра, которая может передавать указанный результат набору других средств обработки. Существует множество других вариантов осуществления схем процессорных устройств, и настоящее описание предназначено исключительно для пояснения одного из вариантов осуществления.
Например, команда арифметического сложения (команда ADD) может выполняться в исполнительном устройстве 307, позволяющем выполнять арифметические и логические операции, в то время как, например, команда с плавающей запятой может выполняться в исполнительном устройстве команд с плавающей запятой (на чертеже не показано), обладающем соответствующими возможностями. Исполнительное устройство предпочтительно работает с операндами, идентифицируемыми по команде, т.е. по выполняемой функции над операндами, определяемой кодом операции. Например, команда ADD может выполняться исполняющим устройством 307 над операндами, располагающимися в двух собственных регистрах 309, идентифицируемых по входящим в состав команды полям регистров.
Исполнительное устройство 307 выполняет арифметическое сложение двух операндов и сохраняет результат операции в третьем операнде, причем указанный третий операнд может располагаться в третьем регистре или в одном из регистров, в которых располагались исходные операнды. Исполнительное устройство 307 предпочтительно использует АЛУ 402, которое способно выполнять различные логические функции, такие как сдвиг, циклический сдвиг, конъюнкцию, дизъюнкцию, сложение по модулю 2, а также различные арифметические операции, в том числе сложение, вычитание, умножение, деление. Некоторые разновидности АЛУ 402 проектируются для скалярных операций, а некоторые - для операций с плавающей запятой. В зависимости от вариантов осуществления данные могут представляться в обратном порядке следования битов (т.е. наименее значимому биту соответствует наибольший адрес) или в прямом порядке следования битов (т.е. наименее значимому биту соответствует наименьший адрес). В архитектуре IBM z/Architecture для представления данных используется обратный порядок следования битов. Числа со знаком зависимости от архитектуры могут храниться в виде знака и значения числа, в виде дополнения числа до единицы или дополнения до двух. Представление чисел в виде дополнения до двух обладает преимуществом, поскольку в этом случае в АЛУ не требуется предусматривать отдельную функцию вычитания: для положительных и отрицательных чисел, представленных в форме дополнения до двух, в АЛУ требуется только операция сложения. Числа обычно описываются в сокращенной форме, как блоки длиной, например, 4 килобайта: 12-разрядное поле определяет адрес блока длиной 4096 байтов.
При выполнении команды ветвления информация о команде обычно передается в устройство 308 ветвления (см. схему на фиг. 4Б), которое использует алгоритм предсказания ветвления, такой как таблица 432 истории ветвления, для предсказания результата ветвления еще до того, как будут завершены другие условные операции. В этом случае ветвь алгоритма - возможный исход текущей команды ветвления будет загружена и спекулятивно выполнена до того, как будет завершено выполнение условных операций. Когда выполнение условных операций завершится, то спекулятивно выполненные команды ветви алгоритма либо будут использованы, либо будут отброшены в зависимости от условий операции принятия решения и результатов спекулятивно выполненных операций. Типичная команда ветвления может проверять коды условий, и если коды условий удовлетворяют требованию ветви команды ветвления, то переходить по адресу соответствующей ветви. Адрес перехода может быть рассчитан на основе различных значений, в том числе например, содержащихся в полях регистров или во внутренних полях команды. Согласно варианту осуществления изобретения устройство 308 ветвления может использовать АЛУ 426, содержащее набор схем 427, 428 и 429 входных регистров и схему 430 выходного регистра. Устройство 308 ветвления может обмениваться информацией с регистрами общего назначения, устройством 306 декодирования-диспетчеризации или, например, с другими устройствами 425.
Выполнение группы команд может быть прервано по ряду причин, в том числе например: по команде смены задачи от операционной системы; при возникновении программного исключения или ошибки, вызывающих переключение задач; по сигналу прерывания ввода-вывода, приводящему к переключению задач; вследствие многопоточной активности многих программ (в многопоточных вычислительных системах). Согласно варианту осуществления изобретения операция переключения задач предпочтительно сохраняет информацию состояния о программе, выполнявшейся до настоящего момента времени, после чего загружает информацию о состоянии другой запускаемой программы. Информация о состоянии может храниться, например, в регистрах аппаратного обеспечения либо в запоминающем устройстве. Информация о состоянии предпочтительно содержит: значение программного счетчика, указывающее на следующую подлежащую выполнению команду; коды условий; информацию о трансляции пространства памяти; содержимое собственных регистров вычислительной системы. Переключение задач может выполняться аппаратными схемами, прикладными программами, программами операционной системы или кодом в ПЗУ (микрокодом, пикокодом или лицензированным внутренним кодом) по отдельности или совместно.
Процессор обращается к операндам в соответствии с методами, определенными командой. Команда может предоставить в качестве операнда значение, содержащееся в части самой команды, может предоставить одно или более полей регистров, явно указывающих либо на регистры общего назначения или на специальные регистры (например, на регистры с плавающей запятой). Команда может косвенно указывать на регистры, идентифицируемые в соответствии с кодом операции как операнды. Команда может использовать в качестве операндов ячейки памяти. На местоположение операнда в пространстве памяти может указывать содержимое регистра, поля из состава команды или комбинация данных в регистрах и в поле команды, как, например, это реализовано в функционале длинного размещения в архитектуре z/Architecture, в котором команда определяет, например, базовый регистр, регистр индекса и поле внутри команды (поле смещения), объединенное содержимое которых даст адрес операнда в запоминающем устройстве. Здесь подразумевается местоположение в главном запоминающем устройстве, если явно не оговорено иное.
Процессор обращается к запоминающему устройству, используя устройство 310 загрузки-хранения, схема которого показана на фиг. 4B. Устройство 310 загрузки-хранения может выполнять операцию загрузки путем получения адреса требуемого операнда в запоминающем устройстве через интерфейс кэш-память - запоминающее устройство и собственно загрузки операнда в собственный регистр 309 или другую ячейку запоминающего устройства, либо может выполнять операцию сохранения путем получения адреса требуемого операнда в запоминающем устройстве и записи данных, полученных из собственного регистра 309 или другой ячейки запоминающего устройства, в соответствующую ячейку запоминающего устройства. Устройство 310 загрузки-хранения может действовать спекулятивно и может обращаться к запоминающему устройству в последовательности, не соответствующей той, которая определяется порядком следования команд. Однако устройство 310 загрузки-хранения должно предоставлять данные таким образом, чтобы команды выполнялись в установленном программой порядке. Устройство 310 загрузки-хранения может обмениваться данными с регистрами 309 общего назначения, устройством 306 декодирования-диспетчеризации, интерфейсом кэш-память - запоминающее устройство или другими устройствами 455 и содержать в своем составе различные схемы регистров, АЛУ 458 и управляющую логику 463 для вычисления адресов хранения и формирования конвейерной последовательности данных для обеспечения правильной очередности выполнения команд. В данной области техники хорошо известно, что некоторые операции могут выполняться в порядке, отличном от установленного, однако при этом устройство загрузки-хранения должно действовать таким образом, чтобы выполненные в ином порядке операции представлялись программе будто бы выполненными в правильном порядке.
Адреса, которыми оперирует прикладная программа, часто называют виртуальными. Для обозначения виртуальных адресов иногда используются термины "логические адреса" и "эффективные адреса". Указанные виртуальные адреса виртуальны в том смысле, что они преобразуются в адресное пространство физической памяти с использованием одной из множества технологий трансляции динамических адресов, такой как реализованная в функциональном узле 312 (см. фиг. 3), в том числе (но не ограничиваясь) добавлением значения смещения как префикса к виртуальному адресу, преобразованием виртуальных адресов в соответствии с одной или более таблиц трансляции, причем таблицы трансляции предпочтительно состоят по меньшей мере из отдельной таблицы сегментов и отдельной таблицы страниц или из комбинации этих таблиц, предпочтительно такой, что таблица сегментов содержит запись, указывающую на таблицу страниц. В архитектуре z/Architecture предусмотрена иерархия трансляции, в том числе таблица первой области, таблица второй области, таблица третьей области, таблица сегментов и, опционально, таблица страниц. Производительность трансляции адресов часто повышается при использовании буфера быстрого преобразования адреса, который содержит записи, отображающие виртуальные адреса на адреса ячеек физической памяти. Записи создаются, когда процедура динамической трансляции адресов в функциональном узле 312 транслирует виртуальный адрес с использованием таблиц трансляции. При последующем обращении по виртуальному адресу вместо последовательных обращений к медленной таблице преобразования адреса может использоваться запись в буфере быстрого преобразования адреса. Содержимое буфера быстрого преобразования адреса может поддерживаться различными алгоритмами замены, в том числе алгоритмом удаления дольше всех неиспользовавшихся элементов.
Если процессор 106 является частью многопроцессорной системы, то каждый процессор отвечает за взаимное блокирование совместно используемых ресурсов, таких как устройства ввода-вывода, кэш-память, буфер быстрого преобразования адреса, запоминающее устройство, что необходимо для обеспечения когерентности информации. Согласно варианту осуществления изобретения для поддержания когерентности содержимого кэш-памяти используются снуп-технологии. В снуп-технологиях для упрощения использования каждая строка кэш-памяти может быть помечена как находящаяся в одном из состояний совместного использования, в состоянии эксклюзивного использования, в измененном состоянии, в недостоверном состоянии и т.п.
Устройства 304 ввода-вывода (см. фиг. 3) дают процессору 106 возможность обмениваться данными с периферийными устройствами, например, с такими как ленточный накопитель, дисковый накопитель, принтеры, дисплеи, сетевое окружение. Устройства 304 ввода-вывода часто представляются компьютерной программе программами-драйверами. В компьютерах-мейнфреймах, таких как z/Series корпорации IBM, адаптеры каналов и адаптеры открытой системы являются устройствами ввода-вывода мейнфрейма, которые обеспечивают связь операционной системы с периферийными устройствами.
Сведения о ходе вычислений представляют собой данные, относящиеся к выполняемым процессором 106 операциям. Согласно варианту осуществления изобретения доступ к сведениям о ходе вычислений и другим параметрам системного уровня может быть ограничен или невозможен. Процессор компьютера работает в привилегированном режиме (т.е. в режиме супервизора), а также в режиме низких привилегий (т.е. в режиме задач). В привилегированном режиме программа может иметь доступ ко всем ресурсам через привилегированные операции (например, доступ к управляющим регистрам и области памяти супервизора). Привилегированный режим также называют привилегированным состоянием или режимом супервизора. В привилегированном режиме может работать выполняемая процессором компьютера операционная система. Режим низких привилегий по существу является режимом без привилегий, в этом режиме доступ к системным ресурсам ограничен. Например, прикладные программы, выполняемые в режиме низких привилегий, могут иметь ограниченный доступ или не иметь доступа к управляющим регистрам и могут обращаться только к пользовательскому пространству памяти, которое выделяется прикладному приложению операционной системой. Как правило, режим низких привилегий назначается прикладным программам, выполняемым под управлением операционной системы, и в режиме низких привилегий привилегированные операции выполняться не могут. Режим низких привилегий также называют состоянием низких привилегий, режимом задач, состоянием выполнения задачи или пользовательским режимом.
Одним из таких ресурсов с ограниченным доступом, к которому выполняемой в режиме низких привилегий программе ограничен доступ на запись, является слово состояния программы (ССП), в состав которого может входить счетчик команд, содержащий адрес следующей подлежащей выполнению команды, поле кода условия, используемое командами ветвления, поле управления сбором сведений о ходе вычислений, указывающее, разрешен или же запрещен сбор таких сведений, а также другую информацию, используемую для управления последовательностью выполняемых команд и для определения состояния процессора компьютера, в том числе привилегированного режима, назначенного программе. В среде многопоточной обработки доступную вычислительную емкость процессора совместно используют или разделяют во времени много программ. Каждая из таких программ обладает контекстной информацией, в том числе соответствующим ССП, значением назначенного программе начального адреса в таблице трансляции адресов главного запоминающего устройства, набором текущих значений регистров общего назначения, управляющих регистров, регистров с плавающей запятой и т.п. Действующее в данный момент времени (т.е. управляющее) значение ССП называется текущим значением ССП. Его значение управляет программой, исполняемой в данный момент времени. Для процессора компьютера предусмотрен механизм прерываний, который позволяет процессору компьютера оперативно переключать контекст (т.е. изменять среду исполнения программ) и переходить к выполнению другой программы в ответ на возникающие программные исключения и внешние воздействия. При возникновении прерывания определенного класса процессор компьютера помещает текущее значение ССП в предназначенную для этого область памяти запоминающего устройства, называемую ячейкой старого значения ССП. Процессор компьютера извлекает новое значение ССП из второй предназначенной ячейки памяти. Это новое значение ССП и новый контекст определяют следующую программу, предназначенную для исполнения. Согласно варианту осуществления изобретения указанные ячейки памяти располагаются в области памяти запоминающего устройства, доступной процессору компьютера. После того, как процессор компьютера завершит обработку прерывания, программа, управляющая обработкой прерываний, может вновь восстановить старый контекст, в том числе загрузить старое значение ССП, сделав тем самым вновь это значение действующим значением ССП, в результате чего выполнение прерванной программы может быть продолжено.
Обращение к полям нового значения ССП может осуществляться либо в явной форме (т.е. при выполнении команды считывается часть разрядов ССП) или в неявной форме (т.е. при выборе команды или операнда, в ходе вычислений по формированию адреса, процедурами формирования адреса и т.п.). Явное обращение обычно осуществляется во время выполнения, а неявное обращение обычно осуществляется на различных стадиях конвейерной обработки во время выполнения команд (т.е. при выборке команды, декодировании команды, непосредственно во время исполнения и завершения). Обращение к отдельным полям ССП или обновление значений отдельных полей ССП может происходить независимо от других полей.
Согласно варианту осуществления изобретения, меняя контекст, операционная система управляет вычислительными ресурсами системы, в том числе активирует сбор процессором компьютера сведений о ходе вычислений. Сбор сведений о ходе вычислений может быть активирован или деактивирован как при выполнении процедур самой операционной системы, так и при выполнении любых прикладных программ, выполняемых операционной системой. Состояние средства сбора сведений о ходе вычислений, активировано или деактивировано, сохраняется как контекстная информация в ССП, связанном с программой.
Средство сбора сведений о ходе вычислений может быть встроено в модели, использующие архитектуру z/Architecture. Если средство сбора сведений о ходе вычислений инсталлировано и активировано, то при выполнении программы в одном или более накопительных буферах в составе ЦПУ собираются сведения (т.е. данные), которые затем передаются в программный буфер. Каждая единица сохраненной информации называется отчетной группой. Отчетная группа состоит из набора записей, содержание которых описывает события, распознанные ЦПУ в ходе выполнения программы.
Если средство сбора сведений о ходе вычислений инсталлировано в вычислительной системе, то разрешением вести сбор сведений о ходе вычислений управляет специальное поле ССП, называемое разрядом RI (от англ. Run-time Instrumentation - средство сбора сведений о ходе вычислений). Возможность активирования разряда RI зависит от корректности управляющих параметров средства сбора сведений о ходе вычислений, однако если значение разряда RI установлено равным единице, то управляющие параметры ЦПУ корректны и сбор сведений о ходе вычислений разрешен. Средство сбора сведений о ходе вычислений может содержать следующие команды: команду загрузки управляющих параметров средства сбора сведений о ходе вычислений; команду модификации значений управляющих параметров средства сбора сведений о ходе вычислений; команду извлечения средства сбора сведений о ходе вычислений; команду выборки следующей команды средства сбора сведений о ходе вычислений; команду отключения средства сбора сведений о ходе вычислений; команду включения средства сбора сведений о ходе вычислений; команду сохранения значений управляющих параметров средства сбора сведений о ходе вычислений; команду тестирования значений управляющих параметров средства сбора сведений о ходе вычислений.
Команда LRIC (от англ. Load Run-time-instrumentation Controls - загрузить управляющие параметры средства сбора сведений о ходе вычислений) осуществляет инициализацию (т.е. присвоение начальных значений) управляющих параметров средства сбора сведений о ходе вычислений. Команда MRIC (от англ. - Modify Run-time-instrumentation Controls - модифицировать значения управляющих параметров средства сбора сведений о ходе вычислений) изменяет значение всех или некоторых управляющих параметров средства сбора сведений о ходе вычислений, исходное значение которым присваивается командой LRIC. Команда RIEMIT (от англ. Run-time-instrumentation Emit - [команда] извлечь [данные для] средства сбора сведений о ходе вычислений) извлекает значение регистра общего назначения и сохраняет его в накопительном буфере. Команда RINEXT (от англ. Run-time-instrumentation Next - следующая [команда] средства сбора сведений о ходе вычислений) предписывает считать выборочной команду, следующую по порядку за командой RINEXT. Команда RIOFF (от англ. Run-time-instrumentation OFF - отключить средство сбора сведений о ходе вычислений) деактивирует сбор сведений о ходе вычислений. Команда RION (от англ. Run-time-instrumentation ON - включить средство сбора сведений о ходе вычислений) активирует сбор сведений о ходе вычислений. Команда STRIC (от англ. Store Run-time-instrumentation Controls - сохранить значения управляющих параметров средства сбора сведений о ходе вычислений) помещает текущие значения управляющих параметров средства сбора сведений о ходе вычислений в определенную ячейку памяти запоминающего устройства. Команда TRIC (от англ. Test Run-time-instrumentation Controls - протестировать значения управляющих параметров средства сбора сведений о ходе вычислений) проверяет значения управляющих параметров средства сбора сведений о ходе вычислений: если критерий проверки выполняется, то устанавливается соответствующее состояние индикатора изменения управляющих параметров.
Средство сбора сведений о ходе вычислений обладает возможностью откладывать внешние прерывания, вызванные срабатыванием механизма контроля. Некоторая часть информации, собираемой средством сбора сведений о ходе вычислений и передаваемой в программный буфер, зависит от типа модели и поэтому не специфицирована (т.е. значение некоторых разрядов не определено). Выборки и данные, формируемые средством сбора сведений о ходе вычислений, предназначенные для статистического оценивания характеристик производительности, хоть и являются принципиально точными, однако повторно воспроизведены быть не могут. Например, независимо от режима выборок невозможно предсказать, приведет ли выборочная команда, вызывающая прерывание или связанная с некоторым интервалом активности системы, к сохранению отчетной группы, а если и приведет к сохранению отчетной группы, то будут ли затронуты зависящие от типа модели данные, включенные в состав сведений о состоянии вычислительной системы.
Накопительный буфер используется для временного хранения набора записей, содержание которых служит отчетом о событиях, распознанных процессором во время выполнения программы. Например: выполнение одного или более ветвлений; останов (прекращение) выполнения транзакции; промах при выборке команды из кэш-памяти; промах при выборке или сохранении данных из кэш-памяти, или операнда команды RIEMIT. Команда RIEMIT извлекает значение регистра общего назначения и сохраняет это значение в накопительном буфере. Дополнительные данные могут извлекаться и/или сохраняться в других буферах, например, в буфере данных команд.
Формирование отчетной группы зависит от значений управляющих параметров отчетной группы. По идентификации выборочной команды каждый управляющий параметр отчетной группы разрешает проверку соответствующего условия. Если соответствующее условие выполнено, то отчетная группа формируется и сохраняется. Сохранение отчетной группы не производится, если не активирован ни один управляющий параметр отчетной группы, либо если ни для одного из активированных управляющих параметров отчетной группы соответствующее условие не выполняется. Доступ к отчетным данным о выборочной команде осуществляется из буфера данных команд и других источников, зависящих от типа модели; указанные отчетные данные затем используются для формирования содержимого одной или большего числа записей отчетной группы, причем одной из таких записей является запись типа команда.
Типы записей, которые могут быть включены в состав сохраняемой отчетной группы: заполнитель (от англ.: filler); дополнительный (от англ.: extra); начальный (от англ.: begin); отметка времени (от англ.: timestamp); команда (от англ.: instruction); извлечение (от англ.: emit); останов режима выполнения транзакции (от англ.: transaction-execution mode abort); вызов (от англ.: call); возврат (от англ.: return); передача (от англ.: transfer). Запись типа заполнитель может использоваться в отчетной группе в случае, если число корректных записей в накопительном буфере недостаточно для формирования отчетной группы заданного используемого в текущий момент размера. Запись типа дополнительный может использоваться в дополнительной секции отчетной группы. Запись типа начало является первой записью первой отчетной группы. Запись типа отметка времени используется как запись ноль (т.е. первая по счету) каждой отчетной группы за исключением первой отчетной группы. Запись типа команда формируется, если отчетная группа сохраняется для выборочной команды как последняя запись отчетной группы. Запись типа извлечение формируется в результате успешного выполнения команды RIEMIT. Запись типа останов режима выполнения транзакции формируется либо при неявном останове, либо в результате выполнения команды останова транзакции. Запись типа вызов формируется при выполнении команды ветвления, которая относится к командам ветвления типа вызов. Запись типа возврат формируется при выполнении команды ветвления, которая относится к командам ветвления типа возврат. Запись типа передача формируется при выполнении команды ветвления, которая удовлетворяет определенному критерию кода условия.
На фиг. 5 показана схема системы для сбора сведений о ходе вычислений в процессоре, которая может быть применена согласно варианту осуществления изобретения. Согласно варианту осуществления изобретения, система 500 содержит ЦПУ, такой как процессор 106 (см. фиг. 1). Согласно варианту осуществления изобретения процессор 106 является одиночным процессором. Согласно альтернативному варианту осуществления процессор 106 является одиночным процессорным ядром многоядерного процессора. Согласно варианту осуществления изобретения, процессор 106 способен работать с изменяющейся скоростью.
Согласно варианту осуществления изобретения процессор 106 также содержит регистр 510. Указанный регистр 510 является аппаратным регистром и способен сохранять данные в виде слов для использования процессором 106. Регистр 510 содержит одну или более защелок (т.е. схем промежуточного хранения) для хранения разрядов данных, которые доступны процессору 106. Регистр 510 может, например, содержать регистры общего назначения и управляющие регистры. Процессор 106 также содержит инструментальный модуль 506, который может обмениваться информацией с регистром 510. Инструментальный модуль 506 является обрабатывающей схемой, управляющей сбором сведений о состоянии процессора 106. Инструментальный модуль 506 сконфигурирован для сбора сведений о ходе вычислений напрямую от процессора 106, таких как ветвь выполнения программы, выбранная одной или более операциями ветвления, события останова выполнения транзакции, различных операндов выполняемой программы, информации об отметках времени и т.д. Инструментальный модуль 506 собирает сведения о состоянии вычислительной системы от процессора 106 и сохраняет указанные данные в накопительном буфере 508. Согласно варианту осуществления изобретения накопительный буфер 508 представляет собой буфер кольцевого типа, который собирает данные, полученные от инструментального модуля 506. В случае полного заполнения буфера кольцевого типа поступающие данные записываются поверх наиболее старых данных буфера, замещая их.
Процессор 106 выполняет одну или более операционных систем 516 и одно или более приложений 518. Одна или более операционных систем 516 и одно или более приложений 518 хранятся в запоминающем устройстве 520, таком как накопитель на жестких дисках, CD-ROM, флеш-память и т.д., и загружаются в главное запоминающее устройство 514 в область 504 выполняемых программ, зарезервированную для хранения одного или более активных фрагментов выполняемой операционной системы и/или приложения, вызываемых страниц, которые загружаются по мере необходимости из запоминающего устройства 520 в область 504 выполняемых программ. Согласно варианту осуществления изобретения каждая из операционных систем выполняется как виртуальная машина, управляемая гипервизором (на фигурах гипервизор не показан) и исполняемая процессором 106.
Согласно варианту осуществления изобретения процессор 106 для исполняемой в текущий момент времени операционной системы или приложения загружает ССП в регистр 510 из области 512 данных ССП главного запоминающего устройства 514 и устанавливает один или более управляющих параметров процессора, например, в регистре 510. Согласно варианту осуществления изобретения ССП в регистре 510 содержит один или более разрядов, предназначенных для активации и управления инструментальным модулем 506.
Одно или более приложений 518 включают программы-приложения, скомпилированные для выполнения на специфической операционной системе, интерпретируемый код, выполняемый на интерпретаторе (например, на интерпретаторе языка Java), или потоки поддержки операционной системы (например, менеджмент процессов, демоны и т.п.). Каждая из указанных одной или более операционных систем 516 и одного или более приложений 518 могут выполнить команду для указания инструментальному модулю 506 начать или остановить сбор данных о ходе вычислений.
Согласно варианту осуществления изобретения одно из указанных приложений 518 выполняет команду, которая определяется как выборочная команда. По завершении выполнения выборочной команды создается точка выборки, в результате чего инструментальный модуль 506 перемещает собранные о работе приложения данные из накопительного буфера 508 в программный буфер 522, располагающийся в главном запоминающем устройстве 514, к которому возможен доступ приложению. Главным запоминающим устройством 514 может являться адресуемое запоминающее устройство любого известного типа. Согласно варианту осуществления изобретения главное запоминающее устройство 514 может содержать быстродействующее буферное запоминающее устройство, называемое иногда кэш-памятью. Каждое ЦПУ может обладать связанной с ним кэш-памятью. Согласно дополнительному варианту осуществления главное запоминающее устройство 514 является динамическим запоминающим устройством с произвольной выборкой (динамическим ОЗУ). Согласно другому варианту осуществления главное запоминающее устройство является устройством хранения, таким как компьютерный накопитель на жестких дисках или флеш-память, к которым может обращаться приложение.
Для настройки значений управляющих параметров средства сбора сведений о ходе вычислений процессор 106 поддерживает команду загрузки управляющих параметров (команду LRIC). Следует учитывать, что помимо специфических полей, описание которых приводится далее, для осуществления дополнительных функций в команде LRIC могут быть определены дополнительные поля. Команда LRIC может использоваться для загрузки и начального конфигурирования средства сбора сведений о ходе вычислений, эта команда поддерживается инструментальным модулем 506. Согласно варианту осуществления изобретения инструментальный модуль 506, который также называют инструментальным модулем 506 средства сбора сведений о ходе вычислений, использует управляющие параметры средства сбора сведений о ходе вычислений и управляющие параметры отчетной группы. Текущее состояние управляющих параметров средства сбора сведений о ходе вычислений может быть переписано из регистра 510 (см. фиг. 5) и сохранено в главном запоминающем устройстве 514 с использованием команды сохранения значений управляющих параметров (команда STRIC). Далее дается определение различных полей блока параметров RICCB, загружаемого как операнд команды LRIC, оно также используется в настоящей заявке для ссылки на состояние соответствующих управляющих параметров средства сбора сведений о ходе вычислений.
На фиг. 6 показана схема фрагмента 600 управляющего блока управляющих параметров средства сбора сведений о ходе вычислений (блока параметров RICCB) согласно варианту осуществления изобретения. Указанный фрагмент 600 блока параметров RICCB содержит управляющие параметры, значения которых согласно варианту осуществления изобретения могут устанавливаться в привилегированном режиме. Фрагмент 600 блока параметров RICCB может содержать дополнительные управляющие параметры (величины) помимо описываемых далее и показанных на фиг. 6. Во фрагмент 600 блока параметров RICCB командой LRIC могут вноситься изменения.
Фрагмент блока параметров RICCB содержит разряд 602 V корректности. Разряд 602 корректности отображает достоверность набора управляющих параметров средства сбора сведений о ходе вычислений в процессоре в том виде, как они были ранее установлены командой LRIC.
Блок параметров RICCB также содержит разряд 604 S, который используется для проверки, разрешается ли в режиме низких привилегий выполнять команду MRIC. Разряд 606 "К" указывает, разрешается ли выполнение программы с низкими привилегиями в режиме частичных привилегий с учетом управляющих параметров средства сбора сведений о состоянии вычислительной системы, таких как начальный адрес и конечный адрес. Разряд 608 Н определяет, относятся ли управляющие параметры адреса (т.е. начальный адрес, конечный адрес и текущий адрес) к основному виртуальному адресному пространству или к домашнему виртуальному адресному пространству. Разряд 610 "0" (ноль) игнорируется и обрабатывается как число ноль.
Управляющий разряд 612 Ps выборки отчетной группы режима низких привилегий используется совместно с программами режима низких привилегий. В режиме низких привилегий при равенстве нулю разряда 612 Ps и при активированном средстве сбора сведений о ходе вычислений игнорируются управляющие параметры отчетной группы из числа управляющих параметров средства сбора сведений о ходе вычислений, в результате чего отчетная группа не сохраняется. В режиме низких привилегий при равенстве значения разряда 612 Ps единице управляющие параметры отчетной группы проверяются и используются согласно своему функциональному назначению.
Управляющий разряд 614 Qs выборки отчетной группы режима супервизора используется совместно с программами режима супервизора. В режиме супервизора при равенстве нулю разряда 614 Qs и при активированном средстве сбора сведений о ходе вычислений игнорируются управляющие параметры отчетной группы из числа управляющих параметров средства сбора сведений о ходе вычислений, в результате чего отчетная группа не сохраняется. В режиме супервизора при равенстве значения разряда 614 Qs единице управляющие параметры отчетной группы проверяются и используются согласно своему функциональному назначению.
Управляющий разряд 616 Рс накопительного буфера режима низких привилегий управляет обновлением содержимого накопительного буфера 508 (см. фиг. 5). В режиме низких привилегий при равенстве нулю разряда 616 Рс и при активированном средстве сбора сведений о ходе вычислений управляющие параметры накопительного буфера из числа управляющих параметров средства сбора сведений о ходе вычислений игнорируются, и обновление накопительного буфера 508 запрещено. В режиме низких привилегий при равенстве значения разряда 616 Рс единице управляющие параметры накопительного буфера проверяются и используются согласно своему функциональному назначению.
Управляющий разряд 618 Qc накопительного буфера режима супервизора управляет обновлением содержимого накопительного буфера 508 (см. фиг. 5). В режиме супервизора при равенстве нулю разряда 618 Qc и при активированном средстве сбора сведений о ходе вычислений управляющие параметры накопительного буфера из числа управляющих параметров средства сбора сведений о ходе вычислений игнорируются, и обновление накопительного буфера 508 запрещено. В режиме супервизора при равенстве значения разряда 618 Qc единице управляющие параметры накопительного буфера проверяются и используются согласно своему функциональному назначению.
Разряд 620 G является управляющим параметром отсрочки (от англ.: pending) остановочного прерывания (от англ.: halted interruption) средства сбора сведений о ходе вычислений, называемого также остановочным прерыванием. Если значение разряда 620 G равняется нулю, то остановочное прерывание не откладывается. Если значение разряда 620 G равняется единице, то остановочное прерывание откладывается. Когда в программный буфер 522 записана первая отчетная группа, значение разряда 620 G устанавливается равным нулю. То есть если начальный адрес 702 ROA (от англ. Run-time-instrumentation program-buffer Origin Address - начальный адрес программного буфера средства сбора сведений о ходе вычислений) программного буфера средства сбора сведений о ходе вычислений совпадает с текущим адресом 706 RCA (от англ. Run-time-instrumentation program-buffer Current Address - текущий адрес программного буфера средства сбора сведений о ходе вычислений) программного буфера средства сбора сведений о ходе вычислений, то значение разряда 620 G устанавливается равным нулю (см. фиг. 7). Если условие остановочного прерывания средства сбора сведений о ходе вычислений не активно, то при попытке сохранения в программном буфере 522 любой отчетной группы кроме первой значение разряда 620 G устанавливается равным нулю и отчетная группа сохраняется. Если условие остановочного прерывания средства сбора сведений о ходе вычислений активно, то при попытке записи в программный буфер 522 любой отчетной группы, кроме первой, значение разряда 620 G устанавливается равным единице и отчетная группа не сохраняется.
Разряд 622 U (см. фиг. 6) является разрешающим управляющим параметром для прерывания по переполнению буфера и остановочного прерывания. Если разряд 622 U равен нулю, то формирование запроса на прерывание отключено, однако если прерывание уже отложено, то оно остается отложенным.
Разряд 624 L является управляющим параметром отсрочки для прерывания по переполнению буфера. Если разряд 624 L равен нулю, то прерывание по заполнению буфера не откладывается. Если разряд 624 L равен единице, то прерывание по заполнению буфера откладывается.
Поле 626 ключа представляет собой четырехразрядное беззнаковое целое число, значение которого используется в качестве защитного ключа хранения при сохранении отчетной группы. Сохранение отчетной группы разрешается, только если ключ хранения совпадает с ключом доступа, связанным с запросом на доступ к хранилищу, а выборка разрешается, если ключ хранения совпадает с ключом доступа или если значение разряда защиты выборки ключа хранения равно нулю. Ключи хранения и доступа совпадают, если совпадают их соответствующие значения четырех разрядов управления доступом, либо если ключ доступа равен нулю.
На фиг. 7 показана схема фрагмента блока параметров RICCB в случае, когда в режиме частичных привилегий (т.е. в случае, когда значение разряда "К" равно единице) разрешается использование команды MRIC. Блок 700 параметров RICCB может также являться операндом команды LRIC и использоваться для инициализации управляющих параметров средства сбора сведений о ходе вычислений. Блок 700 параметров RICCB может содержать дополнительные управляющие параметры помимо описываемых далее и показанных на фиг. 7. Согласно варианту осуществления изобретения программа в режиме низких привилегий не имеет доступа к тем фрагментам операнда команды MRIC, которые не обозначены. Если разрешен режим частичных привилегий, то начальный адрес 702 ROA и конченый адрес 704 RLA устанавливаются программой режима низких привилегий с помощью команды командой MRIC. Начальный адрес 702 ROA средства сбора сведений о ходе вычислений указывает на местоположение первого байта программного буфера 522 (см. фиг. 5). Конечный адрес 704 RLA указывает на местоположение последнего байта программного буфера 522.
Согласно варианту осуществления изобретения текущий адрес 706 RCA программного буфера средства сбора сведений о ходе вычислений может обновляться командой MRIC. Текущий адрес 706 RCA указывает местоположение в программном буфере 522 следующей отчетной группы, подлежащей сохранению. Текущий адрес 706 RCA учитывает значение поля 744 RGS (от англ. Reporting Group Size - длина отчетной группы) и влияет на число значащих разрядов, используемых для формирования адреса программного буфера 522. Текущий адрес 706 RCA длиной 64 разряда занимает слово с порядковым номером ноль, разряды с нулевого по 26-й - RGS слова 1 и RGS+5 двоичных нулей, которые добавляются справа. Это начальное местоположение в программном буфере 522 (см. фиг. 5) последующей отчетной группы, которая будет сохранена в программном буфере 522. Отчетная группа - это единица информации, которая формируется инструментальным модулем 506 и сохраняется в программном буфере 522. Согласно варианту осуществления изобретения, если значение в поле 744 длины отчетной группы, определенное текущим адресом 706 RCA, не равно текущей длине отчетной группы средства сбора сведений о ходе вычислений (т.е. текущий адрес 706 RCA должен изменить значение поля 744 RGS длины отчетной группы), то текущий адрес 706 RCA устанавливается равным начальному адресу 702 ROA.
Значение поля 742 RSIC (от англ. Remaining Sample Interval Count - число оставшихся интервалов выборок) может обновляться программой режима низких привилегий с использованием команды MRIC. Поле 742 RSIC содержит 64-разрядное беззнаковое целое число, которое отражает счет оставшихся интервалов выборок. Если значение поля 742 RSIC равняется нулю или равно значению поля 740 SF (от англ. Scaling Factor - коэффициент масштабирования) и средство сбора сведений о ходе вычислений активировано, то следующий интервал выборки является полным интервалом, определяемым значениями поля 708 М режима выборок и поля 740 SF коэффициента масштабирования. Если значение поля 742 RSIC 742 отлично от нуля и меньше, чем значение поля 740 SF коэффициента масштабирования, и средство сбора сведений о ходе вычислений активировано, то следующий интервал выборки является частичным интервалом. Если значение поля 742 RSIC 742 отлично от нуля и больше, чем значение поля 740 SF коэффициента масштабирования, и средство сбора сведений о ходе вычислений активировано, то следующий интервал выборки является расширенным интервалом. Если расширенный интервал завершается, то продолжительность следующего интервала определяется значением поля 740 SF коэффициента масштабирования. Если значение поля 742 RSIC установлено отличным от нуля, то оно ограничивается тем же зависящим от типа модели пределом, которым ограничено значение поля 740 SF коэффициента масштабирования. Если исходное значение поля 742 RSIC равно нулю, то режим выборок будет определять, устанавливается ли значение поля 742 RSIC равным значению поля 740 SF при выполнении команд LRIC и MRIC, или же оно будет оставаться равным нулю до тех пор, пока активно средство сбора сведений о ходе вычислений.
Поле 740 SF коэффициента масштабирования содержит 64-разрядное беззнаковое целое число, которое является счетчиком единиц коэффициента масштабирования. Размерность единиц определяется значением поля 708 режима выборок. Если значение поля 742 RSIC равно нулю, то поле 740 SF коэффициента масштабирования определяет начальное значение поля 742 RSIC 742, которое в процессе счета уменьшается до нуля. В этот момент текущая команда распознается как выборочная и счетчик интервалов обновляется значением поля 740 SF коэффициента масштабирования. Корректное значение поля 740 SF коэффициента масштабирования находится в пределах от единицы до 264 - 1. Если значение коэффициента масштабирования равняется нулю, то подразумевается значение единица. Тем не менее, в каждой модели может существовать свое минимальное и максимальное значения поля 740 SF коэффициента масштабирования. Минимальные и максимальные значения могут также различаться в зависимости от значения поля 708 режима выборок. Если указано значение, меньшее минимального, то загружается значение, минимальное для данной модели. Если указано значение, превышающее максимальное, то загружается значение, максимальное для данной модели.
Управляющее поле 736 DC представляет собой четырехразрядное беззнаковое целое число, значение которого обозначает уровень латентности кэш-памяти (т.е. показатель задержки при обращении к запоминающему устройству), связанный с промахом при выборке или записи в кэш-память данных. Имеется в виду промах (т.е. отсутствие нужных данных) при обращении выборочной команды к кэш-памяти данных. Если это не запрещено каким-либо другим управляющим параметром средства сбора сведений о ходе вычислений, делается попытка сохранить отчетную группу, представляющую выборочную команду, вызвавшую промах на уровне латентности кэш-памяти, численно большем или равном уровню, установленному значением управляющего поля 736 DC. Структура кэш-памяти и уровень латентности кэш-памяти при доступе к данным зависит от типа модели. В случае команды с большим числом операндов или в случае команды с операндами большой длины от типа модели зависит также то, к какому из обращений к данным будут применяться управляющие параметры отчетной группы и будет ли вообще какое-либо из обращений к данным использоваться. Вообще действия, зависящие от типа модели, могут игнорировать значение управляющего поля 736 DC, и значение этого поля может не использоваться в качестве критерия сохранения отчетной группы.
Поле 734 IC представляет собой четырехразрядное беззнаковое целое число, значение которого обозначает уровень латентности кэш-памяти, связанный с промахом кэш-памяти команд. Имеется в виду обращение за выборочной командой, приводящее к промаху кэш-памяти команд. И для поля 734 IC, и для управляющего поля 736 DC уровень латентности кэш-памяти является обобщенным показателем того, как далеко от рассматриваемого процессора распространяется обращение к кэш-памяти определенного уровня. Уровень латентности зависит как от числа уровней вложенной кэш-памяти между данным процессором и главным запоминающим устройством, так и от того, как эти уровни кэш-памяти распределяются между множеством процессоров. В общем случае больший уровень латентности соответствует большей продолжительности доступа. Значения полей 734 IC и 736 DC могут рассматриваться как отсчитываемые с нуля показатели уровня латентности кэшпамяти. Например, значение ноль соответствует уровню L1 кэш-памяти, т.е. кэш-памяти, располагающейся наиболее близко к процессору. Соответственно, за кэш-памятью первого уровня (за значением единица) следует кэш-память уровня L2 или даже в некоторых вычислительных машинах кэш-память уровня L1.5. Значения от 2 до 15 соответствуют продвижению по дополнительным уровням латентности кэш-памяти до тех пор, пока не будет достигнут уровень главного запоминающего устройства, причем сам уровень главного запоминающего устройства в указанный интервал не включается. В общем случае структуры кэш-памяти не занимают более пятнадцати уровней. В связи с этим значение 15 поля 734 IC и управляющего поля 736 DC воспринимается как особый случай, означающий, что промах кэш-памяти соответственно при выборке команды или при обращении к данным независимо от уровня латентности кэш-памяти не распознан для целей формирования отчетной группы. Если сохранение отчетной группы не запрещено каким-либо другим управляющим параметром средства сбора сведений о ходе вычислений, то делается попытка сохранения отчетной группы, отражающей выборочную команду, чья выборка из кэш-памяти рассматривается как промах с уровнем латентности кэш-памяти, численно равным или превышающим уровень, установленный значением поля 734 IC. Структура кэш-памяти и уровень латентности кэш-памяти для выборки команд зависит от типа модели. Вообще действия, зависящие от типа модели, могут игнорировать значение поля 734 IC, и значение этого поля может не использоваться в качестве критерия сохранения отчетной группы.
Управляющий разряд 732 F учета уровня латентности обращений к кэшпамяти применяется к командам, не относящимся к командам ветвления, а также к управляющим параметрам отчетных групп о результатах предсказания ветвления. Если значение разряда 732 F в составе управляющих параметров средства сбора сведений о ходе вычислений равно нулю, то значения управляющих параметров отчетной группы об обращении к кэш-памяти (поле 734 IC и управляющее поле 736 DC) проверяются и используются согласно их функциональному назначению. В этом случае значения управляющих параметров, относящихся к отчету о предсказании ветвления (разряды 722 BPxn, 724 BPxt, 726 BPti и 728 BPni) в составе управляющих параметров средства сбора сведений о ходе вычислений, также проверяются и используются согласно их функциональному назначению. Если значение разряда 732 F в составе управляющих параметров средства сбора сведений о ходе вычислений равно единице, то значения указанных управляющих параметров отчетных групп игнорируются, и если это не запрещено каким-либо другим управляющим параметром, то отчетная группа сохраняется.
Управляющий разряд 730 D промаха кэш-памяти данных указывает, должна ли сохраняться отчетная группа. Если значение разряда 730 D равно единице, то в дополнительную часть отчетной группы, содержащую зависящие от типа модели данные о выборочной команде, разрешается или же не разрешается внесение записи типа дополнительный.
Команда MRIC содержит управляющие параметры ВР (от англ. Branch Prediction - предсказание ветвления) отчетных групп о предсказании ветвления: разряды 722 BPxn, 724 BPxt, 726 BPti и 728 BPni. Если значение управляющего разряда ВР отчетной группы равно нулю, то соответствующее условие не проверяется. Если значение управляющего разряда ВР отчетной группы равно единице и соответствующее условие предсказания ветвления активно, то отчетная группа сохраняется.
Если значение разряда 722 BPxn равно единице, то разрешена проверка информации о предсказании ветвлений. В частности, если ветвление ложно предсказано и в реальности не произошло, то отчетная группа сохраняется.
Если значение разряда 724 BPxt равняется единице, то разрешена проверка информации о предсказании ветвлений. В частности, если ложно предсказано отсутствие ветвления, но в реальности ветвление произошло, то отчетная группа сохраняется.
Если значение разряда 726 BPti равняется единице, то разрешена проверка информации о предсказании ветвлений. В частности, если ветвление предсказано верно, в реальности ветвление произошло, однако точка назначения предсказана неверно, то отчетная группа сохраняется.
Если значение разряда 728 BPni равняется единице, то разрешена проверка информации о предсказании ветвлений. В частности, если отсутствие ветвления предсказано верно, в реальности ветвление не произошло, однако точка назначения предсказана неверно, то отчетная группа сохраняется.
Разряд 720 Х управления разрешением записей режима выполнения транзакции управляет сбором записей типа останов режима выполнения транзакции. Если разряд 720 Х в составе управляющих параметров средства сбора сведений о ходе вычислений равняется нулю, то записи об останове режима выполнения транзакции регистрируются и помещаются в накопительный буфер 508 (см. фиг. 5). Если в модели не инсталлирована поддержка выполнения транзакций, то значение разряда 720 Х игнорируется.
Разряд 718 Е управления командой RIEMIT управляет действием команды RIEMIT. Если при активированном средстве сбора сведений о ходе вычислений значение разряда 718 Е равняется нулю или игнорируется (при этом значение считается равным нулю), то команда RIEMIT не выполняет действий. Если значение разряда 718 Е равняется единице и сам разряд не игнорируется, то команде RIEMIT разрешается действовать согласно своему функциональному назначению.
Значение разряда 746 J, равное нулю, определяет, что команда ВС (от англ. Branch on Condition - ветвление по условию) находится в категории ветвления другого типа вне зависимости от значения маски. Если значение разряда 746 J равняется единице, то команда ВС, которая определяет значение маски 15, находится в категории ветвления типа возврат. Если команда ВС ветвления по условию определяет значение маски от 1 до 14, то на команду не влияет значение разряда 746 J, и команда всегда находится в категории ветвления другого типа. Если тип категории ветвления - возврат, то разряд 716 R управляет включением в накопительный буфер 508 (см. фиг. 5). Если тип категории ветвления иной, то включением в накопительный буфер 508 управляет разряд 748 В. В качестве иного типа категории может также быть указана категория типа передача.
Разряд 714 С кода адреса команды управляет разрешением регистрации ветвлений типа вызов. Если значение разряда 714 С в составе управляющих параметров средства сбора сведений о ходе вычислений равно единице и команда - ветвление типа вызов, то содержимое накопительного буфера 508 обновляется. Если модель предписывает распознавать оба типа ветвления (тип вызов и тип возврат) как единый тип, то значение разряда 714 С применяется к обоим типам ветвления, а значение разряда 716 R игнорируется.
Разряд 716 R управляет разрешением регистрации ветвлений типа возврат. Если значение разряда 716 R в составе управляющих параметров средства сбора сведений о ходе вычислений равно единице и команда - ветвление типа возврат, то содержимое накопительного буфера 508 обновляется.
Разряд 748 В управляет разрешением ветвлений типов, отличных от типов вызов и возврат. Если значение разряда 748 В в составе управляющих параметров средства сбора сведений о ходе вычислений равно единице и команда - ветвление типа, отличного от указанных, то содержимое накопительного буфера 508 обновляется.
Значение разряда 712 МАЕ превышения максимального адреса, равное единице, указывает, что в одной или более сохраненных отчетных группах значение разряда 714 "С" установлено равным единице. Если значение разряда 712 МАЕ установлено равным единице, то при дальнейшем действии средства сбора сведений о ходе вычислений значение этого разряда не изменяется обратно на ноль. Значение разряда 712 МАЕ обнуляется в результате выполнения команды LRIC или команды MRIC, которые устанавливают значение МАЕ разряда 712 МАЕ равным нулю.
Разряд 710 N управляет действием команды RINEXT средства сбора сведений о ходе вычислений, которая, в свою очередь, указывает выборочную команду. Если значение разряда 710 N в составе управляющих параметров средства сбора сведений о ходе вычислений равно нулю или игнорируется (принимается равным нулю), то команда RINEXT не выполняет действий. Если значение разряда 710 N равно единице и не игнорируется, то команда RINEXT действует согласно ее функциональному назначению.
Поле 708 М режима представляет собой четырехразрядное беззнаковое целое число, значение которого определяет режим выборок для средства сбора сведений о ходе вычислений. Перечень поддерживаемых режимов выборок может содержать: режим выборок на основе подсчета циклов ЦПУ; режим выборок на основе подсчета числа команд; режим по указанию команды на выполнение выборки, такой как команда RINEXT.
Поле 744 RGS размера отчетной группы представляет собой трехзначное беззнаковое целое число, значение которого определяет число RRG записей в отчетной группе. Число записей в отчетной группе может составлять от двух и более, включая запись типа начало или отметка времени и запись типа команда (последняя запись) до 256. Согласно варианту осуществления изобретения значение верхней границы может зависеть от типа модели. Число 16-байтных записей, размещаемых в отчетной группе, составляет 2RGS+1.
Для общего обозначения управляющего разряда 738 Y блокировки первичного по производительности ЦПУ и управляющего разряда 739 Z блокировки вторичного по производительности ЦПУ используется термин управление блокировкой. Блокировка сохранения отчетной группы означает, что попытка сохранения не выполняется. Управление блокировкой игнорируется и блокировка не действует, если производительность всех ЦПУ в данной конфигурации одинакова. Если конфигурация такова, что производительность одного ЦПУ отличается от производительности другого ЦПУ, то управление блокировкой действует, и, по меньшей мере, одно ЦПУ считается первичным по производительности, и, по меньшей мере, одно ЦПУ считается вторичным по производительности. Первичное и вторичное по производительности ЦПУ различаются быстродействием. Если значения обоих разрядов 738 Y и 739 Z равны нулю, то блокировки не происходит. Если значение разряда 738 Y равно нулю и значение разряда 739 Z равно единице, и если ЦПУ, например процессор 106, работает как вторичное по производительности ЦПУ, то происходит блокировка. Если значение разряда 738 Y равно единице и значение разряда 739 Z равно нулю, и если ЦПУ, например процессор 106, работает как первичное по производительности ЦПУ, то также происходит блокировка. Если значения обоих разрядов 738 Y и 739 Z равны единице, то происходит блокировка.
Выше на фиг. 7 размещение и обозначения полей и разрядов даны в качестве примера, с целью лучшего понимания. Следует учитывать, что в других вариантах осуществления может использоваться только часть из перечисленных полей, сами поля могут располагаться в любом порядке и в любой позиции и/или для обозначения полей могут использоваться иные имена.
Если средство сбора сведений о ходе вычислений инсталлировано и активировано, то в накопительный буфер 508 может быть собраны сведения о некотором числе событий, а также данные. Накопительный буфер 508 используется для сбора записей, содержание которых отражает события, распознанные процессором 106 в ходе выполнения программы. Например: выполнение одной или более операций ветвления; события останова выполнения транзакции; промахи кэш-памяти; операнд команды типа RIEMIT. Управляющие поля 734 IC и 736 DC устанавливают уровень, при котором может быть целесообразно вносить коррективы для улучшений в части выполнения команд или упреждающей выборки данных. При выполнении команды RIEMIT производится сохранение значений регистров общего назначения в накопительном буфере 508. Дополнительные данные могут собираться и/или сохраняться в других буферах, таких как буфер IDB (от англ. Instruction-Data Buffer - буфер данных команд), используемый для сбора зависящих от типа модели данных о выборочной команде для формирования записи типа команда средства сбора сведений о ходе вычислений (на чертежах буфер IDB не показан).
Отчет о собранной средством сбора сведений о ходе вычислений информации выдается на основе выборок. Из потока команд выбирается команда, такая выбранная команда называется выборочной командой. Режимы определения выборочных команд при активированном средстве сбора сведений о ходе вычислений определяются следующим образом. В режиме подсчета числа циклов начальным значением счетчика, которое служит для формирования текущего интервала, служит число циклов ЦПУ, определенное либо полем 740 SF, либо полем 742 RSIC. Это число корректируется при возникновении события, связанного с режимом выборок. Например, это число может быть уменьшено, если процессор 106 находится в оперативном состоянии (т.е. задействован). Если значение счетчика циклов уменьшилось до порогового значения, такого как ноль, то текущая команда считается выборочной командой, а значение счетчика вновь инициализируется значением, определяемым полем 740 SF, и далее вновь начинает уменьшаться каждым с очередным циклом. Если ничто не препятствует, то по завершении выполнения выборочной команды формируется отчетная группа.
В режиме подсчета команд начальным значением счетчика, которое служит для формирования текущего интервала, служит число, определенное либо полем 740 SF, либо полем 742 RSIC. В случае выполнения команды, состоящей из одиночной операции, значение счетчика уменьшается по завершении команды, факт завершения служит событием для изменения значения счетчика. Команда считается выборочной командой, если значение счетчика снизится до порогового значения, такого как ноль. Если команда состоит из набора одиночных операций, то значение счетчика может снижаться одним из следующих способов.
А. В случае прерываемой команды все одиночные операции вплоть до частичного завершения команды считаются единым элементом, уменьшающим значение счетчика.
Б. В случае прерываемой команды все одиночные операции, начиная с последнего частичного завершения до полного завершения команды, считаются единым элементом, уменьшающим значение счетчика.
В. В случае команды, которая завершается после выполнения определяемой ЦПУ части обработки, зависящей от параметров этой команды, завершающая часть обработки считается единым элементом, уменьшающим значение счетчика.
Г. В случае команды, которая завершается после выполнения набора одиночных операций и не относится к командам по пп. А-В, значения счетчика уменьшаются по завершении последней одиночной операции команды.
Команда является выборочной командой в случае, если значение счетчика уменьшается до нуля при выполнении любого одиночного элемента этой команды. Если достигается пороговое значение, такое как ноль, то значение счетчика вновь инициализируется значением поля 740 SF и начинается обратный счет с соблюдением правил, изложенных выше в перечислении А-Г. Во всех вариантах режимов подсчета формирование отчета выполняется после завершения последней одиночной операции выборочной команды.
В режиме выборок команд по указанию выборка производится, если значение разряда 710 N равно единице и команда RINEXT выполнена успешно. Выборочная команда является следующей по порядку командой после команды RINEXT. Если эта следующая команда относится к типу исполнимый, то выборочной командой является целевая команда указанной команды типа исполнимый. Выборка по указанию может делаться в режиме подсчета циклов и в режиме подсчета команд. Выборки по результатам подсчета ведутся совместно с выборками по указанию, и выполнение любого из критериев приводит к формированию отчетной группы. Однако в случае, если результаты подсчета и указание определяют одну и ту же команду как выборочную команду, то сразу две отчетные группы не сохраняются.
Если выборочная команда определяется в результате выполнения команды RINEXT, то вне зависимости от режима выборок отчетная группа сохраняется. Однако управляющие параметры 738 Y, 739 Z, 614 Qs и 612 Ps средства сбора сведений о ходе вычислений продолжают действовать.
Механизм подсчета циклов и механизм подсчета команд каждый приближенно определяют длину интервала, которая может изменяться в зависимости от внутренних событий системы и условий исключений. Отсчет начинается с момента перехода средства сбора сведений о ходе вычислений из деактивированного состояния в активное состояние. Режим выборок команд по указанию более стабилен, изменения могут произойти при возникновении любых событий в интервале между завершением команды RINEXT и следующей за ней выборочной командой. Следует заметить, что при возникновении прерывания команда, на которую указывает RINEXT, может перестать считаться выборочной.
Выборочная команда идентифицируется вне зависимости от режима выборок. Если выборочная команда идентифицирована, то по окончании выполнения выборочной команды накопление данных останавливается, после чего начинается формирование отчета. На этой стадии используются различные управляющие параметры формирования отчета. Когда сохранение отчетной группы ставится на ожидание, накопление возобновляется.
В режиме выполнения транзакций сохранение отчетной группы задерживается до окончания выполнения выборочной команды. В этом режиме по завершении выполнения выборочной команды сохранение отчетной группы откладывается до окончания транзакции, после чего ставится на ожидание. Если сохранение отчетной группы откладывается или ставится на ожидание, то оно может быть отменено, если возникнет любое из следующих прерываний: 1) программное прерывание; 2) срочное аппаратное прерывание; 3) прерывание рестарта; 4) прерывание по обращению супервизора.
Любое отложенное прерывание ввода-вывода, внешнее и подавляемое аппаратное прерывание остается отложенным либо до тех пор, пока длится сохранение отчетной группы, либо до тех пор, пока средство сбора сведений о ходе вычислений не определит, что отчетная группа сохранению не подлежит.
В каждом режиме выборок разрешается или не разрешается свой отличный набор значений управляющих параметров отчетной группы. Если действует режим подсчета команд или режим подсчета циклов и при этом используются выборки по указанию, то возможна ситуация, когда несколько режимов определения выборочной команды указывают на одну и ту же команду. Если такое событие происходит и используемые значения управляющих параметров отчетных групп для различных режимов различаются, то используются значения, соответствующие режиму выборок по указанию.
Точное определение интервала означало бы выбор конкретных команд, что на практике неосуществимо из-за асинхронности и несогласованности происходящих системных событий. Вместо этого для более точного указания выборочной команды может использоваться команда RINEXT.
В режиме подсчета команд и в режиме подсчета циклов команда RINEXT может располагаться непосредственно перед той выборочной командой, на которую укажут механизмы подсчета команд и подсчета циклов. Содержимое соответствующей отчетной группы будет таково, как будто выборочная команда была определена командой RINEXT, а не механизмами подсчета циклов или подсчета команд.
При выполнении команды RINEXT фактические действия могут не выполняться, если выполняется одно или более следующих условий исключений:
1. Значения параметров средства сбора сведений о ходе вычислений некорректны.
2. В режиме задач значение параметра 612 Ps из состава управляющих параметров средства сбора сведений о ходе вычислений равняется нулю, что указывает на запрет формирования отчета в режиме задач.
3. В режиме супервизора значение параметров 614 Qs из состава управляющих параметров средства сбора сведений о ходе вычислений равняется нулю, что указывает на запрет формирования отчета в режиме супервизора.
4. Значение разряда 710 N из состава управляющих параметров средства сбора сведений о ходе вычислений равняется нулю, что указывает на запрет выполнения команды RINEXT.
5. Сохранение запрещено.
6. Соответствующее поле в действующем ССП указывает, что средство сбора сведений о ходе вычислений деактивировано.
7. Зависящий от типа модели порог превышен. Число выданных за промежуток времени команд RINEXT превысило порог, установленный моделью.
8. Программный буфер переполнен.
9. Активно условие остановочного прерывания сбора сведений о ходе вычислений.
10. Следующая по порядку команда является командой начала интерпретативного выполнения.
11. Следующая по порядку команда является командой обращения к супервизору.
На фиг. 8 в общем виде показана схема накопительного буфера 508 согласно варианту осуществления изобретения. В соответствии с ранее изложенным, если во время выполнения программы средство сбора сведений о ходе вычислений активировано, то внутри процессора ведется сбор данных о ходе вычислений. Согласно варианту осуществления изобретенияузлами внутри процессора 106, в которых ведется сбор данных, являются накопительный буфер 508 и, опционально, буфер данных команд. Согласно варианту осуществления изобретения накопительный буфер 508 является внутренним буфером процессора 106 и используется для хранения наиболее свежих собранных данных. При возникновении события, инициирующего выборку, записи из накопительного буфера 508 копируются в программный буфер 522 как часть отчетной группы, которая записывается в программный буфер 522. Согласно варианту осуществления изобретения записи копируются из накопительного буфера без потери данных.
Накопительный буфер 508 можно считать "аппаратным накопительным буфером", поскольку накопительный буфер 508 находится в процессоре и в варианте осуществления выполнен в виде массива пар регистров, представляющих для данного события адрес 802 команды и метаданные 804 события. Согласно варианту осуществления изобретения буфер данных команд также выполнен в виде пар регистров. Примером события является переход по ветвлению, для такого события пара регистров может сохранить адрес команды ветвления, а метаданные могут содержать точку назначения, а также информацию о предыстории ветвления. Согласно варианту осуществления изобретения пары регистров назначаются и обновляются последовательно по мере возникновения событий в ходе выполнения потока команд. Для указания индекса последней обновленной записи в массиве используется счетчик. Согласно варианту осуществления изобретения накопительный буфер 508 является кольцевым буфером: в случае полного заполнения накопительного буфера сведения об очередном событии записываются поверх первой записи в массиве, и по мере возникновения новых событий последовательное обновление содержимого пар регистров массива продолжается. Например, пусть имеется массив СВ, его элементы - от СВ[0] до CB[N-1], а также имеется счетчик I, указывающий индекс самого последнего обновленного элемента. Последовательность регистрируемых событий будет представлена последовательностью CB[i], CB[i-1], …, СВ[1], СВ[0], CB[N-1], CB[N-2], …, CB[i+1]. Согласно другому варианту осуществления используются два указателя: указатель начала, указывающий на наиболее давнюю запись в буфере, и текущий (хвостовой) указатель, указывающий на наиболее свежую запись в буфере.
События, представляющие состояние процессора 106 в любой заданной точке вычислительного процесса, регистрируются последовательно в накопительном буфере 508. Накопительный буфер 508 используется для регистрации набора записей, содержимое которых является отчетом о событиях, идентифицированных процессором 106 в ходе выполнения программы (например, один или более переходов по ветвлению, события останова выполнения транзакции, операнд команды RIEMIT и т.д.). Согласно варианту осуществления изобретения идентифицируемые события зависят от блока параметров RICCB (см. фиг. 7). Согласно варианту осуществления изобретения, записи в накопительном буфере 508, схема которого показана на фиг. 8, содержат адрес 802 команды, вызвавшей событие, и другие соответствующие метаданные 804. Примеры метаданных 804 события включают (но не ограничиваются перечисленным): адрес команды ветвления и адрес точки назначения, в том числе некоторую информацию о предыстории ветвления; адрес команды RIEMIT и соответствующее значение регистра; адрес команды останова транзакции и соответствующую точку входа возобновления транзакции.
Вариант осуществления накопительного буера 508, схема которого показана на фиг. 8, позволяет хранить до 32 записей (т.е. информацию о 32 событиях), каждая из которых содержит адрес 802 команды, определяемый 64-разрядным числом (например, разрядами с нулевого по 63-й), а также метаданные 804 события, определяемые 64 разрядами (например, разрядами с 64-го по 127-й). Размер RCB накопительного буфера зависит от типа модели и представляет число записей. Согласно варианту осуществления изобретения накопительного буфера 508, схема которого показана на фиг. 8, размер накопительного буфера в байтах кратен длине записи в байтах, т.е. кратен шестнадцати байтам. Согласно варианту осуществления изобретения длина накопительного буфера - это число записей, большее или равное разности между числом записей RRG в наибольшей отчетной группе в данной модели и числом RNC записей в отчетной группе, которые не были извлечены из накопительного буфера. Иными словами, согласно варианту осуществления изобретения размер накопительного буфера определяется условием
RCB≥RRG-RNC.
Согласно варианту осуществления изобретения содержимое накопительного буфера 508 и буфера данных команд (если такой буфер используется) очищается или иным образом изменяется при возникновении следующих событий: (1) прерывание; (2) значение разряда ССП (например, разряда с номером 24), активирующего и деактивирующего средство сбора сведений о ходе вычислений, изменяется с единицы на ноль; (3) при идентификации выборочной команды в случае, когда средство сбора сведений о ходе вычислений находится в режиме выполнения транзакции (в этом случае дальнейшее обновление накопительного буфера 508 данных и буфера данных-команд останавливается и возобновляется, когда транзакция заканчивается, в это время сохранение отчетной группы откладывается и содержимое накопительного буфера 508 и буфера данных команд очищается).
В варианте осуществления, таком как эмулируемая хост-компьютерная система, схема которой показана на фиг. 1Б, хост-компьютер обеспечивает совместный доступ к средству сбора сведений о ходе вычислений и сохраняет и восстанавливает состояние средства сбора сведений о ходе вычислений для каждого отдельного пользователя. Сохраненное состояние средства сбора сведений о ходе вычислений хранится с использованием регистров и/или запоминающего устройства, принадлежащего хост-системе.
В вариантах осуществления могут присутствовать дополнительные возможности, оказывающие влияние на сбор данных, действие которых проявляется в создании дополнительных точек сбора данных при несущественном изменении регулярного порядка следования выборок, обеспечиваемого механизмами подсчета числа команд и подсчета числа циклов, описанными ранее. К указанным дополнительным возможностям относится выполнение команды RIEMIT, которая осуществляет выборку значения регистра общего назначения путем его сохранения в накопительном буфере 508. Кроме того, могут использоваться управляющие разряды сбора данных в составе средства сбора сведений о ходе вычислений, описанные ранее, в целях более детального указания типов регистрируемых данных (например, управляющие разряды Е, С, R и В). Благодаря этому тип собираемых данных является программируемым.
В вариантах осуществления для сбора зависящих от типа модели данных выборочных команд применяется буфер данных команд. Собранные данные используются для формирования записи типа команда средства сбора сведений о ходе вычислений. Буфер данных команд собирает данные от команды в опережение момента, когда команда будет идентифицирована как выборочная команда. Согласно варианту осуществления изобретения буфер данных команд является аппаратным буферным запоминающим устройством (узлом) в составе процессора. В этом процессоре выполнение команды, о которой собирается информация, является инициирующим моментом, точкой выборки, после которой информация сохраняется. В результате в процессе выгрузки указанная информация может быть записана наряду с данными из накопительного буфера 508. Аналогично информации из накопительного буфера 508, указанная информация содержит адрес команды и метаданные, связанные с командой. В буфере данных команд метаданные часто зависят от вычислительной машины и могут содержать следующие сведения (но не ограничиваясь): информацию, связанную с промахами кэш-памяти; информацию, связанную с предсказанием ветвлений.
Согласно варианту осуществления изобретения могут регистрироваться другие данные, поступающие не из накопительного буфера 508 и не из буфера данных команд, например, могут использоваться данные, состоящие из следующих частей: часть 1 - первая запись отчетной группы: запись типа отметка времени или запись типа начало; часть 2 - записи прочих типов, такие записи могут создаваться для каждой отчетной группы, в связи с чем такие записи не хранятся в накопительном буфере 508, и если они присутствуют, то могут размещаться в дополнительной или машинно-зависимой части отчетной группы. В настоящей заявке для обозначения указанных записей, сформированных системой, используется термин "записи системной информации".
На фиг. 9 показана высокоуровневая схема примера отчетной группы 900, хранящейся в программном буфере 522 на момент выборки. Число RVCB содержательных записей из накопительного буфера 508 находится в интервале
0≤RVCB≤RCB,
где RCB - размер накопительного буфера 508. Размер RRG отчетной группы 900, выраженный в числе записей, составляет 2RGS+1, где RGS в показателе степени - размер отчетной группы. Записи, зависящие от типа модели, такие как запись типа команда, извлекаемые из иной области хранения, чем накопительный буфер 508, при их использовании в отчетной группе 900 разрешается или же не разрешается копировать с частичной потерей информации. Число таких записей обозначается как RNC. Согласно варианту осуществления изобретения, если RVCB меньше RRG-RNC, то оставшаяся часть отчетной группы 900 заполняется записями типа заполнитель, благодаря чему в отчетной группе достигается необходимое число RRG записей. Согласно примеру на фиг. 9 RRG=8, RGS=2, RNC=4. Согласно варианту осуществления изобретения число RRG записей лежит в интервале
2≤RRG≤28.
Согласно варианту осуществления изобретения верхний предел RGS ограничен моделью, т.е. составляет менее семи, в результате наибольший размер отчетной группы в модели должен составлять менее 256, однако должен равняться степени двойки.
На фиг. 9 показана схема примера отчетной группы 900. Отчетная группа 900 содержит область 902 заголовка, область 904 тела, область 906 дополнительных записей и область 908 окончания. Область 902 заголовка может содержать запись типа начало или запись типа отметка времени для хранения информации о статусе, трекинге и/или времени. Область 904 тела может содержать набор записей о событиях и информацию, полученную из накопительного буфера 508. Указанные записи о событиях и информация могут представлять, например, информацию о состоянии, собранную с помощью команд типов исходящий, останов режима выполнения транзакции, вызов, возврат, ветвление, заполнитель. Область 906 дополнительных записей может содержать записи, зависящие от типа модели. Область 908 окончания может содержать записи типа команда, содержащие информацию о выполнении выборочной команды.
Согласно варианту осуществления изобретения первая запись отчетной группы 900 находится в области 902 заголовка и является записью типа начало или записью типа отметка времени для хранения информации о статусе, трекинге и/или времени. Запись типа начало хранится для первой отчетной группы 900, хранящейся в программном буфере 522 (т.е. в случае, когда значение 706 RCA равняется значению 702 ROA). Запись типа отметка времени хранится для каждой последующей отчетной группы. Ни запись типа начало, ни запись типа отметка времени не извлекаются из накопительного буфера 508 и, в связи с этим, они учитываются в RNC. Если значения RRG и RNC равны, то область тела пуста и в отчетной группе не хранится ни одной записи из накопительного буфера 508. Если значение RRG больше значения RNC, и RNC равно двум, то содержимое записей отчетной группы с первой по (RRG-RNC) находится в области тела отчетной группы 900 и было получено из накопительного буфера 508.
Согласно варианту осуществления изобретения записи накопительного буфера, хранящиеся в области тела отчетной группы 900, расположены в порядке от наиболее давней к наиболее свежей, причем номер наиболее свежей хранящейся записи равняется RRG-RNC, если накопительный буфер 508 имеет достаточное число содержательных записей. Если в составе отчетной группы 900 хранится набор записей из накопительного буфера 508, то первой записью является наиболее старая запись накопительного буфера, хотя накопительный буфер 508 может содержать записи еще более старые, которые не поместились в область тела, поскольку должны выдаваться наиболее свежие записи накопительного буфера 508. Если число содержательных записей в накопительном буфере 508 недостаточно для заполнения отчетной группы 900, то для заполнения отчетной группы используются одна или более записей типа заполнитель, которые помещаются непосредственно после наиболее свежей записи накопительного буфера. Иными словами, при необходимости записи типа заполнитель помещаются в конце области 904 тела.
Если RRG больше RNC и RNC больше двух, то записи с (RRG-RNC+1) до (RRG-2) располагаются в области 906 дополнительных записей отчетной группы 900 и содержат одну или более записей, тип которых зависит от типа модели, или записей типа дополнительный. Если RNC равняется двум, то область 906 дополнительных записей пуста, записей типа дополнительный не хранится. Записи типа дополнительный или записи, тип которых зависит от типа модели, занимают в области 906 дополнительных записей требуемое им пространство, а все остающееся пространство становится частью области 904 тела.
Согласно варианту осуществления изобретения запись RRG-1 отчетной группы 900 находится в области 908 окончания и является записью типа команда, представляющей выборочную команду. Запись типа команда не извлекается из накопительного буфера 508, она частично состоит из данных, извлекаемых из буфера данных команд.
Согласно варианту осуществления изобретения отчетная группа 900 хранится в программном буфере 522 в целостном пространстве памяти, размер которого кратен байту.
Если совершается попытка сохранения отчетной группы 900, то сохраняются либо все записи группы, либо меньшее число записей. Приращение значения поля 706 RCA происходит только в том случае, если сохранены все записи отчетной группы 900. Согласно варианту осуществления изобретения, если отчетная группа 900 сохраняется, то записи в отчетной группе 900 не сохраняются в каком-либо определенном порядке. Однако после того, как все записи отчетной группы 900 сохранены, обновляется запись типа начало.
Согласно варианту осуществления изобретения при сохранении отчетной группы 900 применяются механизмы защиты нижнего адреса, защиты динамической трансляции адресов и/или защиты, управляемой ключом. Для механизма защиты, управляемого ключом, ключ как правило поставляется из блока параметров (например, из поля 626 ключа), а не из текущего ССП. Используемое адресное пространство является либо домашним, либо первичным, что определяется блоком параметров (например, значением разряда 608 Н). Если возникает исключение (ошибка) при доступе к области памяти отчетной группы и/или области памяти записи типа начало, то сохранение не выполняется и содержимое отчетной группы не сохраняется.
Согласно варианту осуществления изобретения значение поля 706 RCA увеличивается на 16 после каждого сохранения отчетной группы. Фактическое обновление происходит один раз для каждой отчетной группы 900, в результате увеличение происходит на общий размер отчетной группы 900. Для обозначения такого увеличения значения поля 706 RCA в настоящей заявке используется термин "приращение текущего адреса". Таким образом, успешное сохранение отчетной группы 900 связано с приращением значения поля 706 RCA и приращением на единицу значения поля NRG (от англ. Number of Reporting Groups - число отчетных групп) в составе записи типа начало, содержащего число отчетных групп. Приращения значения поля 706 RCA не происходит, если возникает условие остановочного прерывания средства сбора сведений о состоянии вычислительной системы. Если значение поля 706 RCA равно значению поля 704 RLA, увеличенному на единицу, т.е. если RCA=1+RLA, то возникает условие заполнения программного буфера. Согласно варианту осуществления изобретения при возникновении условия заполнения программного буфера отчетная группа 900 не сохраняется. К возникновению условия заполнения программного буфера приводит приращение значения поля 706 RCA. Если происходит приращение значения поля 706 RCA и условие заполнения программного буфера не возникает, а значение адреса после приращения указывает за границу страницы, то может возникнуть исключение (ошибка) доступа. Такое исключение (ошибка) обозначается как побочный эффект доступа при сохранении. Для обозначения внешнего прерывания, вызванного срабатыванием механизма контроля из-за возникновения условия заполнения программного буфера, в настоящей заявке используется термин "прерывание из-за заполнения буфера".
Если возникает условие заполнения программного буфера, то согласно варианту осуществления изобретения могут выполняться следующие действия в указанном далее порядке:
1. Значение разряда S в поле, входящем в состав записи типа начало, устанавливается равным единице, что указывает на возникновение условия заполнения программного буфера.
2. Прерывание из-за заполнения буфера ставится на ожидание путем установки значения разряда в составе блока параметров (например, разряда 624 L) равным единице. Прерывание из-за заполнения буфера остается в режиме ожидания до того, пока значение разряда L не обнулится. Значение разряда L может обнулиться в результате любого из следующих событий: успешное выполнение команды LRIC, которая устанавливает значение разряда L равным нулю; предъявление прерывания из-за заполнения буфера; рестарт ЦПУ; успешное выполнение команды MRIC, которая неявно устанавливает значение разряда L равным нулю, если условие заполнения программного буфера не активно.
Согласно варианту осуществления изобретения, если активно условие заполнения программного буфера, то это приводит к следующим последствиям: при выполнении команды RINEXT действия не выполняются; при выполнении команды RIEMIT действия не выполняются; в зависимости от типа модели может быть сокращен интервал выборок, причем если это происходит, то также в зависимости от типа модели повторная инициализация интервала при уменьшении его до нуля выполняется до значения коэффициента масштабирования из состава блока параметров (например, до значения, определяемого полем 740 SF), поскольку если указанный интервал выборок сокращается до нуля, то выборочная команда не идентифицируется; прочие команды средства сбора сведений о ходе вычислений не затрагиваются.
Согласно варианту осуществления изобретения условие остановочного прерывания средства сбора сведений о ходе вычислений в первый раз возникает, когда код версии в записи типа отметка времени в отчетной группе 900, подлежащей сохранению, отличается от кода версии в записи типа начало отчетной группы 900, и продолжается до тех пор, пока средство сбора сведений о ходе вычислений не продолжит работу после изменения управляющих параметров (например, блока параметров), благодаря чему будет устранено возможное отличие. Указанное возникшее условие остановочного прерывания средства сбора сведений о ходе вычислений первоначально распознается в момент появления записи типа начало. Для обозначения внешнего прерывания, вызванного срабатыванием механизма контроля из-за возникновения условия остановочного прерывания средства сбора сведений о ходе вычислений, в настоящей заявке используется термин "остановочное прерывание средства сбора сведений о ходе вычислений".
Если возникает условие остановочного прерывания, то выполняются следующие действия в указанном далее порядке:
1. Значение поля Н остановки, входящего в состав записи типа начало, устанавливается равным единице.
2. Остановочное прерывание средства сбора сведений о ходе вычислений ставится на ожидание путем установки значения разряда G (например, разряда 620 G) в составе блока параметров равным единице. Остановочное прерывание средства сбора сведений о ходе вычислений остается в режиме ожидания до того, оно не будет сброшено. Согласно варианту осуществления изобретения указанное прерывание сбрасывается в результате любого из следующих событий: успешное выполнение команды LRIC, которая устанавливает значение разряда G равным нулю; предъявление остановочного прерывания средства сбора сведений о ходе вычислений; рестарт ЦПУ; успешное выполнение команды MRIC, которая неявно устанавливает значение разряда G равным нулю, если загружается значение поля 706 RCA, равное значению поля 702 ROA (это также служит отменой условия остановочного прерывания средства сбора сведений о ходе вычислений).
Пока активно условие остановочного прерывания средства сбора сведений о ходе вычислений, то наступают следующие последствия: 1) при выполнении команды RINEXT действия не выполняются; 2) при выполнении команды RIEMIT действия не выполняются; 3) в зависимости от типа модели может быть сокращен интервал выборок (например, значение поля 742 RSIC), причем если это происходит, то также в зависимости от типа модели в случае уменьшении до нуля интервал повторно инициализируется значением SF (например, значением поля SF), поскольку если указанный интервал сокращается до нуля, то выборочная команда не идентифицируется; 4) дополнительные отчетные группы 900 не сохраняются; 5) приращение значения поля 706 RCA не происходит; 6) прочие команды средства сбора сведений о ходе вычислений не затрагиваются. Если значение разряда G загружается равным единице в результате выполнения команд LRIC или MRIC, то остановочное прерывание средства сбора сведений о ходе вычислений откладывается. Значение разряда G неявно устанавливается равным нулю, если команда MRIC определяет, что значение поля 702 ROA равняется значению поля 706 RCA. Если значение разряда 622 U в составе управляющих параметров средства сбора сведений о ходе вычислений равняется нулю, то запрос на остановочное прерывание средства сбора сведений о ходе вычислений отключен.
На фиг. 10 в общем виде показана схема варианта осуществления записи 1000 типа начало. Согласно варианту осуществления изобретения запись 1000 типа начало хранится в области 902 заголовка для первой отчетной группы 900, хранящейся в программном буфере 522 (т.е. для которой значение поля 706 RCA равняется значению поля 702 ROA). Запись 1000 типа начало обновляется после того, как в программном буфере 522 сохраняется первая отчетная группа 900. Запись 1000 типа начало, схема которой показана на фиг. 10, содержит поле 1002 типа записи, поле 1004 NRG числа отчетных групп, поле 1014 версии, поле 1006 RGS длины отчетной группы, поле 1008 S остановки, поле 1016 Т производительности, поле 1010 Н остановки, поле 1012 часов времени суток. Запись 1000 типа начало инициализируется значениями управляющих параметров средства сбора сведений о ходе вычислений (например, значениями параметров блока параметров RICCB или другого управляющего блока). Значение поля 1002 типа записи устанавливается равным "02", что указывает на то, что данная запись является записью 1000 типа начало. Значение поля 1004 NRG числа отчетных групп устанавливается равным единице, что означает, что в программном буфере 522 хранится одна отчетная группа 900. Поле 1004 NRG обновляется каждый раз при сохранении в программном буфере новой отчетной группы. Поле 1014 версии хранит целое число, значение которого обозначает функциональный уровень поколения разработки (например, инструментального модуля 506). При инициализации записи 1000 типа начало значение поля 1006 RGS обновляется путем записи текущего значения RGS (например, из блока параметров RICCB) для отображения размера всех отчетных групп 900 в программном буфере 522. Значение поля 1008 S остановки устанавливается равным нулю, что сигнализирует о том, что программный буфер 522 незаполнен. Если программный буфер 522 заполнен, то значение поля 1008 S изменяется на единицу, что сигнализирует о том, что возникло условие заполнения программного буфера. Значение поля 1016 Т устанавливается равным нулю при инициализации, когда отчетная группа 900 содержит выборку, характеризующую первичное по производительности ЦПУ, и устанавливается равным единице, если отчетная группа 900 содержит выборку, характеризующую вторичное по производительности ЦПУ. Значение поля 1010 Н устанавливается равным нулю при инициализации и впоследствии устанавливается равным единице, если работа средства сбора сведений о ходе вычислений останавливается по причинам, не связанным с условием заполнения буфера. Если значение поля 1010 Н равняется единице, то значение разряда 620 G в блоке параметров RICCB также устанавливается равным единице. Значение поля 1012 часов времени суток устанавливается таким образом, чтобы отображать время суток, соответствующее моменту начального сохранения отчетной группы, содержащей запись 1000 типа начало. Значения зарезервированных частей записи 1000 типа начало (как и значения любых других зарезервированных частей записей других типов отчетных групп) непредсказуемы.
На фиг. 11 показана схема варианта осуществления записи 11UU типа отметка времени в области заголовка 902 отчетной группы 900. Запись 1100 типа отметка времени хранится как запись ноль (т.е. первой по порядку) каждой отчетной группы 900 за исключением первой отчетной группы 900 программного буфера 522. Запись 1100 типа отметка времени формируется, когда в программном буфере 522 хранится отчетная группа 900 и значение поля 702 ROA отличается от значения поля 70 RCA. Вариант осуществления записи 1100 типа отметка времени, схема которого показанная на фиг. 11, содержит поле 1102 типа записи, поле 1106 версии, поле 1108 Т производительности, поле 1104 часов времени суток. Значение поля 1102 типа записи устанавливается равным "03", что указывает на то, что данная запись является записью 1100 типа отметка времени. Поле 1106 версии хранит целое число, значение которого обозначает функциональный уровень поколения разработки (например, инструментального модуля 506). Значение поля 1108 Т устанавливается равным нулю при инициализации, когда отчетная группа 900 содержит выборку, характеризующую первичное по производительности ЦПУ, и устанавливается равным единице, если отчетная группа 900 содержит выборку, характеризующую вторичное по производительности ЦПУ. Значение поля 1104 часов времени суток устанавливается таким образом, чтобы отображать время суток, соответствующее моменту начального сохранения отчетной группы 900, содержащей запись 1100 типа отметка времени.
Область 904 тела отчетной группы 900 может содержать набор записей о событиях и информацию, переписанную выборками из накопительного буфера 508. Записи о событиях и информация могут представлять, например, информацию о состоянии, полученную командами типа извлечение, останов режима выполнения транзакции, вызов, возврат, ветвление, заполнитель.
Запись типа извлечение формируется и хранится в области 904 тела отчетной группы 900 в программном буфере 522 в результате успешного выполнения команды RIEMIT. На фиг. 12 показаны схемы трех вариантов 1202, 1204 и 1206 осуществления записей типа извлечение в отчетной группе, которые различаются в зависимости от того, какой применяется режим адресации, 64-, 31- или 24-разрядный. Все записи 1202, 1204 и 1206 типа извлечение содержат поле 1208 типа записи, поле 1210 "С" кода адреса команды, поле 1212 адреса команды, поле 1214 извлеченных данных. Значение поля 1208 типа записи устанавливается равным "10", что указывает на то, что данная запись является записью 1202, 1204 или 1206 типа извлечение. Согласно варианту осуществления изобретения поле 1210 "С" кода адреса команды хранит беззнаковое целое число, значение которого является кодом, который описывает, как в записях 1202, 1204 и 1206 типа извлечение представлены позиции разрядов адреса команды текущего ССП. Если значение поля 1210 "С" равняется нулю, то позиции 22-62 разрядов адреса команды текущего ССП соответствуют позициям 22-62 разрядов записи и позиции 0-21 разрядов адреса команды заполнены нулями. Если значение поля 1210 "С" равняется единице, то позиции 22-62 разрядов адреса команды текущего ССП соответствуют позициям 22-62 разрядов записи и позиции 0-21 разрядов адреса команды содержат, по меньшей мере, одну единицу. Если значение поля 1210 "С" равняется единице и запись хранится как часть отчетной группы 900, то значение разряда превышения максимального значения адреса (например, разряда 712 МАЕ) в составе блока параметров средства сбора сведений о ходе вычислений устанавливается равным единице. Поле 1212 адреса команды содержит адрес команды RIEMIT или адрес команды исполнимого типа, если команда RIEMIT являлась точкой назначения команды исполнимого типа. В соответствии со схемой на фиг. 12, поле 1212 адреса команды изменяется в зависимости от режима адресации (например, 64, 31 или 24 разряда). Поле 1214 извлеченных данных содержит данные из регистра общего назначения, определенного командой RIEMIT.
Запись типа останов режима выполнения транзакции (запись типа останов) формируется либо неявным остановом, либо остановом выполнения транзакции и хранится в области 904 тела отчетной группы 900 в программном буфере 522. На фиг. 13 показаны схемы трех различных вариантов 1302, 1304 и 1306 осуществления записи типа останов, которые различаются в зависимости от того, какой применяется режим адресации, 64-, 31- или 24-разрядный. Все записи 1302, 1304 и 1306 типа останов содержат поле 1308 типа записи, поле 1310 "С" кода адреса команды, поле 1312 адреса команды, поле 1314, зависящее от типа модели. Значение поля 1308 типа записи устанавливается равным "11", что указывает на то, что данная запись является записью 1302, 1304 или 1306 типа останов. Согласно варианту осуществления изобретения поле 1310 "С" кода адреса команды хранит беззнаковое целое число, значение которого является кодом, который описывает, как в записях 1302, 1304 и 1306 типа останов представлены позиции разрядов адреса команды текущего ССП. Свойства указанного поля аналогичны свойствам поля 1210 "С", описанного ранее применительно к фиг. 12. Поле 1312 адреса команды содержит адрес остановленной команды или адрес команды исполнимого типа, если остановленная команда являлась точкой назначения команды исполнимого типа. В соответствии со схемой на фиг. 13, поле 1312 адреса команды изменяется в зависимости от режима адресации (например, 64, 31 или 24 разряда). Поле 1314 зависящих от типа модели данных содержит любые зависящие от типа модели данные, связанные с остановом.
Запись типа вызов создается при выполнении команды ветвления, которая характеризуется как команда ветвления типа вызов. Запись типа вызов хранится в области 904 тела отчетной группы 900 в программном буфере 522. Согласно варианту осуществления изобретения к командам ветвления типа вызов относятся: BRANCH AND SAVE (от англ.: ветвление и сохранение, аббревиатура BASR), если значение поля R2 не равно нулю; BRANCH AND SAVE (аббревиатура BAS); BRANCH RELATIVE AND SAVE LONG (от англ.: ветвление относительное и сохранение длинное); BRANCH RELATIVE AND SAVE (от англ.: ветвление относительное и сохранение); BRANCH AND LINK (от англ.: ветвление и связь, аббревиатура BALR), если значение поля R2 отлично от нуля; BRANCH AND LINK (аббревиатура BAL); BRANCH AND SAVE AND SET MODE (от англ.: ветвление и сохранение и установка режима), если значение поля R2 отлично от нуля. На фиг. 14 показаны схемы трех различных вариантов 1402, 1404 и 1406 осуществления записей типа вызов в отчетной группе, которые различаются в зависимости от того, какой применяется режим адресации, 64-, 31- или 24-разрядный. Все записи типа вызов 1402, 1404 и 1406 содержат поле 1408 типа записи, поле 1410 "С" кода адреса команды, поле 1412 адреса команды, поле 1416 W нормального выполнения, поле 1414 адреса точки назначения. Значение поля 1408 типа записи устанавливается равным "12", что указывает на то, что данная запись является записью 1402, 1404 или 1406 типа вызов. Согласно варианту осуществления изобретения поле 1410 "С" кода адреса команды хранит беззнаковое целое число, значение которого является кодом, который описывает, как в записях 1402, 1404 и 1406 типа вызов представлены позиции разрядов адреса команды текущего ССП. Свойства указанного поля аналогичны свойствам поля 1210 "С", описанного ранее применительно к фиг. 12. Поле 1412 адреса команды содержит адрес команды ветвления или адрес команды исполнимого типа, если команда ветвления являлась точкой назначения команды исполнимого типа. Значение поля 1416 W, равное единице, указывает, что ветвление было предсказано верно, а значение, равное нулю, указывает, что ветвление было предсказано неверно. Поле 1414 адреса точки назначения содержит адрес точки назначения ветвления (также используется термин "вызываемое местоположение").
Формат записей типа возврат и типа передача в составе области 904 тела отчетной группы 900 в программном буфере 522 тот же, что и у вариантов 1402 1404 and 1406 записи типа вызов. Согласно варианту осуществления изобретения запись типа возврат снабжена полем типа записи, в котором указано значение "13", эта запись создается в результате выполнения команды ветвления типа возврат, такой как BRANCH ON CONDITION (от англ.: возврат по условию, аббревиатура BCR), если значение поля R2 отлично от нуля и значение маски равно 15; BRANCH ON CONDITION (аббревиатура ВС), если значение разряда J равно единице и значение маски равно 15; BRANCH AND SET MODE (от англ.: ветвление и установка режима), если значение поля R2 отлично от нуля. Для записи типа возврат поле адреса команды содержит адрес команды ветвления или адрес команды исполнимого типа, если команда ветвления является точкой назначения команды исполнимого типа. Для записи типа возврат поле адреса точки назначения содержит местоположение точки возврата.
Согласно варианту осуществления изобретения запись типа передача содержит поле типа записи, в котором указано значение "14", эта запись формируется при выполнении команды ветвления типа возврат, такой как: (а) BRANCH ON CONDITION (BCR), если значение поля R2 отлично от нуля и значение маски лежит в интервале от 1 до 14; (б) BRANCH ON CONDITION (ВС), если значение разряда J равно нулю и значение маски лежит в интервале от 1 до 14; (в) BRANCH ON COUNT (ВСТ, BCTR. BCTG, BCTGR); (г) BRANCH ON INDEX HIGH (BXH, BXHG); (д) BRANCH ON INDEX LOW OR EQUAL (BXLE, BXLEG); (e) BRANCH RELATIVE ON CONDITION (BRC); (ж) BRANCH RELATIVE ON CONDITION LONG (BRCL); (з) BRANCH RELATIVE ON COUNT (BRCT, BRCTG); (и) BRANCH RELATIVE ON COUNT HIGH (BRCTH); (к) BRANCH RELATIVE ON INDEX HIGH(BRXH, BRXHG); (л) BRANCH RELATIVE ON INDEX LOW OREQUAL (BRXLE, BRXLG); (м) COMPARE AND BRANCH (CRB, CGRB); (н) COMPARE AND BRANCH RELATIVE (CRJ, CGRJ); (o) COMPARE IMMEDIATE AND BRANCH (CIB, CGIB); (п) COMPARE IMMEDIATE AND BRANCH RELATIVE (CIJ, CGIJ); (p) COMPARE LOGICAL AND BRANCH (CLRB, CLGRB); (c) COMPARE LOGICAL AND BRANCH RELATIVE (CLRJ, CLGRJ); (т) COMPARE LOGICAL IMMEDIATE AND BRANCH (CLIB, CLGIB); (у) COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (CLIJ, CLGIJ). Запись типа передача создается, если происходит ветвление. Для записи типа передача поле адреса команды содержит адрес команды ветвления или адрес команды исполнимого типа, если команда ветвления является точкой назначения команды исполнимого типа. Для записи типа передача поле адреса точки назначения содержит местоположение точки возврата.
Запись типа заполнитель используется в области 904 тела отчетной группы 900, если число содержательных записей в накопительном буфере 508 недостаточно для заполнения отчетной группы 900 при текущем значении параметра RGS. На фиг. 15 показана схема варианта осуществления записи 1500 типа заполнитель. Вариант осуществления, схема которого показана на фиг. 15, содержит поле 1502 типа записи, в котором указано значение "00", что указывает на то, что данная запись является записью 1500 типа заполнитель. Значение прочих байтов записи не специфицировано.
Если в составе отчетной группы 900 содержится область 906 дополнительных записей, то в этой области могут содержаться записи, зависящие от типа модели. Согласно варианту осуществления изобретения формат записи типа дополнительный аналогичен формату записи 1500 типа заполнитель за исключением того, что значение кода типа записи устанавливается равным "01", что указывает на то, что данная запись является записью типа дополнительный, а прочие байты записи типа дополнительный содержат данные, зависящие от типа модели.
Согласно варианту осуществления изобретения область 908 окончания отчетной группы 900 содержит запись типа команда, содержащую информацию о выполнении выборочной команды. Запись типа команда создается, если отчетная группа 900 сохраняется для выборочной команды. На фиг. 16 показаны схемы вариантов 1602, 1604 и 1606 осуществления записей типа команда в отчетной группе, которые различаются в зависимости от того, какой применяется режим адресации, 64-, 31- или 24-разрядный. Все записи 1602, 1604 и 1606 типа команда содержат поле 1608 типа записи, поле 1610 "С" кода адреса команды, поле 1612 адреса команды и поле 1614 буфера данных команд. Значение поля 1608 типа записи устанавливается равным "04", что указывает на то, что данная запись является записью 1602, 1604 или 1606 типа команда. Согласно варианту осуществления изобретения поле 1610 "С" кода адреса команды хранит беззнаковое целое число, значение которого является кодом, который описывает, как в записях 1602, 1604 и 1606 типа команда представлены позиции разрядов адреса команды текущего ССП. Свойства указанного поля аналогичны свойствам поля 1210 "С", описанного ранее применительно к фиг. 12.
Поле 1612 адреса команды содержит адрес выборочной команды или адрес команды исполнимого типа, если выборочная команда являлась точкой назначения команды исполнимого типа. В соответствии со схемой на фиг. 16, поле 1612 адреса команды изменяется в зависимости от режима адресации (например, 64, 31 или 24 разряда). Поле 1614 содержит данные, полученные из буфера данных команд, состав данных зависит от типа модели.
На фиг. 17 показана схема алгоритма сбора сведений о ходе вычислений согласно варианту осуществления изобретения. Согласно варианту осуществления изобретения алгоритм (фиг. 17) выполняется инструментальным модулем 506. На шаге 1702 процессором, таким как процессор 106 или эмулируемый процессор 29, выполняется поток команд. На шаге 1704 собирается информация для средства сбора сведений о ходе вычислений, относящаяся к выполняемому потоку команд, на шаге 1706 формируются записи средства сбора сведений о ходе вычислений (такие как показаны в накопительном буфере 508) на основе собранной информации для средства сбора сведений о ходе вычислений. На шаге 1708 в потоке выполняемых команд выявляется точка выборки средства сбора сведений о ходе вычислений. На шаге 1710 в программном буфере средства сбора сведений о ходе вычислений, таком как программный буфер 522, сохраняется отчетная группа, такая как отчетная группа 900. Сохранение включает определение текущего адреса программного буфера средства сбора сведений о ходе вычислений на основе значений управляющих параметров средства сбора сведений о ходе вычислений. Согласно варианту осуществления изобретения текущим адресом является значение поля 706 RCA, хранящееся в блоке 700 параметров RICCB. При сохранении используются начальный адрес (например, поле 702 ROA) и указанный текущий адрес программного буфера средства сбора сведений о ходе вычислений.
В соответствии с вышеизложенным варианты изобретения могут быть осуществлены в форме компьютерных процедур и аппаратных средств реализации этих процедур. Вариант осуществления может включать компьютерный программный продукт 1800 (см. фиг. 18) в виде изделия, выполненный на машиночитаемой и пригодной для использования компьютером среде 1802 с логикой 1804 компьютерного программного кода, содержащей команды, хранящиеся на материальном носителе. Примеры изделий в виде машиночитаемой и пригодной для использования компьютером среды 1802 могут включать гибкие диски (дискеты), CD-ROM, накопители на жестких дисках, твердотельные флеш-диски, подключаемые по интерфейсу LJSB (от англ. Universal Serial Bus - универсальная последовательная шина) или иную машиночитаемую среду хранения данных, в случае, когда логика 1804 компьютерного программного кода, будучи загруженной и выполняемой компьютером, делает компьютер средством для осуществления данного изобретения. Варианты осуществления содержат логику 1804 компьютерного программного кода, например, хранящуюся в среде хранения информации, загруженную в компьютер и/или выполняемую компьютером, либо переданную по некоторой среде передачи информации, такой как электрические провода или кабели, волоконно-оптические линии связи, электромагнитное излучение, в случае, когда логика 1804 компьютерного программного кода, будучи загруженной и выполняемой компьютером, делает компьютер средством для осуществления данного изобретения. При применении в микропроцессоре общего назначения сегменты логики 1804 компьютерного программного кода конфигурируют данный микропроцессор для формирования специфических логических схем.
Технический эффект и достоинства включают способность извлекать данные о ходе вычислений в условиях лаборатории для оффлайн-анализа (т.е. анализа по завершении вычислительного процесса), а также в условиях действующего вычислительного процесса внутри программ на этапе исполнения и под управлением программы. Отчетная группа хранится в программном буфере, местоположение которого определяется по параметрам, связанным с вычислительной средой этапа выполнения. Таким образом, данные о состоянии вычислительной системы, хранящиеся в виде отчетных групп в программном буфере, доступны программе для постанализа (или даже более агрессивного анализа во время действия вычислительной системы).
Терминология, употребляемая в настоящей заявке, используется исключительно для описания конкретных вариантов осуществления и не должна рассматриваться как ограничение сущности изобретения. Используемые в настоящей заявке термины в единственном числе обозначают также и сущности во множественном числе, если иное явно не следует из контекста. Следует учитывать, что термины "содержит" и/или "содержащий" при их использовании в настоящем описании указывают на наличие заявленных особенностей, целых чисел, шагов, операций, элементов и/или компонентов, однако не исключают наличие или добавление одной или более других особенностей, целых чисел, шагов, операций, элементов, компонентов и/или их групп.
В следующей далее формуле изобретения соответствующие структуры, материалы, действия, заменители, эквиваленты всех средств или шагов и функциональных элементов, если таковые упоминаются, предполагают включение в свой состав любой структуры, материала или действия по выполнению функции в комбинации с другими заявленными элементами, как это конкретно заявлено. Описание настоящего изобретения было дано в целях иллюстрации и раскрытия, описание не предназначено для ограничения настоящего изобретения исключительно изложенными вариантами осуществления. Специалистам в данной области будут очевидны многочисленные модификации и видоизменения в рамках сущности и идеи настоящего изобретения. Выбор и описание вариантов осуществления обусловлен стремлением наилучшим образом объяснить принципы настоящего изобретения и его практическое приложение, а также дать возможность специалистам в данной области понять сущность изобретения в ее различных вариантах осуществления с различными модификациями, пригодными для конкретного применения.
Специалисту в данной области должно быть понятно, что один или несколько аспектов настоящего изобретения могут быть воплощены в форме системы, способа или компьютерного программного продукта. Соответственно, один или несколько аспектов настоящего изобретения могут быть реализованы в виде чисто аппаратного обеспечения, т.е. на аппаратном уровне, чисто программного обеспечения, т.е. на программном уровне (в том числе в виде программы, записанной в ПЗУ, резидентного программного обеспечения, микрокода и т.п.) или в виде комбинации аппаратного и программного обеспечения; для обозначения всех этих вариантов в настоящей заявке могут в общем использоваться термины "схема", "модуль" или "система". Кроме того, один или несколько аспектов настоящего изобретения могут принимать форму компьютерного программного продукта, реализованного в одной или нескольких машиночитаемых средах, в частности на одном или нескольких машиночитаемых носителях информации, содержащих машиночитаемый программный код.
Может использоваться любая комбинация одной или нескольких машиночитаемых сред. Машиночитаемой средой может являться машиночитаемая среда передачи данных или машиночитаемая среда хранения данных. Машиночитаемой средой хранения данных может быть, например (но не ограничиваясь): электронная, магнитная, оптическая, электромагнитная, инфракрасная или полупроводниковая система, средство или устройство или любая работоспособная комбинация перечисленных сред. Более специфическими примерами машиночитаемых сред хранения данных могут быть, в том числе (но не ограничиваясь): электрическое соединение, содержащее один или более проводников; портативная компьютерная дискета (накопитель на гибких дисках); накопитель на жестких дисках; ОЗУ; ПЗУ; стираемое программируемое постоянное запоминающее устройство (СППЗУ) или флеш-память; оптоволокно; CD-ROM; оптическое запоминающее устройство; магнитное запоминающее устройство; любая работоспособная комбинация вышеперечисленных сред. Применительно к настоящей заявке машиночитаемой средой хранения данных может являться любая материальная среда, которая может содержать или хранить программу для использования или коммуникационное соединение с системой, средством или устройством, выполняющим команды.
Машиночитаемая среда передачи данных может включать в себя распространяющийся сигнал с данными, содержащий машиночитаемый программный код, например, в основной полосе частот или как часть несущего колебания. Такой распространяющийся сигнал может принимать любую из множества форм, в том числе (но не ограничиваясь) электромагнитную, оптическую или любую комбинацию перечисленных. Машиночитаемая среда передачи данных может являться машиночитаемой средой, не относящейся к машиночитаемым средам хранения данных, а являться средой, соединяющей, передающей или транспортирующей программу для использования системой, средством или устройством, выполняющим команды, или являться средой, подключенной к системе, средству или устройству, выполняющему команды.
Программный код, содержащийся в машиночитаемой среде, может передаваться с использованием любой подходящей среды, в том числе (но не ограничиваясь) беспроводной, проводной, волоконно-оптической, радиочастотной и т.п. или любой работоспособной комбинацией перечисленных.
Компьютерный программный код для выполнения операций одного или более аспектов настоящего изобретения может быть написан на одном или любой комбинации нескольких языков программирования, в том числе на языках объектно-ориентированного программирования, таких как Java, Smalltalk, C++ или подобных, и на обычных языках процедурного программирования, таких как язык "С" или подобных языках программирования. Программный код может выполняться: полностью на компьютере пользователя; частично на компьютере пользователя как автономный программный пакет; частично на компьютере пользователя и частично на удаленном компьютере; полностью на удаленном компьютере или сервере. В последнем случае удаленный компьютер может быть соединен с компьютером пользователя через коммуникационную сеть любого типа, в том числе через ЛВС или глобальную вычислительную сеть, либо может быть реализовано соединение с внешним компьютером (например, через сеть Интернет при посредничестве поставщика услуг Интернет).
Аспекты настоящего изобретения описываются в настоящей заявке с использованием изображений схем алгоритмов и/или структурных схем способов, средств (систем) и компьютерных программных продуктов согласно вариантам осуществления изобретения. Должно быть понятно, что каждая операция на чертежах схем алгоритмов и/или структурных схем, а также комбинации операций на чертежах схем алгоритмов и/или структурных схем могут быть реализованы командами компьютерной программы. Эти команды компьютерной программы могут выполняться процессором универсального компьютера, специализированного компьютера или иными средствами обработки данных с программным управлением, образующими машину (вычислительное устройство), таким образом, что команды, выполняемые процессором компьютера или иными средствами обработки данных с программным управлением, формируют среду для осуществления функций (действий), описанных схемой алгоритма и/или операцией или операциями структурной схемы.
Указанные команды компьютерной программы могут также храниться в машиночитаемой среде и могут заставлять компьютер, иное средство обработки данных с программным управлением или иные устройства действовать определенным образом, чтобы команды, хранящиеся в машиночитаемой среде, образовывали изделие, в том числе реализующее команды, которые осуществляют функцию или действуют в соответствии со схемой алгоритма, и/или операцию или операции, показанные на структурных схемах.
Команды компьютерной программы могут также быть загружены в компьютер, иное средство обработки данных с программным управлением или иные устройства для выполнения последовательности операций компьютером, иным средством обработки данных с программным управлением или другими устройствами для организации вычислительного процесса, в результате которого команды, выполняемые на компьютере или ином средстве обработки данных с программным управлением, реализуют процессы для осуществления функции или действия в соответствии со схемой алгоритма и/или операцию или операции, показанные на структурных схемах.
В соответствии с вышеизложенным варианты изобретения могут быть осуществлены в виде компьютерных вычислительных процессов и аппаратных средств, реализующих указанные вычислительные процессы. Изобретение в вариантах осуществления реализуется в компьютерном программном коде, выполняемом одним или более элементами вычислительной сети. Варианты осуществления содержат компьютерный программный продукт на машиночитаемой среде с логикой компьютерного программного кода, содержащей команды, осуществленный на материальном носителе информации как изделие. Примеры изделий в виде машиночитаемой и пригодной для использования компьютером среды могут включать гибкие диски (дискеты), CD-ROM, накопители на жестких дисках, твердотельные флеш-диски, подключаемые по интерфейсу USB, или иную машиночитаемую среду хранения данных, если логика компьютерного программного кода, будучи загруженной и выполняемой компьютером, делает компьютер средством для осуществления данного изобретения. Варианты осуществления содержат логику компьютерного программного кода, например, хранящуюся в среде хранения информации, загруженную в компьютер и/или выполняемую компьютером, либо переданную по некоторой среде передачи информации, такой как электрические провода или кабели, волоконно-оптические линии связи, электромагнитное излучение, если логика компьютерного программного кода, будучи загруженной и выполняемой компьютером, делает компьютер средством для осуществления данного изобретения. При применении в микропроцессоре общего назначения сегменты логики компьютерного программного кода конфигурируют данный микропроцессор для формирования специфических логических схем.
Схемы алгоритмов и структурные схемы, показанные на фигурах, иллюстрируют архитектуру, функциональность и действие возможных вариантов осуществления систем, методов и компьютерных программных продуктов согласно различным вариантам осуществления одного или более аспектов настоящего изобретения. С учетом этого каждая операция (блок) на схемах алгоритмов или структурных схемах может представлять модуль, сегмент или фрагмент кода, содержащий одну или более исполнимых команд для осуществления определенной логической функции или функций. Следует также заметить, что в некоторых альтернативных вариантах осуществления функции, указанные в блоках, могут выполняться в иной последовательности, чем показано на прилагаемых чертежах. Например, две операции, показанные следующими одна за другой, могут фактически выполняться по существу одновременно, либо иногда операции могут выполняться в обратном порядке в зависимости от имеющихся функциональных возможностей. Также будет отмечено, что каждая операция на изображениях структурных схем и/или схем алгоритмов и каждая комбинация операций на изображениях структурных схем и/или схем алгоритмов может быть реализована специализированными аппаратными системами, которые выполняют определенные функции или действия, или комбинациями специализированного аппаратного обеспечения и компьютерных команд.
название | год | авторы | номер документа |
---|---|---|---|
УПРАВЛЕНИЕ В РЕЖИМЕ НИЗКИХ ПРИВИЛЕГИЙ РАБОТОЙ СРЕДСТВА СБОРА СВЕДЕНИЙ О ХОДЕ ВЫЧИСЛЕНИЙ | 2013 |
|
RU2585969C2 |
ВЫБОРКА КОМАНД ПО УКАЗАНИЮ В СРЕДСТВЕ СБОРА СВЕДЕНИЙ О ХОДЕ ВЫЧИСЛЕНИЙ | 2013 |
|
RU2585982C2 |
ОБРАБОТКА ТРАНЗАКЦИЙ | 2013 |
|
RU2606878C2 |
КОМАНДА ВЕКТОРНОГО ТИПА КОНТРОЛЬНОЙ СУММЫ | 2013 |
|
RU2608663C1 |
КОМАНДА ВЕКТОРНОГО ТИПА НА ПОЛЕ ГАЛУА ПЕРЕМНОЖЕНИЯ, СУММИРОВАНИЯ И НАКОПЛЕНИЯ | 2014 |
|
RU2613726C2 |
ОПРЕДЕЛЕНИЕ ДЛИНЫ ГРУППЫ СИМВОЛЬНЫХ ДАННЫХ, СОДЕРЖАЩЕЙ СИМВОЛ ОКОНЧАНИЯ | 2013 |
|
RU2621000C2 |
СПОСОБ ВЫПОЛНЕНИЯ МАШИННОЙ КОМАНДЫ, КОМПЬЮТЕРНАЯ СИСТЕМА И МАШИНОЧИТАЕМЫЙ НОСИТЕЛЬ, ОБЕСПЕЧИВАЮЩИЕ РАСЧЕТ РАССТОЯНИЯ ОТ ПОЛОЖЕНИЯ В ОСНОВНОЙ ПАМЯТИ ДО ГРАНИЦЫ БЛОКА ОСНОВНОЙ ПАМЯТИ | 2012 |
|
RU2568920C2 |
КОМАНДА ВЕКТОРНОГО ТИПА ДЛЯ ПОИСКА НЕРАВНОЗНАЧНОГО ЭЛЕМЕНТА | 2013 |
|
RU2598814C2 |
СОХРАНЕНИЕ/ВОССТАНОВЛЕНИЕ ВЫБРАННЫХ РЕГИСТРОВ ПРИ ТРАНЗАКЦИОННОЙ ОБРАБОТКЕ | 2012 |
|
RU2562424C2 |
КОМАНДА НА НЕТРАНЗАКЦИОННОЕ СОХРАНЕНИЕ | 2012 |
|
RU2568324C2 |
Изобретение относится к сфере обработки в вычислительной среде, в частности к сфере сбора сведений о ходе выполнения команд программы в вычислительной среде. Технический результат заключается в повышении производительности процессора. Технический результат достигается за счет процессора, который собирает информацию, относящуюся к выполняемому потоку команд. На основе собранной информации формируются записи средства сбора сведений о ходе вычислений. В выполняемом процессором потоке команд выявляется точка выборки средства сбора сведений о ходе вычислений. В программном буфере средства сбора сведений о ходе вычислений сохраняется отчетная группа. Это сохранение включает: определение значения текущего адреса указанного программного буфера средства сбора сведений о ходе вычислений, основанное на доступных команде управляющих параметрах средства сбора сведений о ходе вычислений; и собственно сохранение указанной отчетной группы в указанном программном буфере средства сбора сведений о ходе вычислений, основанное на начальном адресе и указанном текущем адресе программного буфера средства сбора сведений о ходе вычислений, причем отчетная группа содержит указанные сформированные записи средства сбора сведений о ходе вычислений. 3 н. и 17 з.п. ф-лы, 22 ил.
1. Машиночитаемый носитель данных с хранящимся на нем компьютерным программным продуктом для сбора сведений о ходе вычислений, содержащим команды, предназначенные для выполнения схемой обработки с целью осуществления способа, включающего:
выполнение процессором потока команд;
сбор процессором информации, предназначенной для средства сбора сведений о ходе вычислений и относящейся к выполняемому потоку команд;
формирование записей средства сбора сведений о ходе вычислений на основе указанной собранной информации для средства сбора сведений о ходе вычислений;
выявление в выполняемом процессором потоке команд точки выборки средства сбора сведений о ходе вычислений; и
сохранение отчетной группы в программном буфере средства сбора сведений о ходе вычислений, основанное на выявлении в выполняемом потоке команд точки выборки средства сбора сведений о ходе вычислений и включающее:
определение значения текущего адреса программного буфера средства сбора сведений о ходе вычислений, основанное на доступных команде управляющих параметрах средства сбора сведений о ходе вычислений; и
сохранение отчетной группы в программном буфере средства сбора сведений о ходе вычислений, основанное на начальном адресе и указанном текущем адресе программного буфера средства сбора сведений о ходе вычислений, причем отчетная группа содержит указанные сформированные записи средства сбора сведений о ходе вычислений.
2. Машиночитаемый носитель данных по п. 1, в котором отчетная группа содержит заранее определенное число записей средства сбора сведений о ходе вычислений, которое задается управляющими параметрами средства сбора сведений о ходе вычислений.
3. Машиночитаемый носитель данных по п. 1, в котором указанный способ также включает выполнение программы в режиме супервизора для задания начального адреса программного буфера средства сбора сведений о ходе вычислений или текущего адреса программного буфера средства сбора сведений о ходе вычислений в управляющих параметрах средства сбора сведений о ходе вычислений.
4. Машиночитаемый носитель данных по п. 3, в котором указанная программа содержит команду загрузки значений управляющих параметров средства сбора сведений о ходе вычислений (команду LRIC) или команду изменения значений управляющих параметров средства сбора сведений о ходе вычислений (команду MRIC).
5. Машиночитаемый носитель данных по п. 1, в котором указанный способ также включает выполнение программы в режиме задач для задания значения указанного начального адреса программного буфера средства сбора сведений о ходе вычислений в управляющих параметрах средства сбора сведений о ходе вычислений, причем указанная программа содержит команду изменения значений управляющих параметров средства сбора сведений о ходе вычислений (команду MRIC).
6. Машиночитаемый носитель данных по п. 1, в котором управляющие параметры средства сбора сведений о ходе вычислений определяют число записей в каждой отчетной группе в программном буфере средства сбора сведений о ходе вычислений.
7. Машиночитаемый носитель данных по п. 1, в котором программный буфер средства сбора сведений о ходе вычислений находится в адресном пространстве, к которому имеет доступ прикладная программа.
8. Реализованный на компьютере способ сбора сведений о ходе вычислений, включающий:
выполнение процессором потока команд;
сбор процессором информации, предназначенной для средства сбора сведений о ходе вычислений и относящейся к выполняемому потоку команд;
формирование записей средства сбора сведений о ходе вычислений на основе указанной собранной информации для средства сбора сведений о ходе вычислений;
выявление в выполняемом процессором потоке команд точки выборки средства сбора сведений о ходе вычислений; и
сохранение отчетной группы в программном буфере средства сбора сведений о ходе вычислений, основанное на выявлении в выполняемом потоке команд точки выборки средства сбора сведений о ходе вычислений и включающее:
определение значения текущего адреса программного буфера средства сбора сведений о ходе вычислений, основанное на доступных команде управляющих параметрах средства сбора сведений о ходе вычислений; и
сохранение отчетной группы в программном буфере средства сбора сведений о ходе вычислений, основанное на начальном адресе и указанном текущем адресе программного буфера средства сбора сведений о ходе вычислений, причем отчетная группа содержит указанные сформированные записи средства сбора сведений о ходе вычислений.
9. Способ по п. 8, в котором отчетная группа содержит заранее определенное число записей средства сбора сведений о ходе вычислений, которое задается управляющими параметрами средства сбора сведений о ходе вычислений.
10. Способ по п. 8, также включающий выполнение программы в режиме супервизора для задания начального адреса программного буфера средства сбора сведений о ходе вычислений или текущего адреса программного буфера средства сбора сведений о ходе вычислений в управляющих параметрах средства сбора сведений о ходе вычислений.
11. Способ по п. 10, в котором указанная программа содержит команду загрузки значений управляющих параметров средства сбора сведений о ходе вычислений (команду LRIC) или команду изменения значений управляющих параметров средства сбора сведений о ходе вычислений (команду MRIC).
12. Способ по п. 8, также включающий выполнение программы в режиме задач для задания значения указанного начального адреса программного буфера средства сбора сведений о ходе вычислений в управляющих параметрах средства сбора сведений о ходе вычислений, причем указанная программа содержит команду изменения значений управляющих параметров средства сбора сведений о ходе вычислений (команду MRIC).
13. Способ по п. 8, в котором управляющие параметры средства сбора сведений о ходе вычислений определяют число записей в каждой отчетной группе в программном буфере средства сбора сведений о ходе вычислений.
14. Способ по п. 8, в котором программный буфер средства сбора сведений о ходе вычислений находится в адресном пространстве, к которому имеет доступ прикладная программа.
15. Система для сбора сведений о ходе вычислений, содержащая процессор и сконфигурированная для выполнения способа, включающего:
выполнение процессором потока команд;
сбор процессором информации, предназначенной для средства сбора сведений о ходе вычислений и относящейся к выполняемому потоку команд;
формирование записей средства сбора сведений о ходе вычислений на основе указанной собранной информации для средства сбора сведений о ходе вычислений;
выявление в выполняемом процессором потоке команд точки выборки средства сбора сведений о ходе вычислений; и
сохранение отчетной группы в программном буфере средства сбора сведений о ходе вычислений, основанное на выявлении в выполняемом потоке команд точки выборки средства сбора сведений о ходе вычислений и включающее:
определение значения текущего адреса программного буфера средства сбора сведений о ходе вычислений, основанное на доступных команде управляющих параметрах средства сбора сведений о ходе вычислений; и
сохранение отчетной группы в программном буфере средства сбора сведений о ходе вычислений, основанное на начальном адресе и указанном текущем адресе программного буфера средства сбора сведений о ходе вычислений, причем отчетная группа содержит указанные сформированные записи средства сбора сведений о ходе вычислений.
16. Система по п. 15, в которой отчетная группа содержит заранее определенное число записей средства сбора сведений о ходе вычислений, которое задается управляющими параметрами средства сбора сведений о ходе вычислений.
17. Система по п. 15, в которой указанный способ также включает выполнение программы в режиме супервизора для задания начального адреса программного буфера средства сбора сведений о ходе вычислений или текущего адреса программного буфера средства сбора сведений о ходе вычислений в управляющих параметрах средства сбора сведений о ходе вычислений.
18. Система по п. 17, в которой указанная программа содержит команду загрузки значений управляющих параметров средства сбора сведений о ходе вычислений (команду LRIC) или команду изменения значений управляющих параметров средства сбора сведений о ходе вычислений (команду MRIC).
19. Система по п. 15, в которой указанный способ также включает выполнение программы в режиме задач для задания значения указанного начального адреса программного буфера средства сбора сведений о ходе вычислений в управляющих параметрах средства сбора сведений о ходе вычислений, причем указанная программа содержит команду изменения значений управляющих параметров средства сбора сведений о ходе вычислений (команду MRIC).
20. Система по п. 15, в которой управляющие параметры средства сбора сведений о ходе вычислений определяют число записей в каждой отчетной группе в программном буфере средства сбора сведений о ходе вычислений.
Колосоуборка | 1923 |
|
SU2009A1 |
US 6145123 A, 07.11.2000 | |||
Пресс для выдавливания из деревянных дисков заготовок для ниточных катушек | 1923 |
|
SU2007A1 |
US 7406603 B1, 29.07.2008 | |||
Устройство для транспортировки рессор | 1939 |
|
SU58744A1 |
Авторы
Даты
2016-06-10—Публикация
2013-02-28—Подача