- •25. Конвейеризация
- •Особенности отладки в срв.
- •29. Отладочные действия при активной отладке.
- •31. Отладочные действия при мониторинге
- •30. Средства мониторинга. Архитектура средств мониторинга. Пользовательский интерфейс.
- •28. Средства активной отладки. Архитектура средств активной отладки. Пользовательский интерфейс.
- •26. Кэш память.
31. Отладочные действия при мониторинге
Требование к средствам мониторинга - сбор данных с минимальным вмешательством в работу целевой системы. Агенту отладки нужно как можно реже обращаться к менеджеру, то есть хранить полученные данные в некотором буфере и пересылать их по мере заполнения буфера. Отличия от активной: агенту отладки запрещено останавливать отлаживаемую задачу и модифицировать ее данные.
Отладочные действия (категории):1)сбор данных; 2)анализ данных; 3)профилирование системы; 4)"посмертный" анализ.
1) Сбор данных. Способы:
-Передавать данные на инструментальную сторону по мере их поступления. Этот способ применяется при оперативной отладке.
-Передавать данные в случае заполнения буфера. Обычный способ сбора данных при мониторинге.
-Сохранять данные на диске. Получение данных для последующего анализа.
Сбор данных может осуществляться однократно, циклически или непрерывно. При этом отладчик может совершать следующие действия: а)начать сбор данных б)прервать сбор данных; в)запланировать начало и/или конец сбора данных по времени, получению сигнала или произошедшему событию.
Данные могут представлять собой как информацию о задаче (содержимое регистров, стека, и.т.д), так и информацию о системе в целом (протокол произошедших событий, протокол выделения памяти). Например при трассировке задачи: на первую инструкцию отлаживаемой функции ставится точка прерывания, обрабатываемая особым образом, а именно: а)ставится точка прерывания на точку возврата из отлаживаемой функции; б)передается управление функции, которая должна быть вызвана перед отлаживаемой ; в)запускается выполнение отлаживаемой функции.Затем при обработке второй точки прерывания вызывается функция, реализующая некоторый набор завершающих действий. При сборе информации о динамическом выделении памяти: Заменить функции выделения и освобождения памяти на соответствующие функции, выполняющие некоторые отладочные действия, а именно: установку флага доступа к блоку, сбор статистики по использованию памяти, протоколирование информации по выделенным блокам.
2) Анализ данных
-Анализ на инструментальной стороне. Анализ данных, полученных во время текущего сеанса отладки, данных, полученных ранее и сохраненных на диске. Фиксируется время отладки.
-Анализ на целевой стороне. В этом случае при обращению к адресу в памяти происходит проверка на принадлежность его к какому-либо блоку и возможность доступа. Далее предоставляется возможность создания пула из некоторого числа буферов одинакового размера. Тогда, используя соответствующие функции доступа к этому пулу, можно осуществлять быстрый захват и освобождение его буферов.
-Распределенный анализ. При передаче данных на инструментальную сторону отладчик может производить фильтрацию. Фильтрация данных нужна, чтобы уменьшить вмешательство в работу целевой системы, то есть можно разбить отладку на несколько уровней: от минимального (исследование событий одного вида) до максимального (получение данных о выполняемых задачах).
3) Профилирование системы Слежка за выполнением некоторого множества задач (или всей системы) и предоставляющий информацию: как конкретная задача использует процессор. Выборка данных производится с определенным периодом.При детальном профилировании собираются данные о каждой функции. Цель профилир. задачи - выявить наиболее часто исполняемые блоки для последующей их оптимизации.
4) "Посмертный" анализ
Подобный анализ производится в том случае, если в работе системы произошел сбой. Записываются события, которые произошли за некоторое время до "обвала" системы. В этом случае, чтобы влияние отладчика на систему было сведено к минимуму, все данные сохраняются в некотором буфере и обновляются по мере его заполнения, но не пересылаются на инструментальную сторону. Адрес для буфера надо выбирать так, чтобы при перезагрузке системы его содержимое не уничтожалось.