RR создан для точного воспроизведения багов, которые проявляют себя непредсказуемо. В таких случаях при отладке стандартными средствами нет смысла запускать программу снова: не факт, что баг опять проявится. Эта проблема постоянно портит жизнь разработчикам. Вот почему в Mozilla решили создать такой фреймворк.
RR позволяет поднять отладку на совершенно новый уровень: перед уходом на обед оставляете скрипт для тестов с разными параметрами, а к вашему возвращению RR запишет хотя бы одно выполнение с ошибкой. Можно прокрутить эту запись и понять, в чём проблема.
Теоретически, GDB тоже позволяет отмотать выполнение программы, но в реальности эта функция в RR реализована на порядок лучше. Главное, что удалось решить проблему с производительностью: воспроизведение программы происходит практически с той же скоростью, что и обычное исполнение, потому что RR записывает только изменяющиеся фрагменты и не трогает бóльшую часть программы.
На диаграмме показано, насколько отличается скорость записи и скорость воспроизведения записанной программы от её нативного исполнения (оверхед).
Относительно большой оверхед reftest объясняется тем, что текущая конфигурация Gecko для Linux работает через X-сервер
К сожалению, пока что дебаггер поддерживает только x86 32-битные процессы, но это ограничение наверняка снимут в будущих версиях. Ещё одно ограничение первой версии — эмуляция только одноядерной машины. Для записи параллельных вычислений не обойтись без аппаратной поддержки, так что от этого ограничения так просто не избавишься. И ещё, дебаггер пока работает только на процессорах Intel Ivy Bridge и Sandy Bridge.
Создание отладочного инструмента RR заняло у разработчиков из Mozilla два года. Код на github.
ссылка на оригинал статьи http://habrahabr.ru/post/217251/
Добавить комментарий