Политика очистки страниц
Замещение
страниц лучше всего работает при наличии
достаточного количества свободных
страничных блоков, которые могут
потребоваться при возникновении ошибки
отсутствия страницы. Если заполнен и,
более того, изменен каждый страничный
блок, то перед помещением в него новой
страницы сначала должна быть записана
на диск старая страница. Для обеспечения
поставки свободных страничных блоков
системы замещения страниц, как правило,
имеют фоновый процесс. Если свободно
слишком мало страничных блоков, фоновый
процесс начинает подбирать страницы
для выгрузки, используя какой-нибудь
алгоритм замещения страниц. Если эти
страницы со времени своей загрузки
подверглись изменению, они записываются
на диск.
В
любом случае предыдущее содержание
страницы запоминается. Если одна из
выгруженных страниц понадобится опять
перед тем, как ее страничный блок будет
переписан, она может быть восстановлена
из резерва свободных страничных блоков.
Обработка ошибки отсутствия страницы
Описание
всего, что происходит при возникновении
ошибки отсутствия страницы. Складывается
следующая последовательность событий:
1.
Аппаратное прерывание передает управление
ядру, сохраняя в стеке значение счетчика
команд. На большинстве машин в специальных
регистрах центрального процессора
сохраняется информация о состоянии
текущей команды.
2.
Запускается код стандартной программы
на ассемблере, предназначенный для
сохранения регистров общего назначения
и другой изменяющейся информации, чтобы
защитить ее от разрушения со стороны
операционной системы.
3.
Операционная система определяет, что
произошла ошибка отсутствия страницы,
и пытается определить, какая виртуальная
страница востребована. Зачастую эта
информация содержится в одном из
аппаратных регистров. В противном случае
операционная система должна взять
значение счетчика команд, извлечь
команду и провести ее разбор программным
способом, чтобы определить, что происходило
в тот момент, когда возникла ошибка.
4.
Когда известен виртуальный адрес,
вызвавший ошибку, система проводит
проверку адреса на приемлемость и
доступа к этому адресу — на согласованность
с системой защиты. При отрицательном
результате проверки процессу посылается
сигнал или же он уничтожается.
5.
Если выбранный страничный блок содержит
измененную страницу, она включается в
план сброса на диск и происходит
переключение контекста, приостанавливающее
процесс, в котором произошла ошибка.
6.
Как только страничный блок очистится
(либо немедленно, либо после сброса его
содержимого на диск), операционная
система ищет адрес на диске, по которому
находится востребованная страница, и
в план включается дисковая операция,
предназначенная для ее извлечения. Пока
страница загружается, процесс, в котором
произошла ошибка, остается приостановленным
и запускается другой пользовательский
процесс, если таковой имеется.
7.
Когда дисковое прерывание показывает,
что страница получена, таблицы страниц
обновляются, чтобы отобразить ее позицию,
и блок получает пометку нормального
состояния.
8.
Команда, на которой произошла ошибка,
возвращается к тому состоянию, в котором
она находилась с самого начала, и счетчик
команд переключается, чтобы указывать
на эту команду.
9.
Процесс, в котором произошла ошибка,
включается в план, и операционная система
возвращает управление стандартной
программе на ассемблере, которая ее
вызвала.
10.
Эта стандартная программа перезагружает
регистры и другую информацию о состоянии
и, если не произошло ошибки, возвращается
в пространство пользователя для
продолжения выполнения.
Когда в Windows запускается процесс, многие из отображающих образы файлов EXE и DLL страниц могут уже находиться в памяти, поскольку они используются другими процессами. Пригодные для записи страницы образов помечены как «копирование при записи», чтобы их можно было совместно использовать до того момента, когда их понадобится модифицировать. Если операционная система узнает уже выполнявшийся ЕХЕ, то она может записать шаблон страничных ссылок (при помощи технологии, которую компания Microsoft называет Super-Fetch). Эта технология старается заблаговременно подкачать много нужных страниц (хотя процесс еще не получил по ним страничные ошибки). Это снижает латентность запуска приложений (чтение страниц с диска накладывается на выполнение инициализационного кода образов). Эта технология повышает производительность вывода на диск, поскольку дисковым драйверам легче организовать операции чтения (чтобы уменьшить необходимое время поиска). Этот процесс упреждающей подкачки страниц используется и во время загрузки системы, а также когда фоновое приложение выходит на передний план и при выходе системы из гибернации.
Упреждающая подкачка страниц поддерживается диспетчером памяти, но реализована она как отдельный компонент системы. Подкачиваемые страницы не вставляются в таблицу страниц процесса, вместо этого они вставляются в резервный список, из которого могут быть быстро вставлены в процесс (без обращения к диску).
Неотображенные страницы несколько отличаются — они не инициализируются путем чтения из файла. Вместо этого при первом обращении к неотображенной странице диспетчер памяти предоставляет новую физическую страницу (убедившись, что ее содержимое заполнено нулями, — из соображений безопасности). При последующих страничных ошибках неотображенную страницу может понадобиться найти в памяти или ее придется прочитать из файла подкачки.
Подкачка по требованию в диспетчере памяти управляется страничными ошибками. При каждой ошибке происходит прерывание в ядро. Затем ядро строит машинно независимый дескриптор (который сообщает о происшедшем) и передает его в диспетчер памяти исполнительного уровня. Диспетчер памяти затем проверяет обращение на действительность. Если давшая сбой страница попадает в зафиксированную область, то он ищет адрес в списке VAD и находит (или создает) элемент таблицы страниц процесса. В случае совместно используемой страницы диспетчер памяти использует элемент таблицы страниц прототипов (связанный с объектом сегмента) для заполнения нового элемента таблицы страниц процесса.
Формат элемента таблицы страниц различается в зависимости от архитектуры процессора. Для процессоров х86 и х64 элементы отображаемой страницы показаны на рис. 11.17. Если элемент помечен как действительный, то его содержимое интерпретируется аппаратным обеспечением (чтобы виртуальный адрес можно было преобразовать в правильную физическую страницу). Неотображенные страницы также имеют свои элементы, но они помечены как недействительные (invalid), и аппаратное обеспечение игнорирует остальную часть элемента. Программный формат несколько отличается от аппаратного и определяется диспетчером памяти. Например, для неотображенной страницы (которая должна быть размещена и обнулена до использования) этот факт отмечен в элементе таблицы страниц.
Два важных бита элемента таблицы страниц обновляются непосредственно аппаратным обеспечением. Это бит доступа (А) и бит «измененная» (D). Эти биты отслеживают использование данного отображения страницы для доступа к странице и возможность модифицирования страницы при этом доступе. Это реально повышает производительность системы, поскольку диспетчер памяти может использовать бит доступа для реализации подкачки по схеме наиболее давнего использования (Least- Recently Used (LRU)). Принцип LRU состоит в том, что те страницы, которые дольше всех не используются, имеют самую низкую вероятность повторного использования в ближайшее время. Бит доступа позволяет диспетчеру памяти определить, что к странице был произведен доступ. Бит «измененная» говорит диспетчеру памяти о том, что страница, возможно, была модифицирована (или, что более важно, она не была модифицирована). Если страница не была модифицирована с момента считывания с диска, то диспетчеру памяти не нужно записывать ее содержимое на диск (перед тем, как использовать ее для чего-то другого).
В обеих архитектурах, х86 и x64, используется элемент таблицы страниц размером 64 бита (см. рис. 11.17).
Каждая страничная ошибка может быть отнесена к одной из пяти категорий:
1. Страница не зафиксирована.
2. Попытка обращения к странице с нарушением разрешений.
3. Попытка модификации страницы типа «копирование при записи».
1. Необходимо увеличение стека.
2. Страница зафиксирована, но в данное время не отображена.
Первый и второй случаи — это ошибки программирования. Если программа пытается использовать адрес, который не имеет действительного отображения, или пытается выполнить недопустимую операцию (наподобие попытки записи в страницу «только для чтения»), это называется нарушением доступа (access violation) и обычно приводит к завершению процесса. Нарушение доступа часто является результатом недопустимых значений указателей, в том числе результатом обращения к памяти, которая была освобождена и откреплена от процесса.
Третий случай имеет такие же симптомы, что и второй (попытка записи в страницу «только для чтения»), но его обработка иная. Поскольку страница была помечена как «копирование при записи», то диспетчер памяти не выдает нарушение доступа. Вместо этого он создает закрытую копию страницы для текущего процесса, а затем возвращает управление тому потоку, который пытался выполнить запись в страницу. Поток повторяет операцию записи, которая теперь завершится без страничной ошибки.
Четвертый случай происходит тогда, когда поток помещает значение в свой стек и попадает на страницу, которая еще не была выделена. Диспетчер памяти распознает это как особый случай. Пока есть место в зарезервированных под стек виртуальных страницах, диспетчер памяти будет поставлять новые страницы, обнулять их и отображать в процесс. Когда поток возобновит выполнение, он повторит попытку доступа, и на этот раз она будет успешной.
И наконец, пятый случай — это нормальная страничная ошибка. Однако она имеет несколько подвариантов. Если страница отображена на файл, то диспетчер памяти должен просмотреть ее структуры данных (такие, как таблица страниц прототипов, связанная с объектом сегмента), чтобы быть уверенным в том, что в памяти нет ее копии. Если копия есть (например, в другом процессе, в резервном списке либо в списке модифицированных страниц), то он просто сделает ее совместно используемой (возможно, что для этого ему придется пометить ее как страницу «копирование при записи», если изменения совместно использовать не предполагается). Если копии еще нет, то диспетчер памяти выделит свободную физическую страницу и подготовит ее для копирования в нее страницы файла с диска, если только в этот момент не осуществляется перенос с диска другой страницы (тогда нужно лишь подождать, пока этот перенос не завершится).
Если диспетчер памяти может обработать страничную ошибку, находя нужную страницу в памяти (а не считывая ее с диска), то такая ошибка называется мягкой ошибкой (soft fault). Если нужна копия с диска, то это жесткая ошибка (hard fault). Мягкие ошибки гораздо дешевле, они мало влияют на производительность приложения (по сравнению с жесткими ошибками). Мягкие ошибки могут происходить потому, что совместно используемая страница уже была отображена на другой процесс, либо нужна просто новая обнуленная страница, либо нужная страница была удалена из рабочего набора процесса, но запрашивается повторно до того, как ее повторно использовали. Мягкие ошибки могут возникать также из-за того, что страницы были сжаты для эффективного увеличения размера физической памяти. Для большинства конфигураций центрального процессора память и ввод-вывод в текущих системах эффективнее сжимать, вместо того чтобы тратиться на дорогостоящий ввод-вывод (с точки зрения производительности и энергозатрат), требующий чтения страницы с диска.
Когда физическая страница больше не отображается таблицей страниц ни одного из процессов, она попадает в один из трех списков: свободных, модифицированных или резервных. Те страницы, которые никогда больше не понадобятся (такие, как страницы стека завершающегося процесса), освобождаются немедленно. Те страницы, которые могут снова дать страничную ошибку, попадают либо в список модифицированных, либо в список резервных (в зависимости от того, был ли бит «измененная» установлен для какого-либо элемента таблицы страниц, который отображал эту страницу с момента ее последнего считывания с диска). Страницы из модифицированного списка будут в конечном итоге записаны на диск, а затем перемещены в список резервных.
Диспетчер памяти может выделять страницы по мере необходимости (используя список либо свободных, либо резервных страниц). Перед размещением страницы и копированием с диска диспетчер памяти всегда проверяет списки резервных и модифицированных страниц, чтобы проверить, нет ли уже этой страницы в памяти. Схема опережающей подкачки в Windows преобразует будущие жесткие ошибки в мягкие (путем чтения страниц, которые могут понадобиться, и помещения их в список резервных страниц). Диспетчер памяти и сам выполняет небольшой объем опережающей подкачки — он обращается к группам последовательных страниц (а не к отдельным страницам). Дополнительные страницы немедленно размещаются в списке резервных страниц. Это не является расточительством, поскольку издержки диспетчера памяти гораздо меньше, чем стоимость выполнения операций ввода-вывода. Чтение целого кластера страниц чуть дороже, чем чтение одной страницы.
Элементы таблицы страниц на рис. 11.17 относятся к номерам физических (а не виртуальных) страниц. Для обновления элемента таблицы страниц (и каталога страниц) ядру нужно использовать виртуальные адреса. Windows отображает таблицы страниц и каталоги страниц для текущего процесса на виртуальное адресное пространство ядра при помощи элемента self-map в каталоге страниц (рис. 11.18). Отображая элемент каталога страниц на каталог страниц (карта self-map), мы получаем виртуальные адреса, которые можно использовать для ссылки на элементы каталога страниц (рис. 11.18, а) и на элементы таблицы страниц (рис. 11.18, б). Карта self-map занимает 8 Мбайт виртуальных адресов ядра для каждого процесса (на процессорах х86). Для простоты на рисунке показан элемент x86 self-map для 32-разрядных PTE-записей (Page-Table Entries). На самом деле Windows использует 64-разрядные PTE-записи, поэтому система может воспользоваться более чем 4 Гбайт физической памяти. С 32-разрядными PTE-записями элемент self-map использует в каталоге страниц только одну PDE- запись (Page-Directory Entry) и поэтому занимает только 4 Мбайт адресов, а не 8 Мбайт.
Многие вычислительные
системы имеют в своем составе тот или
иной вариант диспетчера памяти (другое
название — устройство управления памятью
— УУП), с помощью которого многозадачная
операционная система выделяет память
каждой задаче и обеспечивает защиту от
программ пользователей. Например,
типичная проблема возникает в том
случае, когда прикладная программа
делает ошибку при вычислении адреса,
возможно используя слишком большое или
слишком маленькое значение индекса.
Если в системе нет защиты, такого рода
ошибка может привести к изменению кодов,
входящих в программы операционной
системы, или к модификации таблиц
устройств и даже вызвать незапланированный
запуск устройства с фатальными
последствиями, такими как несанкционированная
запись в фалл с данными.
Помимо защиты
операционной системы от неумышленного
разрушения диспетчер памяти обеспечивает
автоматическое перемещение программы.
С помощью диспетчера памяти логические
или программные адреса программ
пользователей преобразуются в физические,
или аппаратные адреса. Эти адреса могут
располагаться в памяти совершенно не
там, куда указывают логические адреса.
Преобразование адресов приводит к
полному выводу операционной системы и
защищенных устройств ввода-вывода из
адресного пространства пользователя.
Любая попытка чтения или записи в память
вне пространства адресов, отведенных
пользователю, заставляет процессор
аварийно завершить программу пользователя.
Информация обычно
передается порциями, состоящими из
фиксированного числа битов; МП 80386
использует порции размером 32 бит, если
только он не получил указаний об
уменьшении размеров порции до 16 бит.
Эти порции носят названия слов. Процесс
записи слова в запоминающую систему
называется записью в память,
процесс
получения слова из памяти —чтением
из памяти.
Существуют два
метода доступа к памяти: произвольный
и последовательный. Последовательный
доступ используется в тех запоминающих
системах, где обращение к словам
осуществляется в некотором определенном
заранее порядке. Произвольный доступ,
с другой стороны, предполагает возможность
обращения к словам запоминающей системы
в любом порядке и приблизительно за то
же время.
Каким бы совершенным
ни было ЗУ, при прохождении сигнала
между устройствами возникают задержки
в его распространении. Задержка
распространения определяется как время,
требуемое для прохождения логического
сигнала через устройство или
последовательность устройств, образующих
логическую цепочку. Эта задержка также
учитывает прохождение сигнала по всем
соединительным линиям между микросхемами.
Прямой доступ к
памяти (ПДП)
Прямой доступ к
памяти предоставляет возможность
внешним устройствам и памяти непосредственно
обмениваться данными без вмешательства
программы. ПДП обеспечивает максимальную
скорость ввода-вывода и максимальный
параллелизм процессов. В то время как
ввод-вывод по прерываниям и
программно-управляемый ввод-вывод
пересылают данные через процессор, в
случае ПДП данные передаются непосредственно
между устройством ввода-вывода и памятью.
Чтобы свести к
минимуму число шин данных, принимаются
специальные меры, позволяющие использовать
обычную магистраль для ПДП. Меры эти
заключаются в том, что процессор
освобождает магистраль, а внешнее
устройство захватывает ее и использует
для передачи данных.
На время ПДП выполнение
программы обычно приостанавливается.
Магистраль освобождается, как только
возбуждается управляющая линия запроса
ПДП. Процессор завершает текущую
операцию, освобождает линии адреса и
данных и устанавливает сигнал на одной
из линий управления, чтобы предотвратить
непреднамеренную расшифровку
неопределенных сигналов управления.
Интерфейс ввода-вывода
пересылает данные непосредственно в
память с помощью специального регистра.
Когда возникает необходимость в передаче
данных, интерфейс запрашивает у процессора
цикл памяти. Получив подтверждение,
интерфейс пересылает данные непосредственно
в память, в то время как процессор
останавливается на один цикл памяти.
Логика, выполняющая эту пересылку,
называется каналом.
Канал содержит
регистр для хранения адреса ячейки
памяти, в которую или из которой
осуществляется пересылка данных, В
большинстве случаев в канал входит
также счетчик слов для отсчета числа
выполненных прямых пересылок. Кроме
того, канал должен содержать схему,
обеспечивающую обмен управляющими
сигналами, синхронизацию и другие
вспомогательные операции. На рис. 13.4
показаны логические связи между ЦП и
контроллером ПДП.
Компоненты ПДП
.
Основными компонентами ПДП являются
триггер запроса, регистр адреса, счетчик
и регистр данных, который используется
периферийным устройством. Пересылка
данных по каналу ПДП включает несколько
этапов: 1) инициализация логики ПДП для
выполнения ПДП в течение повторяющихся
циклов занятия магистрали; 2) асинхронная
по отношению к операциям программы
активизация ПДП; 3) оповещение об окончании
пересылок (по сигналу от счетчика или
в результате изменении состояния
устройства); 4) вызов программы «очистки»
при окончании пересылок; 5) завершение
ПДП с помощью программы обработки
прерываний, которая возвращает управление
в основную программу.
Блочная пересылка
данных
. Процедура ПДП для высокоскоростных
устройств использует пересылку данных
блоками. Выполняя текущую программу,
процессор инициирует пересылку блока
данных и определяет число слов,
составляющих блок. Однако фактическая
передача слов выполняется под управлением
отдельного устройства — контроллера
ПДП. Максимальная скорость блочной
передачи по каналу ПДП ограничивается
только длительностью цикла памяти
(чтения или записи) и скоростью работы
контроллера ПДП.
ПДП с занятием цикла
памяти. Программа инициирует пересылку
блока, помещая стартовый адрес в адресный
счетчик, а число слов — в счетчик слов.
и выдавая команду запуска. Этот тип ПДП
часто называют ПДП с занятием цикла
памяти,
поскольку он приостанавливает
выполнение программы каждый раз
приблизительно на один машинный цикл.
При использовании
ПДП с занятием цикла памяти пересылка
данных осуществляется параллельно с
другими процессами, выполняемыми ЦП.
Последовательность действий здесь
такая же, как и при блочной передаче, за
тем исключением, что контроллер ПДП
занимает циклы памяти у процессора и,
следовательно, замедляет его работу
(блочная передача данных по каналу ПДП
также занимает
циклы памяти, если
только не используется ПДП по отдельной
шине).
ы подключили новое устройство, а оно не спешит работать, или старое устройство перестало функционировать, или делает свою работу некорректно. Что же делать в этих случаях? Переустанавливать всё? Хлопотно, да и не всегда в этом есть необходимость. Как же узнать в чём причина и как её устранить? Очень просто. Дело в том, что в ОС семейства Windows,
и не только, имеется, некий
Диспетчер устройств,
на самом деле очень нужный и полезный менеджер, если его можно так назвать. Вот он то, нам и поможет выяснить в чём причина неполадки, а моя шпаргалка — устранить проблему. Итак, в выше упомянутом
Диспетчере устройств
остаються следы ошибок в работе устройств в виде кодов. Зная код ошибки, нетрудно установить причину неполадки. Для непосвящённых, коды — это всего лишь непонятные и ничего не говорящие цифры. Но знающему пользователю, они могут сказать о многом. Постараюсь, насколько мне это удасться, пролить свет на эту тему.
Для просмотра ошибок устройств, нам прежде всего необходимо войти в сам Диспетчер устройств. Делается это так. Войдите в
Панель управления
из меню
Пуск (
можно,
Мой
компьютер
, правой клавишей —
Свойства
—
Диспетчер устройств,
а можно и через задание команды в
выполнить
, но зачем всё усложнять). Если мы входим через
Панель
управления
, то путь таков:
Система — Оборудование — Диспетчерн устройств
. Выберем, войдя в меню
Диспетчер устройств
, тип интересующего нас устройства (клавиатура, принтер, модем и т.д.), щёлкнем на нём дважды, в результате увидим входящие в этот тип устройства. Выбирем нужное нам устройство и дважды щёлкнем на нём. Смотрим графу на вкладке О
бщие, Состояние устройства.
Если имеется проблема с работой устройства, то она будет отображена здесь в виде кода ошибки. Итак мы видим цифры и числа. Что же они обозначают. Ниже я привожу полный список ошибок, с кратким описанием ошибки и возможных способах устранения. Красным цветом выделен код ошибки, синим её описание и чёрным устранение.
Код 1
Проблема с настройкой устройства, не правильные настройки или отсутствует драйвер.
Нажмите кнопку
Обновить драйвер
, для запуска мастера
Обновление оборудования
. Если вообще нет драйвера — установите его.
Код 3
Повреждён драйвер устройства, как вариант не хватает оперативной памяти для корректной работы устройства.
1.
Удалим повреждённый драйвер и установим новый. Для этого: Свойства — Драйвер — Удалить, далее следуем указаниям мастера. Перезагрузка. Открываем опять
Диспетчер устройств
—
Действие
—
Обновить конфигурацию оборудования
и следуем указаниям мастера. 2. Если проблема в нехватке виртуальной памяти, закроем работающие приложения, что бы разгрузить память. Что бы проверить состояние памяти нам нужно попасть в
Диспетчер задач
, для этого жмём сочетание клавиш
Ctrl+Shift+Esc.
Настройки виртуальной памяти мы можем посмотреть ещё щёлкнув правой клавишей
Мой компьютер
—
Свойства — Дополнительно — Быстродействие — Настройки (Параметры)
. Вы можете попробовать увеличить файл подкачки (как это делается, я описывал в одной из предыдущих статей моего блога ), но это далеко не радикальная мера. Придётся вам увеличивать оперативную память. Как это делается — отдельная тема, выходящая за рамки этого поста.
Код 10
В разделе реестра имеется соответствующий устройству параметр
FailReasonString,
значение этого параметра и отображается в данных ошибки, то есть, если параметра, как такового нет, то появляется код ошибки, проще говоря — запуск устройства не возможен.
Обновите драйвер, как указано выше. Или установите более новый.
Код 12
Нет запаса ресурсов, необходимых для этого устройства.
Отключите другие работающие устройства, хотя бы одно, для этого воспользуйтесь мастером устранения неполадок, который, если вы будете следовать его указаниям, отключит конфликтное устройство. (В кратце напомню: Свойства — Общие — Устранение неполадок.)
Код 14
Требует перезагрузки ПК для работы этого устройства.
Код 16
Невозможно выявить ресурсы, которые необходимы для работы устройства, устройство настроено не полностью.
Нужно назначить устройству дополнительные ресурсы. Но это можно сделать без проблем если устройство относится к
Plug and Play.
Свойства — Ресурсы.
Если в списке ресурсов есть ресурс с знаком?, выбираем его, чтобы назначить выбранному устройству. Если ресурс не возможно изменить, жмём
Изменить параметры
, если эта функция недоступна, снимаем галочку с
Автоматическая настройка
Код 18
Переустановите драйвер для устройства.
Пробуем обновить драйвер или удалить и сделать, как в примере с
кодом 3.
Код 19
Недостаточные сведения в реестре о настройках устройства, либо настройки повреждены.
Запустите
Мастер устранения неполадок
и следуйте его указаниям, не поможет — переустановите устройство, как было сказано выше. (код 3). Либо, если не поможет, загрузите
Последнюю удачную конфигурацию.
Если и это не поможет — вам нужна помощь специалиста, так, как необходимо редактировать системный реестр. Неимея знаний и опыта, самостоятельно, там вам делать нечего, любой сисадмин вам это подтвердит. Знающий и умеющий, сам знает, как это сделать, без меня. А неопытному, лучше и не пробовать. Реестр — сердце операционной системы и проводить операции на нём должен только опытный специалист, или под его руководством. Ни в коей мере не хочу ни кого обидеть, но если вы не работали с системным реестром и если вам дорог ваш компьютер, мой совет — забудьте туда дорогу. Я пишу не для профессионалов, им это не нужно, а для среднего пользователя. Конечно, я могу написать, как и что там делать, но это будет объяснение на пальцах и если вы, в результате малейшей ошибки, повредите свой компьютер, буду виноват я. Мне это совсем не нужно, да и вам то же.
Код 21 Устройство удаляется из системы, то есть операционная система пытается удалить устройство, но процесс ещё не завершён.
Выдержите паузу в несколько секунд и нажмите клавишу
Код 22 Устройство отключено.
Необходимо включить устройство.
Действие — Включить
и следуем дальнейшим инструкциям.
Код 24 Устройства нет или неправильно установлено, сбой в работе драйвера, может быть устройство было подготовлено к удалению.
Удалите устройство и установите заново.
Код 28 Нет драйвера.
Установите драйвер. Для этого нужно Обновить драйвер, действия, как в инструкции к Коду 1.
Код 29
Отключено устройство
. Необходимо разрешить работу устройства в
настройках
BIOS,
изучите инструкции к использованию устройства.
Код 31
Системе не удалось загрузить драйверы к этому устройству
. Обновите драйверы, как описывалось выше.
Код 32
Драйвер к этому устройству отключен в системном реестре
. Удалите и по-новой установите драйвер (описывалось выше)
Код 33
Операционная система не может определить ресурсы для данного
устройства
. Настройте устройство или замените его.
Код 34
Операционная система не может определить настройки
устройства
. Изучите прилагаемую документацию к оборудованию и настройте конфигурацию вручную на вкладке Ресурсы.
Код 35
Микропрограмма ПК неимеет нужных сведений для правильной
работы устройства
. Необходимо обновить
BIOS.
За инструкциями, как это сделать обратитесь к поставщику, а лучше воспользоваться услугами опытного мастера.
Код 36
Для работы устройства требуется прерывание
PCI,
а устройство настроено на прерывание
ISA,
или наоборот
. Необходимо изменить настройки
BIOS,
обратитесь к опытному мастеру.
Код 37
Операционная система неопознаёт драйвер к этому устройству
. Переустановите драйвер (описывалось выше).
Код 38
ОС не может загрузить драйвер для устройства, так как,
предыдущая версия драйвера осталась в памяти
. Необходимо перезагрузить ПК. Запустите мастер Устранения неполадок, если он не запустился (Свойства — Общие — Устранение неполадок) и следуйте указаниям мастера. После обязательная перезагрузка.
Код 39
ОС не может загрузить драйвер устройства. Драйвер повреждён
или его нет вовсе
. Переустановите драйвер, как было описано выше.
Код 40
Нет доступа к оборудованию, так, как нет информации в системном реестре или информация содержит ошибку
. Переустановите драйвер.
Код 41
Необнаружено устройство
. Запустите мастер Устранения неполадок (описано выше), если не помогло обновите конфигурацию оборудования (см. выше) или обновите драйвер. Если нет, установите более новую версию драйвера.
Код 42
В системе уже имеется такой драйвер. То есть имеются два разных устройства с одинаковым именем, возможно из-за ошибки
. Перезагрузите ПК.
Код 43
Остановка работы устройства из-за возникших проблем в его работе
. Запустите мастер Устранения неполадок и следуйте его указаниям.
Код 44
Приложение или служба остановили работу устройства
. Перезагрузите ПК.
Код 45
Устройство не подключено
. Подключите устройство.
Код 46
Такая ошибка появляется, если операционная система завершает свою работу. Ни чего не нужно делать, при следующем запуске ОС всё будет работать.
Код 47 Устройство было подготовлено для безопасного удаления, но ещё не удалено (например флеш)
. Извлеките устройство, затем подключите снова, перезагрузите ПК.
Код 48
Устройство, вернее его програмное обеспечение, заблокировано
. Обновите драйвер, или установите новый.
Код 49
Устройство не может быть запущено, так, как имеет большой объём системного куста реестра, который превышает допустимые параметры реестра
. Удалите из реестра устройства которые не используются. Можно сделать так: Диспетчер устройств — Вид — Показать скрытые устройства. Здесь вы увидите скрытые устройства, которые не подключены к вашему ПК. Выберите те устройства которые хотите удалить, кликнете Свойства для устройства — Драйвер — Удалить, далее следуйте указаниям мастера и в завершении перезагрузка ПК.
Пособие по удалению любых вирусов с ПК собственноручно. Все способы удаления вирусов реально работающие и проверенные на практике, пошаговая инструкция с илюстрациями — просто и доступно даже для школьника + видеоуроки + программа ultraiso
для создания загрузчиков+ полезные ссылки на инструменты в борьбе с вирусами. Скачать архив
В своей прошлой статье « » я рассказал о возможностях Монитора ресурсов Windows 7 (Resource Monitor), объяснил, как с его помощью наблюдать за распределением системных ресурсов между процессами и службами, а также упомянул, что его можно использовать для решения конкретных задач — например, для анализа расходования памяти. Именно об этом и пойдет речь в данной статье.
Немного о памяти
Прежде чем приступать к анализу, коротко расскажу о том, управляет памятью. После этого вам будет проще понять, какая информация представлена в Мониторе ресурсов Windows 7.
Диспетчер памяти Windows 7 создает виртуальную систему памяти, которая состоит из доступной физической RAM и файла подкачки на жестком диске. Это позволяет операционной системе выделять блоки памяти фиксированной длины (страницы) с последовательными адресами в физической и виртуальной памяти.
Запуск Монитора ресурсов Windows 7
Чтобы запустить Монитор ресурсов Windows 7, откройте меню «Пуск» (Start), введите в строке поиска «Resmon.exe» и нажмите . В открывшемся окне выберите вкладку «Память» (Memory, рис. A).
Рисунок A. На вкладке «Память» в Мониторе ресурсов Windows 7 приводятся подробные сведения о распределении памяти.
Таблица «Процессы»
На вкладке «Память» есть таблица «Процессы» (Processes, рис. B), в которой перечислены все запущенные процессы, а сведения об используемой памяти разбиты на несколько категорий.
Рисунок B. Сведения об используемой памяти для каждого процесса разбиты на несколько категорий.
Графа «Образ»
В колонке «Образ» (Image) указывается имя исполняемого файла процесса. Процессы, запущенные приложениями, узнать очень легко — например, процесс «notepad.exe» со всей очевидностью принадлежит Блокноту (Notepad). Процессы с именем «svchost.exe» представляют различные службы операционной системы. Название службы указывается в скобках рядом с именем процесса.
Графа «ИД процесса»
В колонке «ИД процесса» (PID) указывается номер процесса — уникальное сочетание цифр, позволяющее идентифицировать запущенный процесс.
Графа «Завершено»
В столбце «Завершено» (Commit) указывается объем виртуальной памяти в килобайтах, зарезервированный системой для данного процесса. Сюда входит и используемая физическая память, и сохраненные в файле подкачки страницы.
Графа «Рабочий набор»
В графе «Рабочий набор» (Working Set) указывается объем физической памяти в килобайтах, используемой процессом в данный момент времени. Рабочий набор складывается из общей и частной памяти.
Графа «Общий»
В колонке «Общий» (Shareable) указан объем физической памяти в килобайтах, которую данный процесс использует совместно с другими. Использование одного сегмента памяти или страницы подкачки для родственных процессов позволяет сэкономить место в памяти. При этом физически сохраняется только одна копия страницы, которая затем сопоставляется с виртуальным адресным пространством других процессов, которые к ней обращаются. Например, все процессы, инициированные системными библиотеками DLL — Ntdll, Kernel32, Gdi32 и User32 — используют общую память.
Графа «Частный»
В столбце «Частный» (Private) указывается объем физической памяти в килобайтах, используемой исключительно данным процессом. Именно это значение позволяет определить, сколько памяти нужно тому или иному приложению для работы.
Графа «Ошибок отсутствия страницы в памяти/сек.»
В графе «Ошибок отсутствия страницы в памяти/сек.» (Hard Faults/sec) указано среднее за последнюю минуту количество ошибок отсутствия страницы в памяти в секунду. Если процесс пытается использовать больше физической памяти, чем доступно в данный момент времени, система записывает часть данных из памяти на диск — в файл подкачки. Последующее обращение к данным, сохраненным на диск, и называется ошибкой отсутствия страницы в памяти.
О чем говорят ошибки отсутствия страницы в памяти
Теперь, когда вы представляете, какие сведения собраны в таблице «Процессы», давайте посмотрим, как с их помощью следить за распределением памяти. При запуске приложений и работе с файлами диспетчер памяти отслеживает объем рабочего набора для каждого процесса и фиксирует запросы на дополнительные ресурсы памяти. По мере увеличения рабочего набора процесса, диспетчер соотносит эти запросы с потребностями ядра и других процессов. Если доступного адресного пространства недостаточно, диспетчер уменьшает объем рабочего набора, сохраняя данные из памяти на диск.
В дальнейшем при чтении этих данных с диска возникает ошибка отсутствия страницы в памяти. Это вполне нормально, но если ошибки происходят одновременно для разных процессов, системе требуется дополнительное время для чтения данных с диска. Слишком частые ошибки отсутствия страницы в памяти, соответственно, снижают быстродействие системы. Вам наверняка доводилось наблюдать неожиданное замедление работы всех приложений, которое затем также неожиданно прекращалось. Почти наверняка это замедление было связано с активным перераспределением данных между физической памятью и подкачкой.
Отсюда следует вывод: если ошибки отсутствия страницы в памяти для того или иного процесса происходят слишком часто и притом регулярно, компьютеру не хватает физической памяти.
Чтобы было удобнее наблюдать за процессами, вызывающими частые ошибки отсутствия страницы в памяти, можно отметить их флажками. При этом выбранные процессы переместятся наверх списка, а в графике ошибок отсутствия страницы в памяти будут представлены оранжевой кривой.
Стоит учитывать, что распределение памяти зависит от целого ряда других факторов, и мониторинг ошибок отсутствия страницы в памяти — не лучший и не единственный способ выявления проблем. Тем не менее, он может послужить неплохой отправной точкой для наблюдения.
Таблица «Физическая память»
В таблице «Процессы» приводятся детальные сведения о распределении памяти между отдельными процессами, а таблица «Физическая память» (Physical Memory) дает общую картину использования RAM. Ее ключевой компонент — уникальная гистограмма, показанная на рис. C.
Рисунок C. Гистограмма в таблице «Физическая память» позволяет составить общее представление о распределении памяти в Windows 7.
Каждая секция гистограммы обозначена собственным цветом и представляет определенную группу страниц памяти. По мере использования системы, диспетчер памяти в фоновом режиме перемещает данные между этими группами, поддерживая тонкий баланс между физической и виртуальной памятью для обеспечения эффективной работы всех приложений. Давайте рассмотрим гистограмму поподробнее.
Секция «Зарезервированное оборудование»
Слева расположена секция «Зарезервированное оборудование» (Hardware Reserved), обозначенная серым цветом: это память, выделенная на нужды подключенного оборудования, которую оно использует для взаимодействия с операционной системой. Зарезервированная для оборудования память заблокирована и недоступна диспетчеру памяти.
Обычно объем памяти, выделенной оборудованию, составляет от 10 до 70 Мбайт, однако этот показатель зависит от конкретной конфигурации системы и в некоторых случаях может достигать нескольких сотен мегабайт. К компонентам, влияющим на объем зарезервированной памяти, относятся:
;
компоненты материнской платы — например, усовершенствованный программируемый контроллер прерываний ввода/вывода (APIC);
звуковые карты и другие устройства, осуществляющие ввод/вывод с отображением на память;
шина PCI Express (PCIe);
видеокарты;
различные наборы микросхем;
флеш-накопители.
Некоторые пользователи жалуются, что в их системах для оборудования зарезервировано ненормально много памяти. Мне с такой ситуацией сталкиваться не приходилось и потому я не могу ручаться за действенность предложенного решения, но многие отмечают, что обновление версии BIOS позволяет решить проблему.
Секция «Используется»
Секция «Используется» (In Use, рис C), обозначенная зеленым цветом, представляет количество памяти, используемой системой, драйверами и запущенными процессами. Количество используемой памяти рассчитывается, как значение «Всего» (Total) за вычетом суммы показателей «Изменено» (Modified), «Ожидание» (Standby) и «Свободно» (Free). В свою очередь, значение «Всего» — это показатель «Установлено» (Installed RAM) за вычетом показателя «Зарезервированное оборудование».
Секция «Изменено»
Оранжевым цветом выделена секция «Изменено» (Modified), в которой представлена измененная, но не задействованная память. Фактически она не используется, но может быть в любой момент задействована, если снова понадобится. Если память не используется достаточно давно, данные переносятся в файл подкачки, а память переходит в категорию «Ожидание».
Секция «Ожидание»
Секция «Ожидание», обозначенная синим цветом, представляет страницы памяти, удаленные из рабочих наборов, но по-прежнему с ними связанные. Другими словами, категория «Ожидание» — это фактически кэш. Страницам памяти в этой категории присваивается приоритет от 0 до 7 (максимум). Страницы, связанные с высокоприоритетными процессами, получают максимальный приоритет. Например, совместно используемые процессы обладают высоким приоритетом, поэтому связанным с ними страницам присваивается наивысший приоритет в категории «Ожидание».
Если процессу требуются данные с ожидающей страницы, диспетчер памяти сразу же возвращает эту страницу в рабочий набор. Тем не менее, все страницы в категории «Ожидание» доступны для записи данных от других процессов. Когда процессу требуется дополнительная память, а свободной памяти недостаточно, диспетчер памяти выбирает ожидающую страницу с наименьшим приоритетом, инициализирует ее и выделяет запросившему процессу.
Секция «Свободно»
В категории «Свободно», обозначенной голубым цветом, представлены страницы памяти, еще не выделенные ни одному процессу или освободившиеся после завершения процесса. В этой секции отображается как еще не задействованная, так и уже освобожденная память, но на самом деле, еще не задействованная память относится к другой категории — «Нулевые страницы» (Zero Page), которая так называется, потому что эти страницы инициализированы нулевым значением и готовы для использования.
О проблеме свободной памяти
Теперь, когда вы в общих чертах представляете, как работает диспетчер памяти, ненадолго остановимся на распространенном заблуждении, связанном с системой управления памятью в Windows 7. Как видно из рис. C, секция свободной памяти — одна из самых маленьких в гистограмме. Тем не менее, ошибочно на этом основании полагать, будто Windows 7 потребляет чересчур много памяти и что система не может нормально работать, если свободной памяти так мало.
На самом деле, все совсем наоборот. В контексте принятого в Windows 7 подхода к управлению памятью, свободная память бесполезна. Чем больше памяти задействовано, тем лучше. Заполняя память до максимума и постоянно перемещая страницы из одной категории в другую с использованием системы приоритетов, Windows 7 повышает эффективность работы и предотвращает попадание данных в файл подкачки, не давая ошибкам отсутствия страницы в памяти замедлить быстродействие.
Мониторинг памяти
Хотите понаблюдать систему управления памятью Windows 7 в действии? Перезагрузите компьютер и сразу же после запуска откройте Монитор ресурсов Windows 7. Перейдите на вкладку «Память» и обратите внимание на соотношение секций в гистограмме физической памяти.
Затем начните запускать приложения. По мере запуска следите за изменением гистограммы. Запустив как можно больше приложений, начните закрывать их по одному и наблюдайте, как изменяется соотношение секций в гистограмме физической памяти.
Проделав этот экстремальный эксперимент, вы поймете, как Windows 7 управляет памятью на вашем конкретном компьютере, и сможете использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти в нормальных условиях повседневной работы.
А что думаете вы?
Нравится ли вам идея использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти? Поделитесь своим мнением в комментариях!
Распределение
памяти в Windows9xи вWindowsNT.
Монитор ресурсов Windows 7. Изучение пунктов
и вкладок, связанных с памятью.
Использование монитора ресурсов Windows
7 для наблюдения за распределением
памяти. Увеличение объема файла подкачки
(виртуальной памяти). Проверка памяти
средствами Windows.
3.1. Распределение памяти в
Windows 9x
ОС Windows 9x — это 32-разрядные
многопотоковые ОС с вытесняющей
многозадачностью и графическим
пользовательским интерфейсом. Для своей
загрузки они используют MS-DOS 7.0, которая
обеспечивает два режима работы процессора
– реальный (в файле MSDOS.SYS в секции
прописано BootGUI=0) и защищённый
(BootGUI=1). Защищённый режим устанавливается
непосредственно перед загрузкой Windows
9x, в результате чего процессор начинает
управлять памятью с использованием
страничного механизма преобразования
виртуальных адресов в физические.
Область виртуального адресного
пространства состоит из 4-х килобайтных
страниц, которые размещаются в оперативной
памяти или на диске.
Младшие адреса виртуального
адресного пространства используются
совместно всеми процессами для обеспечения
совместимости с драйверами устройств
реального времени, резидентными
программами Windows и др. Это с одной стороны
удобно, но, с другой, снижает надёжность
(одно из основных качеств ОС), т.к. любой
процесс может запортить компоненты,
расположенные по этим адресам.
Каждая прикладная 32-разрядная
Windows-программа выполняется в своём
адресном пространстве, однако доступ
к нужным адресам возможен, т.е. организация
виртуальных адресов не использует всех
аппаратных средств защиты, заложенных
в микропроцессор. 16-разрядные программы
разделяют общее адресное пространство
и также уязвимы друг перед другом. Модель
памяти Windows 9x представлена на рис.3.1.
Рис. 3.1. Распределения ОП в Windows
9x
Нижние 64 Кб ОП недоступны
32-разрядным программам, но 16-разрядные
программы могут записывать сюда свои
данные. Адреса ниже 4 Мб отображаются в
адресное пространство каждой прикладной
программы и совместно используются
всеми процессами. Это делает эту область
незащищенной от случайной записи.
Минимально необходимый объем
памяти для функционирования Windows 9х
составляет 4 Мб, однако практически при
таком объеме памяти работать невозможно.
Страничный файл
, с помощью
которого реализуется механизм виртуальной
памяти, расположен в каталоге Windows и
имеет переменный размер, изменяемый
при необходимости самой системой. Его
размеры могут быть заданы с помощью
системных средств (Панель управления
→ Система → Быстродействие → Файловая
система), либо заданы в секции файла
SYSTEM.INI – строки с указанием диска и имени
файла:
Pagingfive=c:\PageFile.sys
MinPagingFileSize=65536
(64 Мб)
MaxPagingFileSize=262144
(256 Мб)
Первая и вторая строки определяют
имя файла и его размещение, а две последние
– начальный и предельный размер
страничного файла в Кб.
Минимальный размер файла подкачки
можно получить, запустив программу
SysMon (системный монитор) и, выбрав в
качестве необходимых параметров размер
файла подкачки и объем свободной памяти,
оценить потребности в памяти наиболее
часто используемых приложений.
3.2. Распределение памяти в
Windows NT
Отличия схемы распределения от
Windows 9х сводятся к следующему:
1) более серьезное использование
аппаратных средств защиты памяти,
предусмотренных в микропроцессоре;
2) все системные программные
модули расположены в собственных
виртуальных адресных пространствах и
доступ прикладных программ к ним
невозможен.
Распределение адресного
пространства в Windows NT представлено на
рис. 3.2.
Рис. 3.2. Распределения ОП в Windows
NT
Прикладным программам выделяется
2 Гб локального (собственного) линейного
(неструктурированного) адресного
пространства (первые 64 Кб недоступны).
Они изолированы друг от друга и могут
общаться друг с другом только через
буфер обмена (clipboard), либо через механизмы
DDE (Dynamic Data Exchange – динамический обмен
данными) и OLE (Object Linking and Embedding – связь и
внедрение объектов).
В верхней части 2 Гб-й области
размещается код системных DLL (динамически
связанные библиотеки), выполняющих роль
сервер-процессов. Они проверяют значения
параметров запросов, исполняют запрошенную
функцию и пересылают результаты назад
в адресное пространство вызывающей
программы.
В интервале адресов 2-4 Гб
располагаются системные (низкоуровневые)
компоненты Windows (т.е. самого высокого
уровня защиты от несанкционированного
доступа: ядро, планировщик потоков,
диспетчер памяти).
Для 16-разрядных прикладных
Windows-программ реализуются сеансы WOW
(Windows On Windows) в режиме вытесняющей
многозадачности индивидуально в
собственных адресных пространствах
или совместно в разделяемом адресном
пространстве.
При запуске приложения создаётся
процесс со своей информационной
структурой, в рамках которого запускается
задача. Она может запускать другие
задачи. В результате чего организуется
мультизадачный режим работы.
Управление памятью (выделение,
резервирование, освобождение, подкачка)
производится диспетчером виртуальной
памяти VMM (Virtual Memory Manager). Каждая виртуальная
страница переносится на физическую
страницу − страничный фрейм (page frame),
заполненный в исходном состоянии нулями
(это основное требование стандарта на
системы безопасности уровня С2,
определяющее невозможность использования
их предыдущего содержимого другими
процессами). Место для выгрузки страницы
резервируется в файле подкачки
Pagefile.sys, представляющим собой
зарезервированный блок дискового
пространства.
Вся память Windows NT подразделяется
на зарезервированную
(для динамического
использования процессами при выполнении
задач),выделенную
(для выгрузки
которой резервируется в Pagefile.sys) идоступную
(остальная часть свободной
памяти).
Виртуальная память в Windows
Самая частая причина замедления
работы системы под управлением Windows —
заполнение физической памяти. При этом
Windows начинает так называемую «подкачку»
(paging) — перемещение блоков кода и данных
программ (каждый такой блок называется
страницей — page) из физической памяти на
жесткий диск. Обращение к файлу подкачки
время от времени — нормальное явление,
не ухудшающее производительность
системы, но частые запросы данных из
файла на диске могут заметно снизить
общую скорость работы системы. Эта
проблема становится особенно заметной
при переключении между несколькими
программами, активно использующими
память, на компьютере, который не содержит
достаточного количества физической
памяти. В результате диск почти постоянно
находится в работе, потому что система
пытается «перекачать» данные с
него в память и обратно.
Если общий размер выделенной
памяти превышает общий объем физической
памяти, Windows приходится «перекачивать»
страницы между быстрой оперативной
памятью и гораздо более медленной
виртуальной памятью в файле подкачки,
что приводит к замедлению скорости
системы.
В процессе установки Windows XP файл
подкачки автоматически создается в
корневой папке на том же диске, где
расположены системные файлы Windows. Размер
файла подкачки определяется, исходя из
объема физической памяти в системе. По
умолчанию минимальный размер файла
подкачки в 1,5 раза больше, чем объем
физической памяти, а максимальный размер
— в 3 раза больше. Файл подкачки можно
увидеть в окне Проводника, если включить
режим отображения скрытых и системных
файлов (рис. 3.3).
Рис. 3.3. Включение режима отображения
скрытых и системных файлов
Обычно операционная система
Windows сама устанавливает оптимальный
объем виртуальной памяти и ее хватает
для большинства задач, но если на
компьютере выполняются приложения,
требующие много памяти, то объем
виртуальной памяти можно изменить.
Для этого нужно выполнить
следующую последовательность действий:
1. Войдите в систему под учетной
записью из группы Администраторы и
откройте окно «Панель управления –
Система».
2. На вкладке «Дополнительно»
нажмите кнопку «Параметры» в разделе
«Быстродействие» (рис. 3.4).
3. В диалоговом окне «Параметры
быстродействия» выберите вкладку
«Дополнительно» и нажмите кнопку
«Изменить» (рис. 3.5) для отображения
диалогового окна «Виртуальная память»,
которое показано на рис. 3.6 для WindowsXPи на рис. 3.7 дляWindows7.
Текущие параметры файла подкачки
отражены в поле «Общий размер файла
подкачки на всех дисках».
4. Выберите любой диск из списка
в верхней части диалогового окна, чтобы
настроить параметры этого диска.
Можно изменить перечисленные
ниже параметры:
— Особый размер
. Укажите
значение в полеИсходный размер
для
задания начального размера файла
pagefile.sys на указанном диске (в мегабайтах).
В полеМаксимальный размер
введите
число не меньшее значения в полеИсходный
размер
, но не превышающее 4096 Мбайт (4
Гбайт).
— Размер по выбору системы.
Выберите этот пункт для включения
динамического управления размером
файла подкачки для данного диска. Этот
вариант следует выбирать, если вы не
хотите изменять предлагаемые Windows по
умолчанию параметры.
— Без файла подкачки
. Используйте
для всех дисков, на которых вам не нужен
файл подкачки. Удостоверьтесь, что файл
подкачки есть хотя бы на одном диске.
5. После внесения каких-либо
изменений нажмите Задать
для записи
изменений.
6. Повторите этапы 4 и 5 для прочих
дисков (при необходимости). Нажмите ОК
для закрытия диалогового окна после
завершения работы с ним.
Рис. 3.4. Кнопка «Параметры» для
перехода к просмотру и/или
изменению параметров виртуальной
памяти
Рис. 3.5. Кнопка «Изменить» для
перехода к изменению параметров
виртуальной памяти в WindowsXP(слева) и вWindows7
Рис. 3.6. Окно просмотра и настройки
размера виртуальной памяти
Рис. 3.7. Окно просмотра и настройки
размера виртуальной памяти в Windows7
Если на компьютере установлено
несколько физических дисков, лучше
всего разместить файл подкачки на самом
быстром
, причем предпочтительно, если
системные файлы Windows будут находиться
на другом диске. Еще лучше разделить
файл подкачки на несколькофизических
дисков, поскольку контроллер дисков
может параллельно обрабатывать несколько
запросов на запись и чтение данных.
Не пытайтесь разместить файл
подкачки на несколько логических дисках
одного физического диска!!!
Если в системе есть один жесткий
диск, разбитый на разделы C, D и E, а файл
подкачки распределен на несколько
разделов, то система может даже
замедлиться, поскольку в такой конфигурации
магнитным головкам жесткого диска
приходится считывать данные из нескольких
областей, а не подряд из одной области
диска.
При уменьшении минимального или
максимального размера файла подкачки
и при создании нового файла подкачки
на диске систему необходимо перезагрузить
для того, чтобы изменения вступили в
силу. Увеличение размера файла подкачки
обычно не требует перезагрузки компьютера.
Если у вас очень много физической
памяти, может возникнуть соблазн вовсе
отключить файл подкачки. Не делайте
этого!
!!
Windows XP была разработана так, что
файл подкачки используется для выполнения
некоторых задач ядра, поэтому некоторые
программы третьих фирм могут выдавать
сообщение о нехватке памяти при попытке
полностью отключить виртуальную память.
Windows не использует файл подкачки,
пока он не понадобится, поэтому отключение
виртуальной памяти не приведет к
повышению производительности!!!
Windows может динамически увеличивать
размер файла подкачки при необходимости.
Эта функция работает только при выборе
пункта «Размер по выбору системы
»,
а также при задании максимального
размера, превышающего текущий размер
файла подкачки.
Исходя из опыта работы с предыдущими
версиями Windows некоторые пользователи
стараются создавать файл подкачки
фиксированного объема с равными исходным
и максимальным размерами. Теоретически,
это должно поднимать производительность,
поскольку исключает возможность
фрагментации файла подкачки. Однако
подсистема подкачки разработана таким
образом, что на практике файл занимает
только большие блоки дискового
пространства, что делает фрагментацию
минимальной. Можно заметить небольшое
падение производительности в тот момент,
когда Windows увеличивает размер файла
подкачки, но это однократная операция,
которая никак не влияет на производительность
в среднем.
Контроль использования памяти
в Windows
Самый простой способ узнать,
сколько оперативной памяти используется
в данный момент времени — открыть
Диспетчер задач (Task Manager), нажав
++, и перейти на вкладку
«Быстродействие» (Performance) (рис.3.8).
Подробное описание информации вкладки
«Быстродействие» для WindowsXPпредставлено в табл.
3.1.
Таблица 3.1. Расшифровка данных
Диспетчера задач
Вкладка «Быстродействие» для
Windows7 имеет значимые
нововведения по сравнению с соответствующей
вкладкой Диспетчером задач Windows XP.
Число в графе «Всего» (Total) раздела
«Физическая память» (Physical Memory) указывает
на общий объем оперативной памяти для
данной системы. В графе «Кэшировано»
(Cached) указано количество физической
памяти, которая недавно использовалась
системными ресурсами. Она остается в
кэше на случай, если снова понадобится
системе, но доступна для других процессов.
В новой графе «Доступно» (Available) указывается
количество неиспользуемой в данный
момент физической памяти, а в графе
«Свободно» (Free) — количество памяти,
которая используется кэшем, но не
содержит полезной информации.
В разделе «Память ядра» (Kernel
Memory) содержатся две графы — «Выгружаемая»
(Paged) и «Невыгружаемая» (Nonpaged). В сумме
они указывают, сколько памяти использует
ядро. Выгружаемая — это виртуальная
память, а невыгружаемая — физическая.
В разделе «Система» (System) появились
графы «Дескрипторов» (Handles) и «Потоков»
(Threads), связанные с составными компонентами
процессов. В графе «Дескрипторов»
указывается количество идентификаторов
объектов (дескрипторов), которые
используются запущенными в данный
момент процессами. В графе «Потоков»
указано число подпроцессов, запущенных
в рамках более крупных процессов. Цифра
в графе «Процессов» (Processes), естественно,
указывает на общее количество запущенных
процессов, которые можно увидеть на
вкладке «Процессы».
В графе «Время работы» (Up Time)
указано, сколько времени прошло с
последнего запуска компьютера. В графе
«Выделено» (Commit) содержится информация
о файле подкачки. Первая цифра указывает
на общий объем используемой в данный
момент физической и виртуальной памяти,
а вторая — на общий объем памяти для
данного компьютера в принципе.
Еще более подробную информацию
можно получить, нажав кнопку «Монитор
ресурсов» и выбрав вкладку «Память»
(рис. 3.9).
Рис. 3.9. Вкладка «Память» окна
монитора ресурсов Windows7
На вкладке «Память» есть таблица
«Процессы», в которой перечислены все
запущенные процессы, а сведения об
используемой памяти для каждого процесса
разбиты на несколько категорий
(рис.3.10).
Рис. 3.10. Таблица «Процессы»
В колонке «Образ
» указывается
имя исполняемого файла процесса.
Процессы, запущенные приложениями,
узнать очень легко — например, процесс
«Winword.exe» со всей очевидностью
принадлежит текстовому редакторуWord.
Процессы с именем «svchost.exe» представляют
различные службы операционной системы.
Название службы указывается в скобках
рядом с именем процесса.
В колонке «ИД процесса
»
указывается номер процесса — уникальное
сочетание цифр, позволяющее идентифицировать
запущенный процесс.
В столбце «Завершено
»
указывается объем виртуальной памяти
в килобайтах, зарезервированный системой
для данного процесса. Сюда входит и
используемая физическая память, и
сохраненные в файле подкачки страницы.
В графе «Рабочий набор
»
указывается объем физической памяти в
килобайтах, используемой процессом в
данный момент времени. Рабочий набор
складывается из общей и частной памяти.
В колонке «Общий
» указан
объем физической памяти в килобайтах,
которую данный процесс использует
совместно с другими. Использование
одного сегмента памяти или страницы
подкачки для родственных процессов
позволяет сэкономить место в памяти.
При этом физически сохраняется только
одна копия страницы, которая затем
сопоставляется с виртуальным адресным
пространством других процессов, которые
к ней обращаются. Например, все процессы,
инициированные системными библиотеками
DLL — Ntdll, Kernel32, Gdi32 и User32 — используют
общую память.
В столбце «Частный
» указывается
объем физической памяти в килобайтах,
используемой исключительно данным
процессом. Именно это значение позволяет
определить, сколько памяти нужно тому
или иному приложению для работы.
В графе «Ошибок отсутствия
страницы в памяти/сек.
» указано среднее
за последнюю минуту количество ошибок
отсутствия страницы в памяти в секунду.
Если процесс пытается использовать
больше физической памяти, чем доступно
в данный момент времени, система
записывает часть данных из памяти на
диск — в файл подкачки. Последующее
обращение к данным, сохраненным на диск,
и называется ошибкой отсутствия страницы
в памяти.
При запуске приложений и работе
с файлами диспетчер памяти отслеживает
объем рабочего набора для каждого
процесса и фиксирует запросы на
дополнительные ресурсы памяти. По мере
увеличения рабочего набора процесса,
диспетчер соотносит эти запросы с
потребностями ядра и других процессов.
Если доступного адресного пространства
недостаточно, диспетчер уменьшает объем
рабочего набора, сохраняя данные из
памяти на диск.
В дальнейшем при чтении этих
данных с диска возникает ошибка отсутствия
страницы в памяти. Это вполне нормально,
но если ошибки происходят одновременно
для разных процессов, системе требуется
дополнительное время для чтения данных
с диска. Слишком частые ошибки отсутствия
страницы в памяти, соответственно,
снижают быстродействие системы. Это
проявляется в неожиданном замедлении
работы всех приложений, которое затем
также неожиданно прекращается. Замедление
связано с активным перераспределением
данных между физической памятью и
подкачкой.
Отсюда следует вывод: если ошибки
отсутствия страницы в памяти для того
или иного процесса происходят слишком
часто и притом регулярно, компьютеру
не хватает физической памяти.
Чтобы было удобнее наблюдать за
процессами, вызывающими частые ошибки
отсутствия страницы в памяти, можно
отметить их флажками. При этом выбранные
процессы переместятся наверх списка,
а в графике ошибок отсутствия страницы
в памяти будут представлены оранжевой
кривой.
Стоит учитывать, что распределение
памяти зависит от целого ряда других
факторов, и мониторинг ошибок отсутствия
страницы в памяти — не лучший и не
единственный способ выявления проблем.
Тем не менее, он может послужить неплохой
отправной точкой для наблюдения.
В таблице «Процессы» приводятся
детальные сведения о распределении
памяти между отдельными процессами, а
таблица «Физическая память» дает общую
картину использования RAM. Ее ключевой
компонент — уникальная гистограмма,
показанная на рис. 3.11.
Рисунок
3.11. Гистограмма в таблице «Физическая
память» позволяет составить общее
представление о распределении памяти
в Windows 7
Каждая секция гистограммы
обозначена собственным цветом и
представляет определенную группу
страниц памяти. По мере использования
системы, диспетчер памяти в фоновом
режиме перемещает данные между этими
группами, поддерживая тонкий баланс
между физической и виртуальной памятью
для обеспечения эффективной работы
всех приложений. Рассмотрим гистограмму
поподробнее.
Слева расположена секция
«Зарезервированное оборудование
»,
обозначенная серым цветом: это память,
выделенная на нужды подключенного
оборудования, которую оно использует
для взаимодействия с операционной
системой. Зарезервированная для
оборудования память заблокирована и
недоступна диспетчеру памяти. Обычно
объем памяти, выделенной оборудованию,
составляет от 10 до 70 Мбайт, однако этот
показатель зависит от конкретной
конфигурации системы и в некоторых
случаях может достигать нескольких
сотен мегабайт.
К компонентам, влияющим на объем
зарезервированной памяти, относятся:
Компоненты материнской платы
— например, усовершенствованный
программируемый контроллер прерываний
ввода/вывода (APIC);
Звуковые карты и другие
устройства, осуществляющие ввод/вывод
с отображением на память;
Шина PCI Express (PCIe);
Видеокарты;
Различные наборы микросхем;
Флеш-накопители.
Секция «Используется
»,
обозначенная зеленым цветом, представляет
количество памяти, используемой системой,
драйверами и запущенными процессами.
Количество используемой памяти
рассчитывается, как значение «Всего
»
за вычетом суммы показателей «Изменено
»,
«Ожидание
» и «Свободно
». В свою
очередь, значение «Всего
» — это
показатель «Установлено
» за вычетом
показателя «Зарезервированное
оборудование
».
Вытесняющие/невытесняющие алгоритмы.
В случае вытесняющего алгоритма операционная система в любой момент времени может прервать выполнение текущего потока и переключить процессор на другой поток. В невытесняющих алгоритмах поток, которому предоставлен процессор, только сам решает, когда передать управление операционной системе.
Алгоритмы с квантованием.
Каждому потоку предоставляется квант времени, в течение которого поток может выполняться на процессоре. По истечении кванта операционная система переключает процессор на следующий поток в очереди. Квант обычно равен целому числу интервалов системного таймера 1 .
Алгоритмы с приоритетами.
Каждому потоку назначается приоритет (priority) – целое число, обозначающее степень привилегированности потока. Операционная система при наличии нескольких готовых к выполнению потоков выбирает из них поток с наибольшим приоритетом.
В Windows реализован смешанный алгоритм планирования – вытесняющий, на основе квантования и приоритетов.
- Тип многозадачности для приложения DOS
- Гарантии обслуживания
- Планирование процессов переднего плана
- Назначение файла подкачки
- Процессы Р1, Р2, Р3 выделяют 100, 20, 80 Мб памяти. В системе 128Мб ОП. Каков размер занятой памяти в файле подкачки. Какой размер файла подкачки.
- Что такое «страничная ошибка»?
Прерывание 14 —
Страничная ошибка
(#PF): Intel386 …
Генерируется, если страничный механизм активизирован (CR0.PG = 1) и при трансляции линейного адреса в физический возникает одна из следующих ситуаций:
- элемент таблицы страниц или каталога страниц, используемый при трансляции адреса, имеет нулевой бит присутствия
, т.е. нужная таблица страниц или страница не присутствует в физической памяти; - процедура не располагает уровнем привилегий
, достаточным для доступа к выбранной странице или пытается произвести запись в страницу, защищенную от записи для текущего уровня привилегий.
Обработчик страничной ошибки получает информацию о ее причине из двух источников: кода ошибки, помещаемого в стек, и содержимого регистра CR2, который содержит линейный адрес, вызвавший ошибку. Код страничной ошибки имеет специальный формат (рис. 3.7.).
Прерванная программа после устранения причин, вызвавших страничную ошибку (например, загризки страницы в физическую память), может быть продолжена без каких-либо дополнительных корректировок.
Если страничная ошибка была вызвана в связи с нарушением привилегий страничной защиты, то бит доступа (A) в соответствующем элементе каталога страниц устанавливается. Поведение бита доступа в соответствующем элементе таблиц страниц для этого случая не регламентируется в процессорах Intel и может быть разным в различных моделях.
- Высокая интенсивность ошибок страниц говорит о:
Ненадежности программы
Ненадежности оперативной памяти
Иное: пояснить
Графа «Ошибок отсутствия страницы в памяти/сек.»
В графе «Ошибок отсутствия страницы в памяти/сек.» (Hard Faults/sec) указано среднее за последнюю минуту количество ошибок отсутствия страницы в памяти в секунду. Если процесс пытается использовать больше физической памяти, чем доступно в данный момент времени, система записывает часть данных из памяти на диск — в файл подкачки. Последующее обращение к данным, сохраненным на диск, и называется ошибкой отсутствия страницы в памяти.
О чем говорят ошибки отсутствия страницы в памяти
Теперь, когда вы представляете, какие сведения собраны в таблице «Процессы», давайте посмотрим, как с их помощью следить за распределением памяти. При запуске приложений и работе с файлами диспетчер памяти отслеживает объем рабочего набора для каждого процесса и фиксирует запросы на дополнительные ресурсы памяти. По мере увеличения рабочего набора процесса, диспетчер соотносит эти запросы с потребностями ядра и других процессов. Если доступного адресного пространства недостаточно, диспетчер уменьшает объем рабочего набора, сохраняя данные из памяти на диск.
В дальнейшем при чтении этих данных с диска возникает ошибка отсутствия страницы в памяти. Это вполне нормально, но если ошибки происходят одновременно для разных процессов, системе требуется дополнительное время для чтения данных с диска. Слишком частые ошибки отсутствия страницы в памяти, соответственно, снижают быстродействие системы
. Вам наверняка доводилось наблюдать неожиданное замедление работы всех приложений, которое затем также неожиданно прекращалось. Почти наверняка это замедление было связано с активным перераспределением данных между физической памятью и подкачкой.
Отсюда следует вывод: если ошибки отсутствия страницы в памяти для того или иного процесса происходят слишком часто и притом регулярно, компьютеру не хватает физической памяти.
Чтобы было удобнее наблюдать за процессами, вызывающими частые ошибки отсутствия страницы в памяти, можно отметить их флажками. При этом выбранные процессы переместятся наверх списка, а в графике ошибок отсутствия страницы в памяти будут представлены оранжевой кривой.
Стоит учитывать, что распределение памяти зависит от целого ряда других факторов, и мониторинг ошибок отсутствия страницы в памяти — не лучший и не единственный способ выявления проблем. Тем не менее, он может послужить неплохой отправной точкой для наблюдения.
- Как формируется приоритет потока в Windows
Приоритеты
В ОС Windows реализовано вытесняющее приоритетное планирование, когда каждому потоку присваивается определенное числовое значение — приоритет, в соответствии с которым ему выделяется процессор. Потоки с одинаковыми приоритетами планируются согласно алгоритму Round Robin (карусель). Важным достоинством системы является возможность вытеснения потоков, работающих в режиме ядра — код исполнительной системы полностью реентерабелен. Не вытесняются лишь потоки, удерживающие спин-блокировку (см. «Синхронизация потоков»). Поэтому спин-блокировки используются с большой осторожностью и устанавливаются на минимальное время.
В системе предусмотрено 32 уровня приоритетов. Шестнадцать значений приоритетов (16-31) соответствуют группе приоритетов реального времени, пятнадцать значений (1-15) предназначены для обычных потоков, и значение 0 зарезервировано для системного потока обнуления страниц (см. рис. 6.2).
Рис. 6.2.
Приоритеты потоков
Чтобы избавить пользователя от необходимости запоминать числовые значения приоритетов и иметь возможность модифицировать планировщик, разработчики ввели в систему слой абстрагирования приоритетов
. Например, класс приоритета для всех потоков конкретного процесса можно задать с помощью набора констант-параметров функции SetPriorityClass, которые могут иметь следующие значения:
- реального времени (REALTIME_PRIORITY_CLASS) — 24
- высокий (HIGH_PRIORITY_CLASS) — 13
- выше нормы (ABOVE_NORMAL_PRIORITY_CLASS) 10
- нормальный (NORMAL_PRIORITY_CLASS) — 8
- ниже нормы (BELOW_NORMAL_PRIORITY_CLASS) — 6
- и неработающий (IDLE_PRIORITY_CLASS) 4
Относительный приоритет потока устанавливается аналогичными параметрами функции SetThreadPriority:
Совокупность из шести классов приоритетов процессов и семи классов приоритетов потоков образует 42 возможные комбинации и позволяет сформировать так называемый базовый приоритет потока
Базовый приоритет процесса и первичного потока по умолчанию равен значению из середины диапазонов приоритетов процессов (24, 13, 10, 8, 6 или 4
). Смена приоритета процесса влечет за собой смену приоритетов всех его потоков, при этом их относительные приоритеты остаются без изменений.
Приоритеты с 16 по 31 в действительности приоритетами реального времени не являются, поскольку в рамках поддержки мягкого реального времени, которая реализована в ОС Windows, никаких гарантий относительно сроков выполнения потоков не дается. Это просто более высокие приоритеты, которые зарезервированы для системных потоков и тех потоков, которым такой приоритет дает пользователь с административными правами. Тем не менее, наличие приоритетов реального времени, а также вытесняемость кода ядра, локализация страниц памяти (см. «Функционирование менеджера памяти») и ряд дополнительных возможностей — все это позволяет выполнять в среде ОС Windows приложения мягкого реального времени, например, мультимедийные. Системный поток с нулевым приоритетом занимается обнулением страниц памяти. Обычные пользовательские потоки могут иметь приоритеты от 1 до 15.
Похожая информация.
ы подключили новое устройство, а оно не спешит работать, или старое устройство перестало функционировать, или делает свою работу некорректно. Что же делать в этих случаях? Переустанавливать всё? Хлопотно, да и не всегда в этом есть необходимость. Как же узнать в чём причина и как её устранить? Очень просто. Дело в том, что в ОС семейства Windows,
и не только, имеется, некий
Диспетчер устройств,
на самом деле очень нужный и полезный менеджер, если его можно так назвать. Вот он то, нам и поможет выяснить в чём причина неполадки, а моя шпаргалка — устранить проблему. Итак, в выше упомянутом
Диспетчере устройств
остаються следы ошибок в работе устройств в виде кодов. Зная код ошибки, нетрудно установить причину неполадки. Для непосвящённых, коды — это всего лишь непонятные и ничего не говорящие цифры. Но знающему пользователю, они могут сказать о многом. Постараюсь, насколько мне это удасться, пролить свет на эту тему.
Для просмотра ошибок устройств, нам прежде всего необходимо войти в сам Диспетчер устройств. Делается это так. Войдите в
Панель управления
из меню
Пуск (
можно,
Мой
компьютер
, правой клавишей —
Свойства
—
Диспетчер устройств,
а можно и через задание команды в
выполнить
, но зачем всё усложнять). Если мы входим через
Панель
управления
, то путь таков:
Система — Оборудование — Диспетчерн устройств
. Выберем, войдя в меню
Диспетчер устройств
, тип интересующего нас устройства (клавиатура, принтер, модем и т.д.), щёлкнем на нём дважды, в результате увидим входящие в этот тип устройства. Выбирем нужное нам устройство и дважды щёлкнем на нём. Смотрим графу на вкладке О
бщие, Состояние устройства.
Если имеется проблема с работой устройства, то она будет отображена здесь в виде кода ошибки. Итак мы видим цифры и числа. Что же они обозначают. Ниже я привожу полный список ошибок, с кратким описанием ошибки и возможных способах устранения. Красным цветом выделен код ошибки, синим её описание и чёрным устранение.
Код 1
Проблема с настройкой устройства, не правильные настройки или отсутствует драйвер.
Нажмите кнопку
Обновить драйвер
, для запуска мастера
Обновление оборудования
. Если вообще нет драйвера — установите его.
Код 3
Повреждён драйвер устройства, как вариант не хватает оперативной памяти для корректной работы устройства.
1.
Удалим повреждённый драйвер и установим новый. Для этого: Свойства — Драйвер — Удалить, далее следуем указаниям мастера. Перезагрузка. Открываем опять
Диспетчер устройств
—
Действие
—
Обновить конфигурацию оборудования
и следуем указаниям мастера. 2. Если проблема в нехватке виртуальной памяти, закроем работающие приложения, что бы разгрузить память. Что бы проверить состояние памяти нам нужно попасть в
Диспетчер задач
, для этого жмём сочетание клавиш
Ctrl+Shift+Esc.
Настройки виртуальной памяти мы можем посмотреть ещё щёлкнув правой клавишей
Мой компьютер
—
Свойства — Дополнительно — Быстродействие — Настройки (Параметры)
. Вы можете попробовать увеличить файл подкачки (как это делается, я описывал в одной из предыдущих статей моего блога ), но это далеко не радикальная мера. Придётся вам увеличивать оперативную память. Как это делается — отдельная тема, выходящая за рамки этого поста.
Код 10
В разделе реестра имеется соответствующий устройству параметр
FailReasonString,
значение этого параметра и отображается в данных ошибки, то есть, если параметра, как такового нет, то появляется код ошибки, проще говоря — запуск устройства не возможен.
Обновите драйвер, как указано выше. Или установите более новый.
Код 12
Нет запаса ресурсов, необходимых для этого устройства.
Отключите другие работающие устройства, хотя бы одно, для этого воспользуйтесь мастером устранения неполадок, который, если вы будете следовать его указаниям, отключит конфликтное устройство. (В кратце напомню: Свойства — Общие — Устранение неполадок.)
Код 14
Требует перезагрузки ПК для работы этого устройства.
Код 16
Невозможно выявить ресурсы, которые необходимы для работы устройства, устройство настроено не полностью.
Нужно назначить устройству дополнительные ресурсы. Но это можно сделать без проблем если устройство относится к
Plug and Play.
Свойства — Ресурсы.
Если в списке ресурсов есть ресурс с знаком?, выбираем его, чтобы назначить выбранному устройству. Если ресурс не возможно изменить, жмём
Изменить параметры
, если эта функция недоступна, снимаем галочку с
Автоматическая настройка
Код 18
Переустановите драйвер для устройства.
Пробуем обновить драйвер или удалить и сделать, как в примере с
кодом 3.
Код 19
Недостаточные сведения в реестре о настройках устройства, либо настройки повреждены.
Запустите
Мастер устранения неполадок
и следуйте его указаниям, не поможет — переустановите устройство, как было сказано выше. (код 3). Либо, если не поможет, загрузите
Последнюю удачную конфигурацию.
Если и это не поможет — вам нужна помощь специалиста, так, как необходимо редактировать системный реестр. Неимея знаний и опыта, самостоятельно, там вам делать нечего, любой сисадмин вам это подтвердит. Знающий и умеющий, сам знает, как это сделать, без меня. А неопытному, лучше и не пробовать. Реестр — сердце операционной системы и проводить операции на нём должен только опытный специалист, или под его руководством. Ни в коей мере не хочу ни кого обидеть, но если вы не работали с системным реестром и если вам дорог ваш компьютер, мой совет — забудьте туда дорогу. Я пишу не для профессионалов, им это не нужно, а для среднего пользователя. Конечно, я могу написать, как и что там делать, но это будет объяснение на пальцах и если вы, в результате малейшей ошибки, повредите свой компьютер, буду виноват я. Мне это совсем не нужно, да и вам то же.
Код 21 Устройство удаляется из системы, то есть операционная система пытается удалить устройство, но процесс ещё не завершён.
Выдержите паузу в несколько секунд и нажмите клавишу
Код 22 Устройство отключено.
Необходимо включить устройство.
Действие — Включить
и следуем дальнейшим инструкциям.
Код 24 Устройства нет или неправильно установлено, сбой в работе драйвера, может быть устройство было подготовлено к удалению.
Удалите устройство и установите заново.
Код 28 Нет драйвера.
Установите драйвер. Для этого нужно Обновить драйвер, действия, как в инструкции к Коду 1.
Код 29
Отключено устройство
. Необходимо разрешить работу устройства в
настройках
BIOS,
изучите инструкции к использованию устройства.
Код 31
Системе не удалось загрузить драйверы к этому устройству
. Обновите драйверы, как описывалось выше.
Код 32
Драйвер к этому устройству отключен в системном реестре
. Удалите и по-новой установите драйвер (описывалось выше)
Код 33
Операционная система не может определить ресурсы для данного
устройства
. Настройте устройство или замените его.
Код 34
Операционная система не может определить настройки
устройства
. Изучите прилагаемую документацию к оборудованию и настройте конфигурацию вручную на вкладке Ресурсы.
Код 35
Микропрограмма ПК неимеет нужных сведений для правильной
работы устройства
. Необходимо обновить
BIOS.
За инструкциями, как это сделать обратитесь к поставщику, а лучше воспользоваться услугами опытного мастера.
Код 36
Для работы устройства требуется прерывание
PCI,
а устройство настроено на прерывание
ISA,
или наоборот
. Необходимо изменить настройки
BIOS,
обратитесь к опытному мастеру.
Код 37
Операционная система неопознаёт драйвер к этому устройству
. Переустановите драйвер (описывалось выше).
Код 38
ОС не может загрузить драйвер для устройства, так как,
предыдущая версия драйвера осталась в памяти
. Необходимо перезагрузить ПК. Запустите мастер Устранения неполадок, если он не запустился (Свойства — Общие — Устранение неполадок) и следуйте указаниям мастера. После обязательная перезагрузка.
Код 39
ОС не может загрузить драйвер устройства. Драйвер повреждён
или его нет вовсе
. Переустановите драйвер, как было описано выше.
Код 40
Нет доступа к оборудованию, так, как нет информации в системном реестре или информация содержит ошибку
. Переустановите драйвер.
Код 41
Необнаружено устройство
. Запустите мастер Устранения неполадок (описано выше), если не помогло обновите конфигурацию оборудования (см. выше) или обновите драйвер. Если нет, установите более новую версию драйвера.
Код 42
В системе уже имеется такой драйвер. То есть имеются два разных устройства с одинаковым именем, возможно из-за ошибки
. Перезагрузите ПК.
Код 43
Остановка работы устройства из-за возникших проблем в его работе
. Запустите мастер Устранения неполадок и следуйте его указаниям.
Код 44
Приложение или служба остановили работу устройства
. Перезагрузите ПК.
Код 45
Устройство не подключено
. Подключите устройство.
Код 46
Такая ошибка появляется, если операционная система завершает свою работу. Ни чего не нужно делать, при следующем запуске ОС всё будет работать.
Код 47 Устройство было подготовлено для безопасного удаления, но ещё не удалено (например флеш)
. Извлеките устройство, затем подключите снова, перезагрузите ПК.
Код 48
Устройство, вернее его програмное обеспечение, заблокировано
. Обновите драйвер, или установите новый.
Код 49
Устройство не может быть запущено, так, как имеет большой объём системного куста реестра, который превышает допустимые параметры реестра
. Удалите из реестра устройства которые не используются. Можно сделать так: Диспетчер устройств — Вид — Показать скрытые устройства. Здесь вы увидите скрытые устройства, которые не подключены к вашему ПК. Выберите те устройства которые хотите удалить, кликнете Свойства для устройства — Драйвер — Удалить, далее следуйте указаниям мастера и в завершении перезагрузка ПК.
Пособие по удалению любых вирусов с ПК собственноручно. Все способы удаления вирусов реально работающие и проверенные на практике, пошаговая инструкция с илюстрациями — просто и доступно даже для школьника + видеоуроки + программа ultraiso
для создания загрузчиков+ полезные ссылки на инструменты в борьбе с вирусами. Скачать архив
Распределение
памяти в Windows9xи вWindowsNT.
Монитор ресурсов Windows 7. Изучение пунктов
и вкладок, связанных с памятью.
Использование монитора ресурсов Windows
7 для наблюдения за распределением
памяти. Увеличение объема файла подкачки
(виртуальной памяти). Проверка памяти
средствами Windows.
3.1. Распределение памяти в
Windows 9x
ОС Windows 9x — это 32-разрядные
многопотоковые ОС с вытесняющей
многозадачностью и графическим
пользовательским интерфейсом. Для своей
загрузки они используют MS-DOS 7.0, которая
обеспечивает два режима работы процессора
– реальный (в файле MSDOS.SYS в секции
прописано BootGUI=0) и защищённый
(BootGUI=1). Защищённый режим устанавливается
непосредственно перед загрузкой Windows
9x, в результате чего процессор начинает
управлять памятью с использованием
страничного механизма преобразования
виртуальных адресов в физические.
Область виртуального адресного
пространства состоит из 4-х килобайтных
страниц, которые размещаются в оперативной
памяти или на диске.
Младшие адреса виртуального
адресного пространства используются
совместно всеми процессами для обеспечения
совместимости с драйверами устройств
реального времени, резидентными
программами Windows и др. Это с одной стороны
удобно, но, с другой, снижает надёжность
(одно из основных качеств ОС), т.к. любой
процесс может запортить компоненты,
расположенные по этим адресам.
Каждая прикладная 32-разрядная
Windows-программа выполняется в своём
адресном пространстве, однако доступ
к нужным адресам возможен, т.е. организация
виртуальных адресов не использует всех
аппаратных средств защиты, заложенных
в микропроцессор. 16-разрядные программы
разделяют общее адресное пространство
и также уязвимы друг перед другом. Модель
памяти Windows 9x представлена на рис.3.1.
Рис. 3.1. Распределения ОП в Windows
9x
Нижние 64 Кб ОП недоступны
32-разрядным программам, но 16-разрядные
программы могут записывать сюда свои
данные. Адреса ниже 4 Мб отображаются в
адресное пространство каждой прикладной
программы и совместно используются
всеми процессами. Это делает эту область
незащищенной от случайной записи.
Минимально необходимый объем
памяти для функционирования Windows 9х
составляет 4 Мб, однако практически при
таком объеме памяти работать невозможно.
Страничный файл
, с помощью
которого реализуется механизм виртуальной
памяти, расположен в каталоге Windows и
имеет переменный размер, изменяемый
при необходимости самой системой. Его
размеры могут быть заданы с помощью
системных средств (Панель управления
→ Система → Быстродействие → Файловая
система), либо заданы в секции файла
SYSTEM.INI – строки с указанием диска и имени
файла:
Pagingfive=c:\PageFile.sys
MinPagingFileSize=65536
(64 Мб)
MaxPagingFileSize=262144
(256 Мб)
Первая и вторая строки определяют
имя файла и его размещение, а две последние
– начальный и предельный размер
страничного файла в Кб.
Минимальный размер файла подкачки
можно получить, запустив программу
SysMon (системный монитор) и, выбрав в
качестве необходимых параметров размер
файла подкачки и объем свободной памяти,
оценить потребности в памяти наиболее
часто используемых приложений.
3.2. Распределение памяти в
Windows NT
Отличия схемы распределения от
Windows 9х сводятся к следующему:
1) более серьезное использование
аппаратных средств защиты памяти,
предусмотренных в микропроцессоре;
2) все системные программные
модули расположены в собственных
виртуальных адресных пространствах и
доступ прикладных программ к ним
невозможен.
Распределение адресного
пространства в Windows NT представлено на
рис. 3.2.
Рис. 3.2. Распределения ОП в Windows
NT
Прикладным программам выделяется
2 Гб локального (собственного) линейного
(неструктурированного) адресного
пространства (первые 64 Кб недоступны).
Они изолированы друг от друга и могут
общаться друг с другом только через
буфер обмена (clipboard), либо через механизмы
DDE (Dynamic Data Exchange – динамический обмен
данными) и OLE (Object Linking and Embedding – связь и
внедрение объектов).
В верхней части 2 Гб-й области
размещается код системных DLL (динамически
связанные библиотеки), выполняющих роль
сервер-процессов. Они проверяют значения
параметров запросов, исполняют запрошенную
функцию и пересылают результаты назад
в адресное пространство вызывающей
программы.
В интервале адресов 2-4 Гб
располагаются системные (низкоуровневые)
компоненты Windows (т.е. самого высокого
уровня защиты от несанкционированного
доступа: ядро, планировщик потоков,
диспетчер памяти).
Для 16-разрядных прикладных
Windows-программ реализуются сеансы WOW
(Windows On Windows) в режиме вытесняющей
многозадачности индивидуально в
собственных адресных пространствах
или совместно в разделяемом адресном
пространстве.
При запуске приложения создаётся
процесс со своей информационной
структурой, в рамках которого запускается
задача. Она может запускать другие
задачи. В результате чего организуется
мультизадачный режим работы.
Управление памятью (выделение,
резервирование, освобождение, подкачка)
производится диспетчером виртуальной
памяти VMM (Virtual Memory Manager). Каждая виртуальная
страница переносится на физическую
страницу − страничный фрейм (page frame),
заполненный в исходном состоянии нулями
(это основное требование стандарта на
системы безопасности уровня С2,
определяющее невозможность использования
их предыдущего содержимого другими
процессами). Место для выгрузки страницы
резервируется в файле подкачки
Pagefile.sys, представляющим собой
зарезервированный блок дискового
пространства.
Вся память Windows NT подразделяется
на зарезервированную
(для динамического
использования процессами при выполнении
задач),выделенную
(для выгрузки
которой резервируется в Pagefile.sys) идоступную
(остальная часть свободной
памяти).
Виртуальная память в Windows
Самая частая причина замедления
работы системы под управлением Windows —
заполнение физической памяти. При этом
Windows начинает так называемую «подкачку»
(paging) — перемещение блоков кода и данных
программ (каждый такой блок называется
страницей — page) из физической памяти на
жесткий диск. Обращение к файлу подкачки
время от времени — нормальное явление,
не ухудшающее производительность
системы, но частые запросы данных из
файла на диске могут заметно снизить
общую скорость работы системы. Эта
проблема становится особенно заметной
при переключении между несколькими
программами, активно использующими
память, на компьютере, который не содержит
достаточного количества физической
памяти. В результате диск почти постоянно
находится в работе, потому что система
пытается «перекачать» данные с
него в память и обратно.
Если общий размер выделенной
памяти превышает общий объем физической
памяти, Windows приходится «перекачивать»
страницы между быстрой оперативной
памятью и гораздо более медленной
виртуальной памятью в файле подкачки,
что приводит к замедлению скорости
системы.
В процессе установки Windows XP файл
подкачки автоматически создается в
корневой папке на том же диске, где
расположены системные файлы Windows. Размер
файла подкачки определяется, исходя из
объема физической памяти в системе. По
умолчанию минимальный размер файла
подкачки в 1,5 раза больше, чем объем
физической памяти, а максимальный размер
— в 3 раза больше. Файл подкачки можно
увидеть в окне Проводника, если включить
режим отображения скрытых и системных
файлов (рис. 3.3).
Рис. 3.3. Включение режима отображения
скрытых и системных файлов
Обычно операционная система
Windows сама устанавливает оптимальный
объем виртуальной памяти и ее хватает
для большинства задач, но если на
компьютере выполняются приложения,
требующие много памяти, то объем
виртуальной памяти можно изменить.
Для этого нужно выполнить
следующую последовательность действий:
1. Войдите в систему под учетной
записью из группы Администраторы и
откройте окно «Панель управления –
Система».
2. На вкладке «Дополнительно»
нажмите кнопку «Параметры» в разделе
«Быстродействие» (рис. 3.4).
3. В диалоговом окне «Параметры
быстродействия» выберите вкладку
«Дополнительно» и нажмите кнопку
«Изменить» (рис. 3.5) для отображения
диалогового окна «Виртуальная память»,
которое показано на рис. 3.6 для WindowsXPи на рис. 3.7 дляWindows7.
Текущие параметры файла подкачки
отражены в поле «Общий размер файла
подкачки на всех дисках».
4. Выберите любой диск из списка
в верхней части диалогового окна, чтобы
настроить параметры этого диска.
Можно изменить перечисленные
ниже параметры:
— Особый размер
. Укажите
значение в полеИсходный размер
для
задания начального размера файла
pagefile.sys на указанном диске (в мегабайтах).
В полеМаксимальный размер
введите
число не меньшее значения в полеИсходный
размер
, но не превышающее 4096 Мбайт (4
Гбайт).
— Размер по выбору системы.
Выберите этот пункт для включения
динамического управления размером
файла подкачки для данного диска. Этот
вариант следует выбирать, если вы не
хотите изменять предлагаемые Windows по
умолчанию параметры.
— Без файла подкачки
. Используйте
для всех дисков, на которых вам не нужен
файл подкачки. Удостоверьтесь, что файл
подкачки есть хотя бы на одном диске.
5. После внесения каких-либо
изменений нажмите Задать
для записи
изменений.
6. Повторите этапы 4 и 5 для прочих
дисков (при необходимости). Нажмите ОК
для закрытия диалогового окна после
завершения работы с ним.
Рис. 3.4. Кнопка «Параметры» для
перехода к просмотру и/или
изменению параметров виртуальной
памяти
Рис. 3.5. Кнопка «Изменить» для
перехода к изменению параметров
виртуальной памяти в WindowsXP(слева) и вWindows7
Рис. 3.6. Окно просмотра и настройки
размера виртуальной памяти
Рис. 3.7. Окно просмотра и настройки
размера виртуальной памяти в Windows7
Если на компьютере установлено
несколько физических дисков, лучше
всего разместить файл подкачки на самом
быстром
, причем предпочтительно, если
системные файлы Windows будут находиться
на другом диске. Еще лучше разделить
файл подкачки на несколькофизических
дисков, поскольку контроллер дисков
может параллельно обрабатывать несколько
запросов на запись и чтение данных.
Не пытайтесь разместить файл
подкачки на несколько логических дисках
одного физического диска!!!
Если в системе есть один жесткий
диск, разбитый на разделы C, D и E, а файл
подкачки распределен на несколько
разделов, то система может даже
замедлиться, поскольку в такой конфигурации
магнитным головкам жесткого диска
приходится считывать данные из нескольких
областей, а не подряд из одной области
диска.
При уменьшении минимального или
максимального размера файла подкачки
и при создании нового файла подкачки
на диске систему необходимо перезагрузить
для того, чтобы изменения вступили в
силу. Увеличение размера файла подкачки
обычно не требует перезагрузки компьютера.
Если у вас очень много физической
памяти, может возникнуть соблазн вовсе
отключить файл подкачки. Не делайте
этого!
!!
Windows XP была разработана так, что
файл подкачки используется для выполнения
некоторых задач ядра, поэтому некоторые
программы третьих фирм могут выдавать
сообщение о нехватке памяти при попытке
полностью отключить виртуальную память.
Windows не использует файл подкачки,
пока он не понадобится, поэтому отключение
виртуальной памяти не приведет к
повышению производительности!!!
Windows может динамически увеличивать
размер файла подкачки при необходимости.
Эта функция работает только при выборе
пункта «Размер по выбору системы
»,
а также при задании максимального
размера, превышающего текущий размер
файла подкачки.
Исходя из опыта работы с предыдущими
версиями Windows некоторые пользователи
стараются создавать файл подкачки
фиксированного объема с равными исходным
и максимальным размерами. Теоретически,
это должно поднимать производительность,
поскольку исключает возможность
фрагментации файла подкачки. Однако
подсистема подкачки разработана таким
образом, что на практике файл занимает
только большие блоки дискового
пространства, что делает фрагментацию
минимальной. Можно заметить небольшое
падение производительности в тот момент,
когда Windows увеличивает размер файла
подкачки, но это однократная операция,
которая никак не влияет на производительность
в среднем.
Контроль использования памяти
в Windows
Самый простой способ узнать,
сколько оперативной памяти используется
в данный момент времени — открыть
Диспетчер задач (Task Manager), нажав
++, и перейти на вкладку
«Быстродействие» (Performance) (рис.3.8).
Подробное описание информации вкладки
«Быстродействие» для WindowsXPпредставлено в табл.
3.1.
Таблица 3.1. Расшифровка данных
Диспетчера задач
Вкладка «Быстродействие» для
Windows7 имеет значимые
нововведения по сравнению с соответствующей
вкладкой Диспетчером задач Windows XP.
Число в графе «Всего» (Total) раздела
«Физическая память» (Physical Memory) указывает
на общий объем оперативной памяти для
данной системы. В графе «Кэшировано»
(Cached) указано количество физической
памяти, которая недавно использовалась
системными ресурсами. Она остается в
кэше на случай, если снова понадобится
системе, но доступна для других процессов.
В новой графе «Доступно» (Available) указывается
количество неиспользуемой в данный
момент физической памяти, а в графе
«Свободно» (Free) — количество памяти,
которая используется кэшем, но не
содержит полезной информации.
В разделе «Память ядра» (Kernel
Memory) содержатся две графы — «Выгружаемая»
(Paged) и «Невыгружаемая» (Nonpaged). В сумме
они указывают, сколько памяти использует
ядро. Выгружаемая — это виртуальная
память, а невыгружаемая — физическая.
В разделе «Система» (System) появились
графы «Дескрипторов» (Handles) и «Потоков»
(Threads), связанные с составными компонентами
процессов. В графе «Дескрипторов»
указывается количество идентификаторов
объектов (дескрипторов), которые
используются запущенными в данный
момент процессами. В графе «Потоков»
указано число подпроцессов, запущенных
в рамках более крупных процессов. Цифра
в графе «Процессов» (Processes), естественно,
указывает на общее количество запущенных
процессов, которые можно увидеть на
вкладке «Процессы».
В графе «Время работы» (Up Time)
указано, сколько времени прошло с
последнего запуска компьютера. В графе
«Выделено» (Commit) содержится информация
о файле подкачки. Первая цифра указывает
на общий объем используемой в данный
момент физической и виртуальной памяти,
а вторая — на общий объем памяти для
данного компьютера в принципе.
Еще более подробную информацию
можно получить, нажав кнопку «Монитор
ресурсов» и выбрав вкладку «Память»
(рис. 3.9).
Рис. 3.9. Вкладка «Память» окна
монитора ресурсов Windows7
На вкладке «Память» есть таблица
«Процессы», в которой перечислены все
запущенные процессы, а сведения об
используемой памяти для каждого процесса
разбиты на несколько категорий
(рис.3.10).
Рис. 3.10. Таблица «Процессы»
В колонке «Образ
» указывается
имя исполняемого файла процесса.
Процессы, запущенные приложениями,
узнать очень легко — например, процесс
«Winword.exe» со всей очевидностью
принадлежит текстовому редакторуWord.
Процессы с именем «svchost.exe» представляют
различные службы операционной системы.
Название службы указывается в скобках
рядом с именем процесса.
В колонке «ИД процесса
»
указывается номер процесса — уникальное
сочетание цифр, позволяющее идентифицировать
запущенный процесс.
В столбце «Завершено
»
указывается объем виртуальной памяти
в килобайтах, зарезервированный системой
для данного процесса. Сюда входит и
используемая физическая память, и
сохраненные в файле подкачки страницы.
В графе «Рабочий набор
»
указывается объем физической памяти в
килобайтах, используемой процессом в
данный момент времени. Рабочий набор
складывается из общей и частной памяти.
В колонке «Общий
» указан
объем физической памяти в килобайтах,
которую данный процесс использует
совместно с другими. Использование
одного сегмента памяти или страницы
подкачки для родственных процессов
позволяет сэкономить место в памяти.
При этом физически сохраняется только
одна копия страницы, которая затем
сопоставляется с виртуальным адресным
пространством других процессов, которые
к ней обращаются. Например, все процессы,
инициированные системными библиотеками
DLL — Ntdll, Kernel32, Gdi32 и User32 — используют
общую память.
В столбце «Частный
» указывается
объем физической памяти в килобайтах,
используемой исключительно данным
процессом. Именно это значение позволяет
определить, сколько памяти нужно тому
или иному приложению для работы.
В графе «Ошибок отсутствия
страницы в памяти/сек.
» указано среднее
за последнюю минуту количество ошибок
отсутствия страницы в памяти в секунду.
Если процесс пытается использовать
больше физической памяти, чем доступно
в данный момент времени, система
записывает часть данных из памяти на
диск — в файл подкачки. Последующее
обращение к данным, сохраненным на диск,
и называется ошибкой отсутствия страницы
в памяти.
При запуске приложений и работе
с файлами диспетчер памяти отслеживает
объем рабочего набора для каждого
процесса и фиксирует запросы на
дополнительные ресурсы памяти. По мере
увеличения рабочего набора процесса,
диспетчер соотносит эти запросы с
потребностями ядра и других процессов.
Если доступного адресного пространства
недостаточно, диспетчер уменьшает объем
рабочего набора, сохраняя данные из
памяти на диск.
В дальнейшем при чтении этих
данных с диска возникает ошибка отсутствия
страницы в памяти. Это вполне нормально,
но если ошибки происходят одновременно
для разных процессов, системе требуется
дополнительное время для чтения данных
с диска. Слишком частые ошибки отсутствия
страницы в памяти, соответственно,
снижают быстродействие системы. Это
проявляется в неожиданном замедлении
работы всех приложений, которое затем
также неожиданно прекращается. Замедление
связано с активным перераспределением
данных между физической памятью и
подкачкой.
Отсюда следует вывод: если ошибки
отсутствия страницы в памяти для того
или иного процесса происходят слишком
часто и притом регулярно, компьютеру
не хватает физической памяти.
Чтобы было удобнее наблюдать за
процессами, вызывающими частые ошибки
отсутствия страницы в памяти, можно
отметить их флажками. При этом выбранные
процессы переместятся наверх списка,
а в графике ошибок отсутствия страницы
в памяти будут представлены оранжевой
кривой.
Стоит учитывать, что распределение
памяти зависит от целого ряда других
факторов, и мониторинг ошибок отсутствия
страницы в памяти — не лучший и не
единственный способ выявления проблем.
Тем не менее, он может послужить неплохой
отправной точкой для наблюдения.
В таблице «Процессы» приводятся
детальные сведения о распределении
памяти между отдельными процессами, а
таблица «Физическая память» дает общую
картину использования RAM. Ее ключевой
компонент — уникальная гистограмма,
показанная на рис. 3.11.
Рисунок
3.11. Гистограмма в таблице «Физическая
память» позволяет составить общее
представление о распределении памяти
в Windows 7
Каждая секция гистограммы
обозначена собственным цветом и
представляет определенную группу
страниц памяти. По мере использования
системы, диспетчер памяти в фоновом
режиме перемещает данные между этими
группами, поддерживая тонкий баланс
между физической и виртуальной памятью
для обеспечения эффективной работы
всех приложений. Рассмотрим гистограмму
поподробнее.
Слева расположена секция
«Зарезервированное оборудование
»,
обозначенная серым цветом: это память,
выделенная на нужды подключенного
оборудования, которую оно использует
для взаимодействия с операционной
системой. Зарезервированная для
оборудования память заблокирована и
недоступна диспетчеру памяти. Обычно
объем памяти, выделенной оборудованию,
составляет от 10 до 70 Мбайт, однако этот
показатель зависит от конкретной
конфигурации системы и в некоторых
случаях может достигать нескольких
сотен мегабайт.
К компонентам, влияющим на объем
зарезервированной памяти, относятся:
Компоненты материнской платы
— например, усовершенствованный
программируемый контроллер прерываний
ввода/вывода (APIC);
Звуковые карты и другие
устройства, осуществляющие ввод/вывод
с отображением на память;
Шина PCI Express (PCIe);
Видеокарты;
Различные наборы микросхем;
Флеш-накопители.
Секция «Используется
»,
обозначенная зеленым цветом, представляет
количество памяти, используемой системой,
драйверами и запущенными процессами.
Количество используемой памяти
рассчитывается, как значение «Всего
»
за вычетом суммы показателей «Изменено
»,
«Ожидание
» и «Свободно
». В свою
очередь, значение «Всего
» — это
показатель «Установлено
» за вычетом
показателя «Зарезервированное
оборудование
».
В своей прошлой статье « » я рассказал о возможностях Монитора ресурсов Windows 7 (Resource Monitor), объяснил, как с его помощью наблюдать за распределением системных ресурсов между процессами и службами, а также упомянул, что его можно использовать для решения конкретных задач — например, для анализа расходования памяти. Именно об этом и пойдет речь в данной статье.
Немного о памяти
Прежде чем приступать к анализу, коротко расскажу о том, управляет памятью. После этого вам будет проще понять, какая информация представлена в Мониторе ресурсов Windows 7.
Диспетчер памяти Windows 7 создает виртуальную систему памяти, которая состоит из доступной физической RAM и файла подкачки на жестком диске. Это позволяет операционной системе выделять блоки памяти фиксированной длины (страницы) с последовательными адресами в физической и виртуальной памяти.
Запуск Монитора ресурсов Windows 7
Чтобы запустить Монитор ресурсов Windows 7, откройте меню «Пуск» (Start), введите в строке поиска «Resmon.exe» и нажмите . В открывшемся окне выберите вкладку «Память» (Memory, рис. A).
Рисунок A. На вкладке «Память» в Мониторе ресурсов Windows 7 приводятся подробные сведения о распределении памяти.
Таблица «Процессы»
На вкладке «Память» есть таблица «Процессы» (Processes, рис. B), в которой перечислены все запущенные процессы, а сведения об используемой памяти разбиты на несколько категорий.
Рисунок B. Сведения об используемой памяти для каждого процесса разбиты на несколько категорий.
Графа «Образ»
В колонке «Образ» (Image) указывается имя исполняемого файла процесса. Процессы, запущенные приложениями, узнать очень легко — например, процесс «notepad.exe» со всей очевидностью принадлежит Блокноту (Notepad). Процессы с именем «svchost.exe» представляют различные службы операционной системы. Название службы указывается в скобках рядом с именем процесса.
Графа «ИД процесса»
В колонке «ИД процесса» (PID) указывается номер процесса — уникальное сочетание цифр, позволяющее идентифицировать запущенный процесс.
Графа «Завершено»
В столбце «Завершено» (Commit) указывается объем виртуальной памяти в килобайтах, зарезервированный системой для данного процесса. Сюда входит и используемая физическая память, и сохраненные в файле подкачки страницы.
Графа «Рабочий набор»
В графе «Рабочий набор» (Working Set) указывается объем физической памяти в килобайтах, используемой процессом в данный момент времени. Рабочий набор складывается из общей и частной памяти.
Графа «Общий»
В колонке «Общий» (Shareable) указан объем физической памяти в килобайтах, которую данный процесс использует совместно с другими. Использование одного сегмента памяти или страницы подкачки для родственных процессов позволяет сэкономить место в памяти. При этом физически сохраняется только одна копия страницы, которая затем сопоставляется с виртуальным адресным пространством других процессов, которые к ней обращаются. Например, все процессы, инициированные системными библиотеками DLL — Ntdll, Kernel32, Gdi32 и User32 — используют общую память.
Графа «Частный»
В столбце «Частный» (Private) указывается объем физической памяти в килобайтах, используемой исключительно данным процессом. Именно это значение позволяет определить, сколько памяти нужно тому или иному приложению для работы.
Графа «Ошибок отсутствия страницы в памяти/сек.»
В графе «Ошибок отсутствия страницы в памяти/сек.» (Hard Faults/sec) указано среднее за последнюю минуту количество ошибок отсутствия страницы в памяти в секунду. Если процесс пытается использовать больше физической памяти, чем доступно в данный момент времени, система записывает часть данных из памяти на диск — в файл подкачки. Последующее обращение к данным, сохраненным на диск, и называется ошибкой отсутствия страницы в памяти.
О чем говорят ошибки отсутствия страницы в памяти
Теперь, когда вы представляете, какие сведения собраны в таблице «Процессы», давайте посмотрим, как с их помощью следить за распределением памяти. При запуске приложений и работе с файлами диспетчер памяти отслеживает объем рабочего набора для каждого процесса и фиксирует запросы на дополнительные ресурсы памяти. По мере увеличения рабочего набора процесса, диспетчер соотносит эти запросы с потребностями ядра и других процессов. Если доступного адресного пространства недостаточно, диспетчер уменьшает объем рабочего набора, сохраняя данные из памяти на диск.
В дальнейшем при чтении этих данных с диска возникает ошибка отсутствия страницы в памяти. Это вполне нормально, но если ошибки происходят одновременно для разных процессов, системе требуется дополнительное время для чтения данных с диска. Слишком частые ошибки отсутствия страницы в памяти, соответственно, снижают быстродействие системы. Вам наверняка доводилось наблюдать неожиданное замедление работы всех приложений, которое затем также неожиданно прекращалось. Почти наверняка это замедление было связано с активным перераспределением данных между физической памятью и подкачкой.
Отсюда следует вывод: если ошибки отсутствия страницы в памяти для того или иного процесса происходят слишком часто и притом регулярно, компьютеру не хватает физической памяти.
Чтобы было удобнее наблюдать за процессами, вызывающими частые ошибки отсутствия страницы в памяти, можно отметить их флажками. При этом выбранные процессы переместятся наверх списка, а в графике ошибок отсутствия страницы в памяти будут представлены оранжевой кривой.
Стоит учитывать, что распределение памяти зависит от целого ряда других факторов, и мониторинг ошибок отсутствия страницы в памяти — не лучший и не единственный способ выявления проблем. Тем не менее, он может послужить неплохой отправной точкой для наблюдения.
Таблица «Физическая память»
В таблице «Процессы» приводятся детальные сведения о распределении памяти между отдельными процессами, а таблица «Физическая память» (Physical Memory) дает общую картину использования RAM. Ее ключевой компонент — уникальная гистограмма, показанная на рис. C.
Рисунок C. Гистограмма в таблице «Физическая память» позволяет составить общее представление о распределении памяти в Windows 7.
Каждая секция гистограммы обозначена собственным цветом и представляет определенную группу страниц памяти. По мере использования системы, диспетчер памяти в фоновом режиме перемещает данные между этими группами, поддерживая тонкий баланс между физической и виртуальной памятью для обеспечения эффективной работы всех приложений. Давайте рассмотрим гистограмму поподробнее.
Секция «Зарезервированное оборудование»
Слева расположена секция «Зарезервированное оборудование» (Hardware Reserved), обозначенная серым цветом: это память, выделенная на нужды подключенного оборудования, которую оно использует для взаимодействия с операционной системой. Зарезервированная для оборудования память заблокирована и недоступна диспетчеру памяти.
Обычно объем памяти, выделенной оборудованию, составляет от 10 до 70 Мбайт, однако этот показатель зависит от конкретной конфигурации системы и в некоторых случаях может достигать нескольких сотен мегабайт. К компонентам, влияющим на объем зарезервированной памяти, относятся:
;
компоненты материнской платы — например, усовершенствованный программируемый контроллер прерываний ввода/вывода (APIC);
звуковые карты и другие устройства, осуществляющие ввод/вывод с отображением на память;
шина PCI Express (PCIe);
видеокарты;
различные наборы микросхем;
флеш-накопители.
Некоторые пользователи жалуются, что в их системах для оборудования зарезервировано ненормально много памяти. Мне с такой ситуацией сталкиваться не приходилось и потому я не могу ручаться за действенность предложенного решения, но многие отмечают, что обновление версии BIOS позволяет решить проблему.
Секция «Используется»
Секция «Используется» (In Use, рис C), обозначенная зеленым цветом, представляет количество памяти, используемой системой, драйверами и запущенными процессами. Количество используемой памяти рассчитывается, как значение «Всего» (Total) за вычетом суммы показателей «Изменено» (Modified), «Ожидание» (Standby) и «Свободно» (Free). В свою очередь, значение «Всего» — это показатель «Установлено» (Installed RAM) за вычетом показателя «Зарезервированное оборудование».
Секция «Изменено»
Оранжевым цветом выделена секция «Изменено» (Modified), в которой представлена измененная, но не задействованная память. Фактически она не используется, но может быть в любой момент задействована, если снова понадобится. Если память не используется достаточно давно, данные переносятся в файл подкачки, а память переходит в категорию «Ожидание».
Секция «Ожидание»
Секция «Ожидание», обозначенная синим цветом, представляет страницы памяти, удаленные из рабочих наборов, но по-прежнему с ними связанные. Другими словами, категория «Ожидание» — это фактически кэш. Страницам памяти в этой категории присваивается приоритет от 0 до 7 (максимум). Страницы, связанные с высокоприоритетными процессами, получают максимальный приоритет. Например, совместно используемые процессы обладают высоким приоритетом, поэтому связанным с ними страницам присваивается наивысший приоритет в категории «Ожидание».
Если процессу требуются данные с ожидающей страницы, диспетчер памяти сразу же возвращает эту страницу в рабочий набор. Тем не менее, все страницы в категории «Ожидание» доступны для записи данных от других процессов. Когда процессу требуется дополнительная память, а свободной памяти недостаточно, диспетчер памяти выбирает ожидающую страницу с наименьшим приоритетом, инициализирует ее и выделяет запросившему процессу.
Секция «Свободно»
В категории «Свободно», обозначенной голубым цветом, представлены страницы памяти, еще не выделенные ни одному процессу или освободившиеся после завершения процесса. В этой секции отображается как еще не задействованная, так и уже освобожденная память, но на самом деле, еще не задействованная память относится к другой категории — «Нулевые страницы» (Zero Page), которая так называется, потому что эти страницы инициализированы нулевым значением и готовы для использования.
О проблеме свободной памяти
Теперь, когда вы в общих чертах представляете, как работает диспетчер памяти, ненадолго остановимся на распространенном заблуждении, связанном с системой управления памятью в Windows 7. Как видно из рис. C, секция свободной памяти — одна из самых маленьких в гистограмме. Тем не менее, ошибочно на этом основании полагать, будто Windows 7 потребляет чересчур много памяти и что система не может нормально работать, если свободной памяти так мало.
На самом деле, все совсем наоборот. В контексте принятого в Windows 7 подхода к управлению памятью, свободная память бесполезна. Чем больше памяти задействовано, тем лучше. Заполняя память до максимума и постоянно перемещая страницы из одной категории в другую с использованием системы приоритетов, Windows 7 повышает эффективность работы и предотвращает попадание данных в файл подкачки, не давая ошибкам отсутствия страницы в памяти замедлить быстродействие.
Мониторинг памяти
Хотите понаблюдать систему управления памятью Windows 7 в действии? Перезагрузите компьютер и сразу же после запуска откройте Монитор ресурсов Windows 7. Перейдите на вкладку «Память» и обратите внимание на соотношение секций в гистограмме физической памяти.
Затем начните запускать приложения. По мере запуска следите за изменением гистограммы. Запустив как можно больше приложений, начните закрывать их по одному и наблюдайте, как изменяется соотношение секций в гистограмме физической памяти.
Проделав этот экстремальный эксперимент, вы поймете, как Windows 7 управляет памятью на вашем конкретном компьютере, и сможете использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти в нормальных условиях повседневной работы.
А что думаете вы?
Нравится ли вам идея использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти? Поделитесь своим мнением в комментариях!
Когда в Windows запускается процесс, многие из отображающих образы файлов EXE и DLL страниц могут уже находиться в памяти, поскольку они используются другими процессами. Пригодные для записи страницы образов помечены как «копирование при записи», чтобы их можно было совместно использовать до того момента, когда их понадобится модифицировать. Если операционная система узнает уже выполнявшийся ЕХЕ, то она может записать шаблон страничных ссылок (при помощи технологии, которую компания Microsoft называет Super-Fetch). Эта технология старается заблаговременно подкачать много нужных страниц (хотя процесс еще не получил по ним страничные ошибки). Это снижает латентность запуска приложений (чтение страниц с диска накладывается на выполнение инициализационного кода образов). Эта технология повышает производительность вывода на диск, поскольку дисковым драйверам легче организовать операции чтения (чтобы уменьшить необходимое время поиска). Этот процесс упреждающей подкачки страниц используется и во время загрузки системы, а также когда фоновое приложение выходит на передний план и при выходе системы из гибернации.
Упреждающая подкачка страниц поддерживается диспетчером памяти, но реализована она как отдельный компонент системы. Подкачиваемые страницы не вставляются в таблицу страниц процесса, вместо этого они вставляются в резервный список, из которого могут быть быстро вставлены в процесс (без обращения к диску).
Неотображенные страницы несколько отличаются — они не инициализируются путем чтения из файла. Вместо этого при первом обращении к неотображенной странице диспетчер памяти предоставляет новую физическую страницу (убедившись, что ее содержимое заполнено нулями, — из соображений безопасности). При последующих страничных ошибках неотображенную страницу может понадобиться найти в памяти или ее придется прочитать из файла подкачки.
Подкачка по требованию в диспетчере памяти управляется страничными ошибками. При каждой ошибке происходит прерывание в ядро. Затем ядро строит машинно независимый дескриптор (который сообщает о происшедшем) и передает его в диспетчер памяти исполнительного уровня. Диспетчер памяти затем проверяет обращение на действительность. Если давшая сбой страница попадает в зафиксированную область, то он ищет адрес в списке VAD и находит (или создает) элемент таблицы страниц процесса. В случае совместно используемой страницы диспетчер памяти использует элемент таблицы страниц прототипов (связанный с объектом сегмента) для заполнения нового элемента таблицы страниц процесса.
Формат элемента таблицы страниц различается в зависимости от архитектуры процессора. Для процессоров х86 и х64 элементы отображаемой страницы показаны на рис. 11.17. Если элемент помечен как действительный, то его содержимое интерпретируется аппаратным обеспечением (чтобы виртуальный адрес можно было преобразовать в правильную физическую страницу). Неотображенные страницы также имеют свои элементы, но они помечены как недействительные (invalid), и аппаратное обеспечение игнорирует остальную часть элемента. Программный формат несколько отличается от аппаратного и определяется диспетчером памяти. Например, для неотображенной страницы (которая должна быть размещена и обнулена до использования) этот факт отмечен в элементе таблицы страниц.
Два важных бита элемента таблицы страниц обновляются непосредственно аппаратным обеспечением. Это бит доступа (А) и бит «измененная» (D). Эти биты отслеживают использование данного отображения страницы для доступа к странице и возможность модифицирования страницы при этом доступе. Это реально повышает производительность системы, поскольку диспетчер памяти может использовать бит доступа для реализации подкачки по схеме наиболее давнего использования (Least- Recently Used (LRU)). Принцип LRU состоит в том, что те страницы, которые дольше всех не используются, имеют самую низкую вероятность повторного использования в ближайшее время. Бит доступа позволяет диспетчеру памяти определить, что к странице был произведен доступ. Бит «измененная» говорит диспетчеру памяти о том, что страница, возможно, была модифицирована (или, что более важно, она не была модифицирована). Если страница не была модифицирована с момента считывания с диска, то диспетчеру памяти не нужно записывать ее содержимое на диск (перед тем, как использовать ее для чего-то другого).
В обеих архитектурах, х86 и x64, используется элемент таблицы страниц размером 64 бита (см. рис. 11.17).
Каждая страничная ошибка может быть отнесена к одной из пяти категорий:
1. Страница не зафиксирована.
2. Попытка обращения к странице с нарушением разрешений.
3. Попытка модификации страницы типа «копирование при записи».
1. Необходимо увеличение стека.
2. Страница зафиксирована, но в данное время не отображена.
Первый и второй случаи — это ошибки программирования. Если программа пытается использовать адрес, который не имеет действительного отображения, или пытается выполнить недопустимую операцию (наподобие попытки записи в страницу «только для чтения»), это называется нарушением доступа (access violation) и обычно приводит к завершению процесса. Нарушение доступа часто является результатом недопустимых значений указателей, в том числе результатом обращения к памяти, которая была освобождена и откреплена от процесса.
Третий случай имеет такие же симптомы, что и второй (попытка записи в страницу «только для чтения»), но его обработка иная. Поскольку страница была помечена как «копирование при записи», то диспетчер памяти не выдает нарушение доступа. Вместо этого он создает закрытую копию страницы для текущего процесса, а затем возвращает управление тому потоку, который пытался выполнить запись в страницу. Поток повторяет операцию записи, которая теперь завершится без страничной ошибки.
Четвертый случай происходит тогда, когда поток помещает значение в свой стек и попадает на страницу, которая еще не была выделена. Диспетчер памяти распознает это как особый случай. Пока есть место в зарезервированных под стек виртуальных страницах, диспетчер памяти будет поставлять новые страницы, обнулять их и отображать в процесс. Когда поток возобновит выполнение, он повторит попытку доступа, и на этот раз она будет успешной.
И наконец, пятый случай — это нормальная страничная ошибка. Однако она имеет несколько подвариантов. Если страница отображена на файл, то диспетчер памяти должен просмотреть ее структуры данных (такие, как таблица страниц прототипов, связанная с объектом сегмента), чтобы быть уверенным в том, что в памяти нет ее копии. Если копия есть (например, в другом процессе, в резервном списке либо в списке модифицированных страниц), то он просто сделает ее совместно используемой (возможно, что для этого ему придется пометить ее как страницу «копирование при записи», если изменения совместно использовать не предполагается). Если копии еще нет, то диспетчер памяти выделит свободную физическую страницу и подготовит ее для копирования в нее страницы файла с диска, если только в этот момент не осуществляется перенос с диска другой страницы (тогда нужно лишь подождать, пока этот перенос не завершится).
Если диспетчер памяти может обработать страничную ошибку, находя нужную страницу в памяти (а не считывая ее с диска), то такая ошибка называется мягкой ошибкой (soft fault). Если нужна копия с диска, то это жесткая ошибка (hard fault). Мягкие ошибки гораздо дешевле, они мало влияют на производительность приложения (по сравнению с жесткими ошибками). Мягкие ошибки могут происходить потому, что совместно используемая страница уже была отображена на другой процесс, либо нужна просто новая обнуленная страница, либо нужная страница была удалена из рабочего набора процесса, но запрашивается повторно до того, как ее повторно использовали. Мягкие ошибки могут возникать также из-за того, что страницы были сжаты для эффективного увеличения размера физической памяти. Для большинства конфигураций центрального процессора память и ввод-вывод в текущих системах эффективнее сжимать, вместо того чтобы тратиться на дорогостоящий ввод-вывод (с точки зрения производительности и энергозатрат), требующий чтения страницы с диска.
Когда физическая страница больше не отображается таблицей страниц ни одного из процессов, она попадает в один из трех списков: свободных, модифицированных или резервных. Те страницы, которые никогда больше не понадобятся (такие, как страницы стека завершающегося процесса), освобождаются немедленно. Те страницы, которые могут снова дать страничную ошибку, попадают либо в список модифицированных, либо в список резервных (в зависимости от того, был ли бит «измененная» установлен для какого-либо элемента таблицы страниц, который отображал эту страницу с момента ее последнего считывания с диска). Страницы из модифицированного списка будут в конечном итоге записаны на диск, а затем перемещены в список резервных.
Диспетчер памяти может выделять страницы по мере необходимости (используя список либо свободных, либо резервных страниц). Перед размещением страницы и копированием с диска диспетчер памяти всегда проверяет списки резервных и модифицированных страниц, чтобы проверить, нет ли уже этой страницы в памяти. Схема опережающей подкачки в Windows преобразует будущие жесткие ошибки в мягкие (путем чтения страниц, которые могут понадобиться, и помещения их в список резервных страниц). Диспетчер памяти и сам выполняет небольшой объем опережающей подкачки — он обращается к группам последовательных страниц (а не к отдельным страницам). Дополнительные страницы немедленно размещаются в списке резервных страниц. Это не является расточительством, поскольку издержки диспетчера памяти гораздо меньше, чем стоимость выполнения операций ввода-вывода. Чтение целого кластера страниц чуть дороже, чем чтение одной страницы.
Элементы таблицы страниц на рис. 11.17 относятся к номерам физических (а не виртуальных) страниц. Для обновления элемента таблицы страниц (и каталога страниц) ядру нужно использовать виртуальные адреса. Windows отображает таблицы страниц и каталоги страниц для текущего процесса на виртуальное адресное пространство ядра при помощи элемента self-map в каталоге страниц (рис. 11.18). Отображая элемент каталога страниц на каталог страниц (карта self-map), мы получаем виртуальные адреса, которые можно использовать для ссылки на элементы каталога страниц (рис. 11.18, а) и на элементы таблицы страниц (рис. 11.18, б). Карта self-map занимает 8 Мбайт виртуальных адресов ядра для каждого процесса (на процессорах х86). Для простоты на рисунке показан элемент x86 self-map для 32-разрядных PTE-записей (Page-Table Entries). На самом деле Windows использует 64-разрядные PTE-записи, поэтому система может воспользоваться более чем 4 Гбайт физической памяти. С 32-разрядными PTE-записями элемент self-map использует в каталоге страниц только одну PDE- запись (Page-Directory Entry) и поэтому занимает только 4 Мбайт адресов, а не 8 Мбайт.
Обработка ситуации отсутствия страницы в памяти
Если в таблице страниц имеется ссылка на страницу, отсутствующую в памяти, первое же обращение по такой ссылке приведет к прерыванию и вызову ОС (ситуации page fault – отсутствие страницы в памяти)
ОС по таблицам определяет, что именно произошло:
Если имеет место неверная ссылка (на страницу, отсутствующую в логической памяти), то работа программы прекращается.
Если же имеет место обычное отсутствие страницы в памяти, то ОС должна разместить его в основной памяти. Для этого ОС выполняет следующий алгоритм:
- Найти незанятый фрейм в основной памяти ;
- Считать содержимое страницы в данный фрейм ;
- Изменить элемент таблицы страниц: validation-бит установить равным 1;
- Продолжить работу программы. Напомним, что программа после прерывания продолжается с той же команды, которая была прервана из-за отсутствия страницы. Поэтому теперь программа продолжит нормально выполняться, и обращение к странице произойдет успешно.
Этапы обработки ситуации отсутствия страницы в памяти показаны на
рис.
18.4.
Этап 1 – выполнение команды load M, которая прерывается по отсутствию страницы в памяти; 2 – прерывание и вызов ОС; 3 – обращение к странице, находящейся в файле откачки на диске; 4 – считывание страницы в память на свободный фрейм; 5 – изменение элемента таблицы страниц; 6 – повторное (успешное) выполнение команды.
Отсутствие свободного фрейма. Оценка производительности стратегии обработки страниц по требованию.
На этапе 4 (рис. 18.4) возможна ситуация отсутствия свободного фрейма в основной памяти. При этом ОС должна выполнить замещение страницы (page replacement) – найти страницу, загруженную в память, но реально не используемую, и откачать ее.
Для оптимальной реализации стратегии замещения страниц требуется алгоритм, приводящий к наименьшему возможному числу отказов страниц. Возможные решения мы рассмотрим немного позже в данной лекции.
Дадим общую оценку производительности обработки страниц по требованию.
Введем коэффициент отказов страниц (Page Fault Rate) p:> 0 <= p <= 1.0.
Если p = 0, то имеет место отсутствие отказов страниц.
Если p = 1, то каждое обращение к странице приводит к отказу.
Оценим теперь эффективное время доступа (Effective Access Time — EAT):
EAT = (1 – p) * время доступа к памяти + p * (время реакции на отказ + [ время откачки страницы ] + время подкачки страницы + время рестарта)
Дадим необходимые пояснения к данной формуле. Оценка времени складывается из двух слагаемых. Первое слагаемое соответствует ситуации, когда отказ страницы не имеет места, и оценивает среднее время доступа к странице в этом случае. Второе слагаемое вычисляет оценку времени в случае отказа страницы. В нем первая компонента – суммарное время реакции апппратуры и ОС на отказ страницы, вторая (необязательная) – время откачки страницы (если она требуется для замещения страниц), третья – время подкачки страницы, четвертая – время рестарта программы. Если коэффициент p рассматривать как вероятность отказа страницы, то величина EAT будет математическим ожиданием общего времени доступа к странице.
Преимущества виртуальной памяти при создании процессов
Благодаря механизму виртуальной памяти, могут быть использованы следующие оптимизации расходования памяти при создании процессов:
- Копирование по записи (Copy-on-Write)
- Отображение файлов в память (Memory-Mapped Files).
Принцип совместного использования страниц процессами (или копирование по записи — Copy-On-Write, COW) позволяет первоначально родительскому и дочернему процессам использовать одни и те же страницы памяти. Если какой-либо процесс модифицирует разделяемую страницу, то только в этом случае данная страница копируется. Принцип COW обеспечивает более эффективное создание процесса, так как копируются только модифицируемые страницы. Свободные страницы распределяются из списка страниц, инициализированных нулями.
Использование при вводе-выводе файлов, отображаемых в память, позволяет рассматривать файловый ввод-вывод как обычное обращение к памяти путем отображения блока на диске в страницу памяти.
Первоначально файл читается с использованием запроса страниц по требованию. Часть файла размером с одну страницу читается из файла в физическую страницу (фрейм). Последующие чтения из файла и записи в файл трактуются как обычные обращения к памяти. Это упрощает доступ к файлу, по сравнению с системными вызовами read() и write(). Это позволяет также нескольким процессам отображать в память один и тот же файл, по тому же принципу, как они совместно используют какие-либо страницы.
На
рис.
18.5 иллюстрируется концепция файла, отображаемого в память.
Процессы A и B совместно используют файл, причем каждому блоку файла соответствует страница в памяти. Эти страницы имеют одни и те же номера в таблицах страниц виртуальной памяти процессов. Страницы, присутствующие в памяти, фактически являются частями файла, обрабатываемого при вводе-выводе, благодаря этому, гораздо быстрее, чем обычный файл. По окончании обмена, при закрытии файла, система записывает все его измененные части на диск.
Подобный механизм имеется в большинстве операционных систем. Например, в системе Solaris он реализуется командой и системным вызовом mmap (memory map).
Политика очистки страниц
Замещение
страниц лучше всего работает при наличии
достаточного количества свободных
страничных блоков, которые могут
потребоваться при возникновении ошибки
отсутствия страницы. Если заполнен и,
более того, изменен каждый страничный
блок, то перед помещением в него новой
страницы сначала должна быть записана
на диск старая страница. Для обеспечения
поставки свободных страничных блоков
системы замещения страниц, как правило,
имеют фоновый процесс. Если свободно
слишком мало страничных блоков, фоновый
процесс начинает подбирать страницы
для выгрузки, используя какой-нибудь
алгоритм замещения страниц. Если эти
страницы со времени своей загрузки
подверглись изменению, они записываются
на диск.
В
любом случае предыдущее содержание
страницы запоминается. Если одна из
выгруженных страниц понадобится опять
перед тем, как ее страничный блок будет
переписан, она может быть восстановлена
из резерва свободных страничных блоков.
Обработка ошибки отсутствия страницы
Описание
всего, что происходит при возникновении
ошибки отсутствия страницы. Складывается
следующая последовательность событий:
1.
Аппаратное прерывание передает управление
ядру, сохраняя в стеке значение счетчика
команд. На большинстве машин в специальных
регистрах центрального процессора
сохраняется информация о состоянии
текущей команды.
2.
Запускается код стандартной программы
на ассемблере, предназначенный для
сохранения регистров общего назначения
и другой изменяющейся информации, чтобы
защитить ее от разрушения со стороны
операционной системы.
3.
Операционная система определяет, что
произошла ошибка отсутствия страницы,
и пытается определить, какая виртуальная
страница востребована. Зачастую эта
информация содержится в одном из
аппаратных регистров. В противном случае
операционная система должна взять
значение счетчика команд, извлечь
команду и провести ее разбор программным
способом, чтобы определить, что происходило
в тот момент, когда возникла ошибка.
4.
Когда известен виртуальный адрес,
вызвавший ошибку, система проводит
проверку адреса на приемлемость и
доступа к этому адресу — на согласованность
с системой защиты. При отрицательном
результате проверки процессу посылается
сигнал или же он уничтожается.
5.
Если выбранный страничный блок содержит
измененную страницу, она включается в
план сброса на диск и происходит
переключение контекста, приостанавливающее
процесс, в котором произошла ошибка.
6.
Как только страничный блок очистится
(либо немедленно, либо после сброса его
содержимого на диск), операционная
система ищет адрес на диске, по которому
находится востребованная страница, и
в план включается дисковая операция,
предназначенная для ее извлечения. Пока
страница загружается, процесс, в котором
произошла ошибка, остается приостановленным
и запускается другой пользовательский
процесс, если таковой имеется.
7.
Когда дисковое прерывание показывает,
что страница получена, таблицы страниц
обновляются, чтобы отобразить ее позицию,
и блок получает пометку нормального
состояния.
8.
Команда, на которой произошла ошибка,
возвращается к тому состоянию, в котором
она находилась с самого начала, и счетчик
команд переключается, чтобы указывать
на эту команду.
9.
Процесс, в котором произошла ошибка,
включается в план, и операционная система
возвращает управление стандартной
программе на ассемблере, которая ее
вызвала.
10.
Эта стандартная программа перезагружает
регистры и другую информацию о состоянии
и, если не произошло ошибки, возвращается
в пространство пользователя для
продолжения выполнения.
Анализ использования памяти с помощью Монитора ресурсов Windows 7
Прежде чем приступать к анализу, коротко расскажу о том, как Microsoft Windows 7 управляет памятью. После этого вам будет проще понять, какая информация представлена в Мониторе ресурсов Windows 7.
Диспетчер памяти Windows 7 создает виртуальную систему памяти, которая состоит из доступной физической RAM и файла подкачки на жестком диске. Это позволяет операционной системе выделять блоки памяти фиксированной длины (страницы) с последовательными адресами в физической и виртуальной памяти.
Запуск Монитора ресурсов Windows 7
Чтобы запустить Монитор ресурсов Windows 7, откройте меню «Пуск» (Start), введите в строке поиска «Resmon.exe» и нажмите [Enter]. В открывшемся окне выберите вкладку «Память» (Memory, рис. A).
Рисунок A. На вкладке «Память» в Мониторе ресурсов Windows 7 приводятся подробные сведения о распределении памяти.
Таблица «Процессы»
На вкладке «Память» есть таблица «Процессы» (Processes, рис. B), в которой перечислены все запущенные процессы, а сведения об используемой памяти разбиты на несколько категорий.
Рисунок B. Сведения об используемой памяти для каждого процесса разбиты на несколько категорий.
Графа «Образ»
В колонке «Образ» (Image) указывается имя исполняемого файла процесса. Процессы, запущенные приложениями, узнать очень легко — например, процесс «notepad.exe» со всей очевидностью принадлежит Блокноту (Notepad). Процессы с именем «svchost.exe» представляют различные службы операционной системы. Название службы указывается в скобках рядом с именем процесса.
Графа «ИД процесса»
В колонке «ИД процесса» (PID) указывается номер процесса — уникальное сочетание цифр, позволяющее идентифицировать запущенный процесс.
Графа «Завершено»
В столбце «Завершено» (Commit) указывается объем виртуальной памяти в килобайтах, зарезервированный системой для данного процесса. Сюда входит и используемая физическая память, и сохраненные в файле подкачки страницы.
Графа «Рабочий набор»
В графе «Рабочий набор» (Working Set) указывается объем физической памяти в килобайтах, используемой процессом в данный момент времени. Рабочий набор складывается из общей и частной памяти.
Графа «Общий»
В колонке «Общий» (Shareable) указан объем физической памяти в килобайтах, которую данный процесс использует совместно с другими. Использование одного сегмента памяти или страницы подкачки для родственных процессов позволяет сэкономить место в памяти. При этом физически сохраняется только одна копия страницы, которая затем сопоставляется с виртуальным адресным пространством других процессов, которые к ней обращаются. Например, все процессы, инициированные системными библиотеками DLL — Ntdll, Kernel32, Gdi32 и User32 — используют общую память.
Графа «Частный»
В столбце «Частный» (Private) указывается объем физической памяти в килобайтах, используемой исключительно данным процессом. Именно это значение позволяет определить, сколько памяти нужно тому или иному приложению для работы.
Графа «Ошибок отсутствия страницы в памяти/сек.»
В графе «Ошибок отсутствия страницы в памяти/сек.» (Hard Faults/sec) указано среднее за последнюю минуту количество ошибок отсутствия страницы в памяти в секунду. Если процесс пытается использовать больше физической памяти, чем доступно в данный момент времени, система записывает часть данных из памяти на диск — в файл подкачки. Последующее обращение к данным, сохраненным на диск, и называется ошибкой отсутствия страницы в памяти.
О чем говорят ошибки отсутствия страницы в памяти
Теперь, когда вы представляете, какие сведения собраны в таблице «Процессы», давайте посмотрим, как с их помощью следить за распределением памяти. При запуске приложений и работе с файлами диспетчер памяти отслеживает объем рабочего набора для каждого процесса и фиксирует запросы на дополнительные ресурсы памяти. По мере увеличения рабочего набора процесса, диспетчер соотносит эти запросы с потребностями ядра и других процессов. Если доступного адресного пространства недостаточно, диспетчер уменьшает объем рабочего набора, сохраняя данные из памяти на диск.
В дальнейшем при чтении этих данных с диска возникает ошибка отсутствия страницы в памяти. Это вполне нормально, но если ошибки происходят одновременно для разных процессов, системе требуется дополнительное время для чтения данных с диска. Слишком частые ошибки отсутствия страницы в памяти, соответственно, снижают быстродействие системы. Вам наверняка доводилось наблюдать неожиданное замедление работы всех приложений, которое затем также неожиданно прекращалось. Почти наверняка это замедление было связано с активным перераспределением данных между физической памятью и подкачкой.
Отсюда следует вывод: если ошибки отсутствия страницы в памяти для того или иного процесса происходят слишком часто и притом регулярно, компьютеру не хватает физической памяти.
Чтобы было удобнее наблюдать за процессами, вызывающими частые ошибки отсутствия страницы в памяти, можно отметить их флажками. При этом выбранные процессы переместятся наверх списка, а в графике ошибок отсутствия страницы в памяти будут представлены оранжевой кривой.
Стоит учитывать, что распределение памяти зависит от целого ряда других факторов, и мониторинг ошибок отсутствия страницы в памяти — не лучший и не единственный способ выявления проблем. Тем не менее, он может послужить неплохой отправной точкой для наблюдения.
Таблица «Физическая память»
В таблице «Процессы» приводятся детальные сведения о распределении памяти между отдельными процессами, а таблица «Физическая память» (Physical Memory) дает общую картину использования RAM. Ее ключевой компонент — уникальная гистограмма, показанная на рис. C.
Рисунок C. Гистограмма в таблице «Физическая память» позволяет составить общее представление о распределении памяти в Windows 7.
Каждая секция гистограммы обозначена собственным цветом и представляет определенную группу страниц памяти. По мере использования системы, диспетчер памяти в фоновом режиме перемещает данные между этими группами, поддерживая тонкий баланс между физической и виртуальной памятью для обеспечения эффективной работы всех приложений. Давайте рассмотрим гистограмму поподробнее.
Секция «Зарезервированное оборудование»
Слева расположена секция «Зарезервированное оборудование» (Hardware Reserved), обозначенная серым цветом: это память, выделенная на нужды подключенного оборудования, которую оно использует для взаимодействия с операционной системой. Зарезервированная для оборудования память заблокирована и недоступна диспетчеру памяти.
Обычно объем памяти, выделенной оборудованию, составляет от 10 до 70 Мбайт, однако этот показатель зависит от конкретной конфигурации системы и в некоторых случаях может достигать нескольких сотен мегабайт. К компонентам, влияющим на объем зарезервированной памяти, относятся:
• BIOS;
• компоненты материнской платы — например, усовершенствованный программируемый контроллер прерываний ввода/вывода (APIC);
• звуковые карты и другие устройства, осуществляющие ввод/вывод с отображением на память;
• шина PCI Express (PCIe);
• видеокарты;
• различные наборы микросхем;
• флеш-накопители.
Некоторые пользователи жалуются, что в их системах для оборудования зарезервировано ненормально много памяти. Мне с такой ситуацией сталкиваться не приходилось и потому я не могу ручаться за действенность предложенного решения, но многие отмечают, что обновление версии BIOS позволяет решить проблему.
Секция «Используется»
Секция «Используется» (In Use, рис C), обозначенная зеленым цветом, представляет количество памяти, используемой системой, драйверами и запущенными процессами. Количество используемой памяти рассчитывается, как значение «Всего» (Total) за вычетом суммы показателей «Изменено» (Modified), «Ожидание» (Standby) и «Свободно» (Free). В свою очередь, значение «Всего» — это показатель «Установлено» (Installed RAM) за вычетом показателя «Зарезервированное оборудование».
Секция «Изменено»
Оранжевым цветом выделена секция «Изменено» (Modified), в которой представлена измененная, но не задействованная память. Фактически она не используется, но может быть в любой момент задействована, если снова понадобится. Если память не используется достаточно давно, данные переносятся в файл подкачки, а память переходит в категорию «Ожидание».
Секция «Ожидание»
Секция «Ожидание», обозначенная синим цветом, представляет страницы памяти, удаленные из рабочих наборов, но по-прежнему с ними связанные. Другими словами, категория «Ожидание» — это фактически кэш. Страницам памяти в этой категории присваивается приоритет от 0 до 7 (максимум). Страницы, связанные с высокоприоритетными процессами, получают максимальный приоритет. Например, совместно используемые процессы обладают высоким приоритетом, поэтому связанным с ними страницам присваивается наивысший приоритет в категории «Ожидание».
Если процессу требуются данные с ожидающей страницы, диспетчер памяти сразу же возвращает эту страницу в рабочий набор. Тем не менее, все страницы в категории «Ожидание» доступны для записи данных от других процессов. Когда процессу требуется дополнительная память, а свободной памяти недостаточно, диспетчер памяти выбирает ожидающую страницу с наименьшим приоритетом, инициализирует ее и выделяет запросившему процессу.
Секция «Свободно»
В категории «Свободно», обозначенной голубым цветом, представлены страницы памяти, еще не выделенные ни одному процессу или освободившиеся после завершения процесса. В этой секции отображается как еще не задействованная, так и уже освобожденная память, но на самом деле, еще не задействованная память относится к другой категории — «Нулевые страницы» (Zero Page), которая так называется, потому что эти страницы инициализированы нулевым значением и готовы для использования.
О проблеме свободной памяти
Теперь, когда вы в общих чертах представляете, как работает диспетчер памяти, ненадолго остановимся на распространенном заблуждении, связанном с системой управления памятью в Windows 7. Как видно из рис. C, секция свободной памяти — одна из самых маленьких в гистограмме. Тем не менее, ошибочно на этом основании полагать, будто Windows 7 потребляет чересчур много памяти и что система не может нормально работать, если свободной памяти так мало.
На самом деле, все совсем наоборот. В контексте принятого в Windows 7 подхода к управлению памятью, свободная память бесполезна. Чем больше памяти задействовано, тем лучше. Заполняя память до максимума и постоянно перемещая страницы из одной категории в другую с использованием системы приоритетов, Windows 7 повышает эффективность работы и предотвращает попадание данных в файл подкачки, не давая ошибкам отсутствия страницы в памяти замедлить быстродействие.
Мониторинг памяти
Хотите понаблюдать систему управления памятью Windows 7 в действии? Перезагрузите компьютер и сразу же после запуска откройте Монитор ресурсов Windows 7. Перейдите на вкладку «Память» и обратите внимание на соотношение секций в гистограмме физической памяти.
Затем начните запускать приложения. По мере запуска следите за изменением гистограммы. Запустив как можно больше приложений, начните закрывать их по одному и наблюдайте, как изменяется соотношение секций в гистограмме физической памяти.
Проделав этот экстремальный эксперимент, вы поймете, как Windows 7 управляет памятью на вашем конкретном компьютере, и сможете использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти в нормальных условиях повседневной работы.
А что думаете вы?
Нравится ли вам идея использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти? Поделитесь своим мнением в комментариях!
Автор: Greg Shultz
Перевод SVET
Оцените статью: Голосов
Монитор ресурсов Windows как средство диагностики.
Монитор ресурсов Windows позволяет просматривать наиболее полную информацию по использованию системой и программами процессора, хранилища информации, памяти. Кроме того, в режиме реального времени позволяет наблюдать за конкретными процессами (в т.ч. и зависшими), определять использующие процесс приложения и фалы, и контролировать сами процессы и службы.
Запуск Монитора ресурсов
Для быстрого вызова Монитора зажимаем сочетание Win + R для вызова строки поиска и вводим быструю команду:
Эта же команда доступна и для командной строки cmd от имени администратора:
Монитор ресурсов представляет собой программу, состоящую из нескольких вкладок, которые дублируют строки главного окна-вкладки приложения Обзор:
Все свёрнутые в строку данные разворачиваются с подробным описанием каждого из процесса и служб Windows. По вашему выбору графическое отображение диаграмм в правом квадранте окна программы также можно изменить.
За чем следит Монитор ресурсов?
В режиме реального времени вы можете просматривать информацию о работе и загрузке процессора, RAM, скорости обмена данными с жёстким диском и данными по сетевому соединению. Причём выбираемый галочкой процесс во вкладке Обзор автоматически применяет фильтр на остальные строчки того же окна, помещая сам процесс в верхнюю часть окна. Вот как, например, выглядит скачивание и установка обновлений в Windows 7:
- TrustedInstaller — доверенное приложение отображается как …
- Установщик модулей Windows, забирая четверть мощности центрального процессора,…
- начиная запись с отображаемыми во вкладке Диск…
- файлами на жёстком диске компьютера, показывая полную информацию о потребляемых при этом ресурсах; для каждого файла показан полный путь к месту его хранения.
- При этом в правой части окна подсвечивается та же информация (участие выбранного процесса), но в виде диаграммы.
Конкретика или что во вкладках Монитора?
От обзорной вкладки перейдём к конкретным показателям. Окна Монитора доступны к изменениям и визуальным настройкам:
Каждое из окон показывает список программ, которые в данный момент потребляют хоть какие-то ресурсы компьютера. К вашему сведению предлагаются все модули, файлы библиотек, ключи реестра, события и пути к местам хранения файлов, связанных с выбранным процессом:
Переходя по каждой из вкладок, вы можете увидеть как выбранный процесс (или процессы) влияет на загрузку процессора, сколько они ил он потребляют оперативной памяти. Можно проверить, идёт ли сейчас от имени процесса запись на диски, и общается ли сейчас процесс с кем-либо по сети, отнимая сетевой трафик. Во вкладках…
- ЦП — отображается информация о загрузке процессора над каждой из выполняемых задач. Помните, что некоторые приложения (чаще всего браузеры) разбивают себя на несколько одноимённых процессов с целью предотвращения зависания, сильной нагрузки на ЦП и потери данных. Дескрипторы в части окна ниже показывают связанные с процессами файлы библиотек и ключи реестра, которые сейчас обрабатываются. Отсюда можно проследить практически все цепочки, связанные с любым процессом в вашей системе.
- Память — выводится список тех же процессов с потребляемыми ресурсами RAM, причём внизу вкладки можно увидеть состояние общей памяти в виде строки состояние с всплывающими подсказками:
Обратите внимание на столбец с наименованием Ошибок отсутствия страниц в памяти в секунду. Нормальный показатель здесь — 0, но и другая цифра не должна вас смущать. Цифры в столбце не означают ошибки памяти, это лишь показатель того, что системе в какой-то момент «немного не хватило» физических объёмов RAM, и та отправилась за дополнительными объёмами оперативки к swap-файлу на жёстком диске. Повторюсь, эта ситуация при небольших показателях в столбце абсолютно нормальна.
- Диск — показана информация по степени загруженности жёсткого диска выбранным процессом. Их уже не так много, так как нет смысла перечислять все процессы, висящие в памяти Windows. Отсюда хорошо видно, куда сейчас записываются данные или из которых осуществляется чтение.
Разверните строку Запоминающие устройства: увидите активность установленных логических томов по отношению к выбранному процессу. Эта вкладка, кстати, прекрасный инструмент для первоначального анализа «непонятных» процессов: слишком активная деятельность несистемных и неизвестных вам процессов должна вас насторожить. Плюсом к тому, показатель Длины очереди диска не должен забегать за единицы и, тем более, десятки единиц, если сейчас не происходит интенсивная запись чего-либо. В противном случае, присмотритесь к происходящим процессам.
- Сеть — показана сетевая активность процессов. Здесь всё просто — если процесс отображён, значит его сейчас используют чьи-то сторонние сервера. И именно эти процессы сейчас грузят ваше сетевое соединение. Разверните все строчки основного окна вкладки:
Монитор ресурсов во вкладке подробно показывает ваши (локальные) и внешние IP адреса, порты и протоколы, по которым сейчас ведут общение выбранные процессы. Если вы имеете представления об этих понятиях, дальнейшие объяснения излишни. Смотрите и проверяйте.
Что Монитор ресурсов может починить?
Ничего. Монитор ресурсов не является ремонтной утилитой системы, однако является прекрасным инструментом предоставления отчётности. При этом является развёрнутым вариантом или своеобразным «аналогом» Диспетчера задач с некоторыми похожими функциями. Так, Монитор ресурсов способен не только приостанавливать выбранные процессы, но и выдавать отчёт по тем, что зависли во время выполнения. Более того, по каждому процессу из списка можно будет получить справку: нажмите правой мышкой по любому процессу, выберите Поиск в интернете, и браузер по умолчанию ответит поисковой выдачей по этому процессу.
Если вы хотите получить отчёт в общем виде о состоянии системы, возможно вас заинтересует готовый вариант по общим данным состояния Windows, который можно получить из строки cmd от Системного монитора:
Проблемы: Монитор ресурсов не отвечает
Разберём тот случай, когда Монитор не появляется после вызова на экран. В этом случае вам следует вспомнить, что сама утилита под именем resmon.exe прежде всего располагается в директории Windows с остальными системными приложениями по адресу:
C:WindowsSystem32
Попробуйте запустить утилиту прямо оттуда. Если вы испытываете проблемы с Монитором в Windows 7, то попробуйте для начала переключиться на любую тему Аэро. Если прокатило, то для включения Монитора ресурсов вам придётся постоянно менять тему на какую-то из состава пакета Aero:
Причиной, а точнее, решением проблемы с Монитором может послужить изменение размеров текста и других элементов на экране. Попробуйте изменить их и проверьте:
Панель управленияВсе элементы панели управленияЭкран
Следующим шагом по решению проблем является чистая загрузка Windows. Так, вам необходимо отключить все дополнительные программы, службы и драйвера, воспользовавшись любым удобным инструментом. Это может утилита msconfig или раздел Автозагрузка программы CCleaner.
Наконец, финальный этап исправления любых ошибок, связанных с системными утилитами Windows. Это проверка состояния системных файлов. Для запуска откройте консоль команд cmd от имени администратора и наберите :
Ошибок отсутствия страницы в памяти что это
Сообщения: 10692
Благодарности: 2891
Конфигурация компьютера | |
Процессор: IntelCorei3-2100 CPU @ 3.10GHz, 3100 МГц, ядер: 2, логических процессоров: 4 | |
Материнская плата: MSI H61M-P21 (MS-7680) (B3.0) | |
Память: Kingston 99U5471-052.A00LF 8Gb DDR3-1333 DDR3 SDRAM; Samsung M378B5773DH0-CH9 2Gb DDR3-1333 DDR3 SDRAM | |
HDD: WDC Caviar Green WD10EARS-22Y5B1 ATA Device 1Т (1000 Gb), WDC Caviar Blue WD10EZEX-08M2NA0 ATA Device 1Т (1000 Gb) | |
Видеокарта: Sapphire Radeon HD 6570 650Mhz PCI-E 2.1 2048Mb 1600Mhz 128 bit DVI HDMI HDCP | |
Звук: VIA VT1708S VIA High Definition Audio | |
Блок питания: OCZ ZS Series Power Supply 550W 2014 г. | |
CD/DVD: ATAPI iHAS122 ATA Device | |
Монитор: LG FLATRON E2050 1600×900 | |
ОС: Microsoft Windows 7 Home Basic x86, Microsoft Windows 10 Home x64 . | |
Индекс производительности Windows: 5.9 | |
Прочее: Multi Flash Reader USB Device, Logitech HD Webcam C310 |
По этому файлу ПКМ > Анализ цепочки ожидания. Что там ?
1. Откройте командную строку с Административными правами.
2. В командной строке введите следующую команду и нажмите клавишу ВВОД:
По окончании выложите C:windowsLogsCBS CBS.log в архиве.
Запустите AIDA64 Portable от имени Администратора > Сверху, в окне программы AIDA нажмите «Отчет» >
Далее > выберите «Аппаратные разделы» > Далее > Простой текст > Готово > Сохранить в файл.
Файл, в архиве, подкрепите к сообщению.
——-
Будь джентльменом, если есть удача. А нет удачи, джентльменов нет . Нажми .
Сообщения: 23
Благодарности: 1
Сообщения: 3
Благодарности: 0
Доброго времени суток господа.
Из железа имеем:
В общем суть проблемы такова — при первом запуске или же после долговременного перерыва (как я себе это вижу, до того момента как файлы браузера выгрузятся из памяти) просто невообразимо долго грутится (причем абсолютно любой) браузер, к примеру одна единственная начальная страниц хрома в лучшем случае открывается секунд 30, в худшем и по 2-3 минуты ждать приходится. Всё это безобразие сопровождается Ошибками отсутствия страниц, значения скачут, но иной раз даже до 500 с копейками прыгает, та же ерунда происходит после долговременного простоя ноута (минут 20-30) или просмотра продолжительного видеоряда.
Пытаясь оптимизировать, нашел лишь огромное множество разочарований, автозагрузка — только минимально необходимый набор программ. Антивирус систему не грузит (MSE же) ну вообщем в целом всё работает шустро, только вот пожалуй в этих двух случаях проблемы (но так вот повелось, что это и есть основные режимы работы сего аппарата).
Изначально грешил на хард, но проверив его, убедился в том, что он еще живой и затем отключил спящий режим для жесткого диска в настройках электропитания, хотя из него он и нормально выходил.
так. что еще можно сказать то.
После выхода ноута из режима гибернации/сна/выключения экрана — минут 10 невозможно его терпеть, вообщем ужасные тормоза (и как я недавно заметил, специфическим поднятием ошибок отсутствия страниц)
Пожалуй это и натолкнуло меня написать пост именно здесь, а не создавать тему, т.к. на первый взгляд кажется всё это тесно связано между собой.
P.S. Конечно — 2 Гб RAM довольно таки мало, но ПК с примерно таким-же железом (отличие в более слабой GPU и и немного более мощный CPU) работает в разы быстрее и уж точно без минутных «залипаний» на то, что бы открыть аимп. я конечно не ванга, но так быть не должно
По поводу раммапа, похоже там критических утечек нет, но на мой взгляд многовато всё же для 2-х гигов)
Сейчас вот после перезагрузки проведу тест RAM на ошибки, но не думаю что он что-то покажет, за всё время жизни ноутбука — ни одного синего экрана не было.
Еще одно (на мой взгляд важное) замечание — Первое включение ноутбука, довольно длительное (если учитывать то, что автозагрузка практически пуста), но если сразу после включения перезагрузить ОС, то он заметно (сильно заметно) быстрее включается и в последствии немного быстрее реагирует на команды.
Вытесняющие/невытесняющие алгоритмы.
В случае вытесняющего алгоритма операционная система в любой момент времени может прервать выполнение текущего потока и переключить процессор на другой поток. В невытесняющих алгоритмах поток, которому предоставлен процессор, только сам решает, когда передать управление операционной системе.
Алгоритмы с квантованием.
Каждому потоку предоставляется квант времени, в течение которого поток может выполняться на процессоре. По истечении кванта операционная система переключает процессор на следующий поток в очереди. Квант обычно равен целому числу интервалов системного таймера 1 .
Алгоритмы с приоритетами.
Каждому потоку назначается приоритет (priority) – целое число, обозначающее степень привилегированности потока. Операционная система при наличии нескольких готовых к выполнению потоков выбирает из них поток с наибольшим приоритетом.
В Windows реализован смешанный алгоритм планирования – вытесняющий, на основе квантования и приоритетов.
- Тип многозадачности для приложения DOS
- Гарантии обслуживания
- Планирование процессов переднего плана
- Назначение файла подкачки
- Процессы Р1, Р2, Р3 выделяют 100, 20, 80 Мб памяти. В системе 128Мб ОП. Каков размер занятой памяти в файле подкачки. Какой размер файла подкачки.
- Что такое «страничная ошибка»?
Прерывание 14 —
Страничная ошибка
(#PF): Intel386 …
Генерируется, если страничный механизм активизирован (CR0.PG = 1) и при трансляции линейного адреса в физический возникает одна из следующих ситуаций:
- элемент таблицы страниц или каталога страниц, используемый при трансляции адреса, имеет нулевой бит присутствия
, т.е. нужная таблица страниц или страница не присутствует в физической памяти; - процедура не располагает уровнем привилегий
, достаточным для доступа к выбранной странице или пытается произвести запись в страницу, защищенную от записи для текущего уровня привилегий.
Обработчик страничной ошибки получает информацию о ее причине из двух источников: кода ошибки, помещаемого в стек, и содержимого регистра CR2, который содержит линейный адрес, вызвавший ошибку. Код страничной ошибки имеет специальный формат (рис. 3.7.).
Прерванная программа после устранения причин, вызвавших страничную ошибку (например, загризки страницы в физическую память), может быть продолжена без каких-либо дополнительных корректировок.
Если страничная ошибка была вызвана в связи с нарушением привилегий страничной защиты, то бит доступа (A) в соответствующем элементе каталога страниц устанавливается. Поведение бита доступа в соответствующем элементе таблиц страниц для этого случая не регламентируется в процессорах Intel и может быть разным в различных моделях.
- Высокая интенсивность ошибок страниц говорит о:
Ненадежности программы
Ненадежности оперативной памяти
Иное: пояснить
Графа «Ошибок отсутствия страницы в памяти/сек.»
В графе «Ошибок отсутствия страницы в памяти/сек.» (Hard Faults/sec) указано среднее за последнюю минуту количество ошибок отсутствия страницы в памяти в секунду. Если процесс пытается использовать больше физической памяти, чем доступно в данный момент времени, система записывает часть данных из памяти на диск — в файл подкачки. Последующее обращение к данным, сохраненным на диск, и называется ошибкой отсутствия страницы в памяти.
О чем говорят ошибки отсутствия страницы в памяти
Теперь, когда вы представляете, какие сведения собраны в таблице «Процессы», давайте посмотрим, как с их помощью следить за распределением памяти. При запуске приложений и работе с файлами диспетчер памяти отслеживает объем рабочего набора для каждого процесса и фиксирует запросы на дополнительные ресурсы памяти. По мере увеличения рабочего набора процесса, диспетчер соотносит эти запросы с потребностями ядра и других процессов. Если доступного адресного пространства недостаточно, диспетчер уменьшает объем рабочего набора, сохраняя данные из памяти на диск.
В дальнейшем при чтении этих данных с диска возникает ошибка отсутствия страницы в памяти. Это вполне нормально, но если ошибки происходят одновременно для разных процессов, системе требуется дополнительное время для чтения данных с диска. Слишком частые ошибки отсутствия страницы в памяти, соответственно, снижают быстродействие системы
. Вам наверняка доводилось наблюдать неожиданное замедление работы всех приложений, которое затем также неожиданно прекращалось. Почти наверняка это замедление было связано с активным перераспределением данных между физической памятью и подкачкой.
Отсюда следует вывод: если ошибки отсутствия страницы в памяти для того или иного процесса происходят слишком часто и притом регулярно, компьютеру не хватает физической памяти.
Чтобы было удобнее наблюдать за процессами, вызывающими частые ошибки отсутствия страницы в памяти, можно отметить их флажками. При этом выбранные процессы переместятся наверх списка, а в графике ошибок отсутствия страницы в памяти будут представлены оранжевой кривой.
Стоит учитывать, что распределение памяти зависит от целого ряда других факторов, и мониторинг ошибок отсутствия страницы в памяти — не лучший и не единственный способ выявления проблем. Тем не менее, он может послужить неплохой отправной точкой для наблюдения.
- Как формируется приоритет потока в Windows
Приоритеты
В ОС Windows реализовано вытесняющее приоритетное планирование, когда каждому потоку присваивается определенное числовое значение — приоритет, в соответствии с которым ему выделяется процессор. Потоки с одинаковыми приоритетами планируются согласно алгоритму Round Robin (карусель). Важным достоинством системы является возможность вытеснения потоков, работающих в режиме ядра — код исполнительной системы полностью реентерабелен. Не вытесняются лишь потоки, удерживающие спин-блокировку (см. «Синхронизация потоков»). Поэтому спин-блокировки используются с большой осторожностью и устанавливаются на минимальное время.
В системе предусмотрено 32 уровня приоритетов. Шестнадцать значений приоритетов (16-31) соответствуют группе приоритетов реального времени, пятнадцать значений (1-15) предназначены для обычных потоков, и значение 0 зарезервировано для системного потока обнуления страниц (см. рис. 6.2).
Рис. 6.2.
Приоритеты потоков
Чтобы избавить пользователя от необходимости запоминать числовые значения приоритетов и иметь возможность модифицировать планировщик, разработчики ввели в систему слой абстрагирования приоритетов
. Например, класс приоритета для всех потоков конкретного процесса можно задать с помощью набора констант-параметров функции SetPriorityClass, которые могут иметь следующие значения:
- реального времени (REALTIME_PRIORITY_CLASS) — 24
- высокий (HIGH_PRIORITY_CLASS) — 13
- выше нормы (ABOVE_NORMAL_PRIORITY_CLASS) 10
- нормальный (NORMAL_PRIORITY_CLASS) — 8
- ниже нормы (BELOW_NORMAL_PRIORITY_CLASS) — 6
- и неработающий (IDLE_PRIORITY_CLASS) 4
Относительный приоритет потока устанавливается аналогичными параметрами функции SetThreadPriority:
Совокупность из шести классов приоритетов процессов и семи классов приоритетов потоков образует 42 возможные комбинации и позволяет сформировать так называемый базовый приоритет потока
Базовый приоритет процесса и первичного потока по умолчанию равен значению из середины диапазонов приоритетов процессов (24, 13, 10, 8, 6 или 4
). Смена приоритета процесса влечет за собой смену приоритетов всех его потоков, при этом их относительные приоритеты остаются без изменений.
Приоритеты с 16 по 31 в действительности приоритетами реального времени не являются, поскольку в рамках поддержки мягкого реального времени, которая реализована в ОС Windows, никаких гарантий относительно сроков выполнения потоков не дается. Это просто более высокие приоритеты, которые зарезервированы для системных потоков и тех потоков, которым такой приоритет дает пользователь с административными правами. Тем не менее, наличие приоритетов реального времени, а также вытесняемость кода ядра, локализация страниц памяти (см. «Функционирование менеджера памяти») и ряд дополнительных возможностей — все это позволяет выполнять в среде ОС Windows приложения мягкого реального времени, например, мультимедийные. Системный поток с нулевым приоритетом занимается обнулением страниц памяти. Обычные пользовательские потоки могут иметь приоритеты от 1 до 15.
Похожая информация.
В своей прошлой статье « » я рассказал о возможностях Монитора ресурсов Windows 7 (Resource Monitor), объяснил, как с его помощью наблюдать за распределением системных ресурсов между процессами и службами, а также упомянул, что его можно использовать для решения конкретных задач — например, для анализа расходования памяти. Именно об этом и пойдет речь в данной статье.
Немного о памяти
Прежде чем приступать к анализу, коротко расскажу о том, управляет памятью. После этого вам будет проще понять, какая информация представлена в Мониторе ресурсов Windows 7.
Диспетчер памяти Windows 7 создает виртуальную систему памяти, которая состоит из доступной физической RAM и файла подкачки на жестком диске. Это позволяет операционной системе выделять блоки памяти фиксированной длины (страницы) с последовательными адресами в физической и виртуальной памяти.
Запуск Монитора ресурсов Windows 7
Чтобы запустить Монитор ресурсов Windows 7, откройте меню «Пуск» (Start), введите в строке поиска «Resmon.exe» и нажмите . В открывшемся окне выберите вкладку «Память» (Memory, рис. A).
Рисунок A. На вкладке «Память» в Мониторе ресурсов Windows 7 приводятся подробные сведения о распределении памяти.
Таблица «Процессы»
На вкладке «Память» есть таблица «Процессы» (Processes, рис. B), в которой перечислены все запущенные процессы, а сведения об используемой памяти разбиты на несколько категорий.
Рисунок B. Сведения об используемой памяти для каждого процесса разбиты на несколько категорий.
Графа «Образ»
В колонке «Образ» (Image) указывается имя исполняемого файла процесса. Процессы, запущенные приложениями, узнать очень легко — например, процесс «notepad.exe» со всей очевидностью принадлежит Блокноту (Notepad). Процессы с именем «svchost.exe» представляют различные службы операционной системы. Название службы указывается в скобках рядом с именем процесса.
Графа «ИД процесса»
В колонке «ИД процесса» (PID) указывается номер процесса — уникальное сочетание цифр, позволяющее идентифицировать запущенный процесс.
Графа «Завершено»
В столбце «Завершено» (Commit) указывается объем виртуальной памяти в килобайтах, зарезервированный системой для данного процесса. Сюда входит и используемая физическая память, и сохраненные в файле подкачки страницы.
Графа «Рабочий набор»
В графе «Рабочий набор» (Working Set) указывается объем физической памяти в килобайтах, используемой процессом в данный момент времени. Рабочий набор складывается из общей и частной памяти.
Графа «Общий»
В колонке «Общий» (Shareable) указан объем физической памяти в килобайтах, которую данный процесс использует совместно с другими. Использование одного сегмента памяти или страницы подкачки для родственных процессов позволяет сэкономить место в памяти. При этом физически сохраняется только одна копия страницы, которая затем сопоставляется с виртуальным адресным пространством других процессов, которые к ней обращаются. Например, все процессы, инициированные системными библиотеками DLL — Ntdll, Kernel32, Gdi32 и User32 — используют общую память.
Графа «Частный»
В столбце «Частный» (Private) указывается объем физической памяти в килобайтах, используемой исключительно данным процессом. Именно это значение позволяет определить, сколько памяти нужно тому или иному приложению для работы.
Графа «Ошибок отсутствия страницы в памяти/сек.»
В графе «Ошибок отсутствия страницы в памяти/сек.» (Hard Faults/sec) указано среднее за последнюю минуту количество ошибок отсутствия страницы в памяти в секунду. Если процесс пытается использовать больше физической памяти, чем доступно в данный момент времени, система записывает часть данных из памяти на диск — в файл подкачки. Последующее обращение к данным, сохраненным на диск, и называется ошибкой отсутствия страницы в памяти.
О чем говорят ошибки отсутствия страницы в памяти
Теперь, когда вы представляете, какие сведения собраны в таблице «Процессы», давайте посмотрим, как с их помощью следить за распределением памяти. При запуске приложений и работе с файлами диспетчер памяти отслеживает объем рабочего набора для каждого процесса и фиксирует запросы на дополнительные ресурсы памяти. По мере увеличения рабочего набора процесса, диспетчер соотносит эти запросы с потребностями ядра и других процессов. Если доступного адресного пространства недостаточно, диспетчер уменьшает объем рабочего набора, сохраняя данные из памяти на диск.
В дальнейшем при чтении этих данных с диска возникает ошибка отсутствия страницы в памяти. Это вполне нормально, но если ошибки происходят одновременно для разных процессов, системе требуется дополнительное время для чтения данных с диска. Слишком частые ошибки отсутствия страницы в памяти, соответственно, снижают быстродействие системы. Вам наверняка доводилось наблюдать неожиданное замедление работы всех приложений, которое затем также неожиданно прекращалось. Почти наверняка это замедление было связано с активным перераспределением данных между физической памятью и подкачкой.
Отсюда следует вывод: если ошибки отсутствия страницы в памяти для того или иного процесса происходят слишком часто и притом регулярно, компьютеру не хватает физической памяти.
Чтобы было удобнее наблюдать за процессами, вызывающими частые ошибки отсутствия страницы в памяти, можно отметить их флажками. При этом выбранные процессы переместятся наверх списка, а в графике ошибок отсутствия страницы в памяти будут представлены оранжевой кривой.
Стоит учитывать, что распределение памяти зависит от целого ряда других факторов, и мониторинг ошибок отсутствия страницы в памяти — не лучший и не единственный способ выявления проблем. Тем не менее, он может послужить неплохой отправной точкой для наблюдения.
Таблица «Физическая память»
В таблице «Процессы» приводятся детальные сведения о распределении памяти между отдельными процессами, а таблица «Физическая память» (Physical Memory) дает общую картину использования RAM. Ее ключевой компонент — уникальная гистограмма, показанная на рис. C.
Рисунок C. Гистограмма в таблице «Физическая память» позволяет составить общее представление о распределении памяти в Windows 7.
Каждая секция гистограммы обозначена собственным цветом и представляет определенную группу страниц памяти. По мере использования системы, диспетчер памяти в фоновом режиме перемещает данные между этими группами, поддерживая тонкий баланс между физической и виртуальной памятью для обеспечения эффективной работы всех приложений. Давайте рассмотрим гистограмму поподробнее.
Секция «Зарезервированное оборудование»
Слева расположена секция «Зарезервированное оборудование» (Hardware Reserved), обозначенная серым цветом: это память, выделенная на нужды подключенного оборудования, которую оно использует для взаимодействия с операционной системой. Зарезервированная для оборудования память заблокирована и недоступна диспетчеру памяти.
Обычно объем памяти, выделенной оборудованию, составляет от 10 до 70 Мбайт, однако этот показатель зависит от конкретной конфигурации системы и в некоторых случаях может достигать нескольких сотен мегабайт. К компонентам, влияющим на объем зарезервированной памяти, относятся:
;
компоненты материнской платы — например, усовершенствованный программируемый контроллер прерываний ввода/вывода (APIC);
звуковые карты и другие устройства, осуществляющие ввод/вывод с отображением на память;
шина PCI Express (PCIe);
видеокарты;
различные наборы микросхем;
флеш-накопители.
Некоторые пользователи жалуются, что в их системах для оборудования зарезервировано ненормально много памяти. Мне с такой ситуацией сталкиваться не приходилось и потому я не могу ручаться за действенность предложенного решения, но многие отмечают, что обновление версии BIOS позволяет решить проблему.
Секция «Используется»
Секция «Используется» (In Use, рис C), обозначенная зеленым цветом, представляет количество памяти, используемой системой, драйверами и запущенными процессами. Количество используемой памяти рассчитывается, как значение «Всего» (Total) за вычетом суммы показателей «Изменено» (Modified), «Ожидание» (Standby) и «Свободно» (Free). В свою очередь, значение «Всего» — это показатель «Установлено» (Installed RAM) за вычетом показателя «Зарезервированное оборудование».
Секция «Изменено»
Оранжевым цветом выделена секция «Изменено» (Modified), в которой представлена измененная, но не задействованная память. Фактически она не используется, но может быть в любой момент задействована, если снова понадобится. Если память не используется достаточно давно, данные переносятся в файл подкачки, а память переходит в категорию «Ожидание».
Секция «Ожидание»
Секция «Ожидание», обозначенная синим цветом, представляет страницы памяти, удаленные из рабочих наборов, но по-прежнему с ними связанные. Другими словами, категория «Ожидание» — это фактически кэш. Страницам памяти в этой категории присваивается приоритет от 0 до 7 (максимум). Страницы, связанные с высокоприоритетными процессами, получают максимальный приоритет. Например, совместно используемые процессы обладают высоким приоритетом, поэтому связанным с ними страницам присваивается наивысший приоритет в категории «Ожидание».
Если процессу требуются данные с ожидающей страницы, диспетчер памяти сразу же возвращает эту страницу в рабочий набор. Тем не менее, все страницы в категории «Ожидание» доступны для записи данных от других процессов. Когда процессу требуется дополнительная память, а свободной памяти недостаточно, диспетчер памяти выбирает ожидающую страницу с наименьшим приоритетом, инициализирует ее и выделяет запросившему процессу.
Секция «Свободно»
В категории «Свободно», обозначенной голубым цветом, представлены страницы памяти, еще не выделенные ни одному процессу или освободившиеся после завершения процесса. В этой секции отображается как еще не задействованная, так и уже освобожденная память, но на самом деле, еще не задействованная память относится к другой категории — «Нулевые страницы» (Zero Page), которая так называется, потому что эти страницы инициализированы нулевым значением и готовы для использования.
О проблеме свободной памяти
Теперь, когда вы в общих чертах представляете, как работает диспетчер памяти, ненадолго остановимся на распространенном заблуждении, связанном с системой управления памятью в Windows 7. Как видно из рис. C, секция свободной памяти — одна из самых маленьких в гистограмме. Тем не менее, ошибочно на этом основании полагать, будто Windows 7 потребляет чересчур много памяти и что система не может нормально работать, если свободной памяти так мало.
На самом деле, все совсем наоборот. В контексте принятого в Windows 7 подхода к управлению памятью, свободная память бесполезна. Чем больше памяти задействовано, тем лучше. Заполняя память до максимума и постоянно перемещая страницы из одной категории в другую с использованием системы приоритетов, Windows 7 повышает эффективность работы и предотвращает попадание данных в файл подкачки, не давая ошибкам отсутствия страницы в памяти замедлить быстродействие.
Мониторинг памяти
Хотите понаблюдать систему управления памятью Windows 7 в действии? Перезагрузите компьютер и сразу же после запуска откройте Монитор ресурсов Windows 7. Перейдите на вкладку «Память» и обратите внимание на соотношение секций в гистограмме физической памяти.
Затем начните запускать приложения. По мере запуска следите за изменением гистограммы. Запустив как можно больше приложений, начните закрывать их по одному и наблюдайте, как изменяется соотношение секций в гистограмме физической памяти.
Проделав этот экстремальный эксперимент, вы поймете, как Windows 7 управляет памятью на вашем конкретном компьютере, и сможете использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти в нормальных условиях повседневной работы.
А что думаете вы?
Нравится ли вам идея использовать Монитор ресурсов Windows 7 для наблюдения за распределением памяти? Поделитесь своим мнением в комментариях!
ы подключили новое устройство, а оно не спешит работать, или старое устройство перестало функционировать, или делает свою работу некорректно. Что же делать в этих случаях? Переустанавливать всё? Хлопотно, да и не всегда в этом есть необходимость. Как же узнать в чём причина и как её устранить? Очень просто. Дело в том, что в ОС семейства Windows,
и не только, имеется, некий
Диспетчер устройств,
на самом деле очень нужный и полезный менеджер, если его можно так назвать. Вот он то, нам и поможет выяснить в чём причина неполадки, а моя шпаргалка — устранить проблему. Итак, в выше упомянутом
Диспетчере устройств
остаються следы ошибок в работе устройств в виде кодов. Зная код ошибки, нетрудно установить причину неполадки. Для непосвящённых, коды — это всего лишь непонятные и ничего не говорящие цифры. Но знающему пользователю, они могут сказать о многом. Постараюсь, насколько мне это удасться, пролить свет на эту тему.
Для просмотра ошибок устройств, нам прежде всего необходимо войти в сам Диспетчер устройств. Делается это так. Войдите в
Панель управления
из меню
Пуск (
можно,
Мой
компьютер
, правой клавишей —
Свойства
—
Диспетчер устройств,
а можно и через задание команды в
выполнить
, но зачем всё усложнять). Если мы входим через
Панель
управления
, то путь таков:
Система — Оборудование — Диспетчерн устройств
. Выберем, войдя в меню
Диспетчер устройств
, тип интересующего нас устройства (клавиатура, принтер, модем и т.д.), щёлкнем на нём дважды, в результате увидим входящие в этот тип устройства. Выбирем нужное нам устройство и дважды щёлкнем на нём. Смотрим графу на вкладке О
бщие, Состояние устройства.
Если имеется проблема с работой устройства, то она будет отображена здесь в виде кода ошибки. Итак мы видим цифры и числа. Что же они обозначают. Ниже я привожу полный список ошибок, с кратким описанием ошибки и возможных способах устранения. Красным цветом выделен код ошибки, синим её описание и чёрным устранение.
Код 1
Проблема с настройкой устройства, не правильные настройки или отсутствует драйвер.
Нажмите кнопку
Обновить драйвер
, для запуска мастера
Обновление оборудования
. Если вообще нет драйвера — установите его.
Код 3
Повреждён драйвер устройства, как вариант не хватает оперативной памяти для корректной работы устройства.
1.
Удалим повреждённый драйвер и установим новый. Для этого: Свойства — Драйвер — Удалить, далее следуем указаниям мастера. Перезагрузка. Открываем опять
Диспетчер устройств
—
Действие
—
Обновить конфигурацию оборудования
и следуем указаниям мастера. 2. Если проблема в нехватке виртуальной памяти, закроем работающие приложения, что бы разгрузить память. Что бы проверить состояние памяти нам нужно попасть в
Диспетчер задач
, для этого жмём сочетание клавиш
Ctrl+Shift+Esc.
Настройки виртуальной памяти мы можем посмотреть ещё щёлкнув правой клавишей
Мой компьютер
—
Свойства — Дополнительно — Быстродействие — Настройки (Параметры)
. Вы можете попробовать увеличить файл подкачки (как это делается, я описывал в одной из предыдущих статей моего блога ), но это далеко не радикальная мера. Придётся вам увеличивать оперативную память. Как это делается — отдельная тема, выходящая за рамки этого поста.
Код 10
В разделе реестра имеется соответствующий устройству параметр
FailReasonString,
значение этого параметра и отображается в данных ошибки, то есть, если параметра, как такового нет, то появляется код ошибки, проще говоря — запуск устройства не возможен.
Обновите драйвер, как указано выше. Или установите более новый.
Код 12
Нет запаса ресурсов, необходимых для этого устройства.
Отключите другие работающие устройства, хотя бы одно, для этого воспользуйтесь мастером устранения неполадок, который, если вы будете следовать его указаниям, отключит конфликтное устройство. (В кратце напомню: Свойства — Общие — Устранение неполадок.)
Код 14
Требует перезагрузки ПК для работы этого устройства.
Код 16
Невозможно выявить ресурсы, которые необходимы для работы устройства, устройство настроено не полностью.
Нужно назначить устройству дополнительные ресурсы. Но это можно сделать без проблем если устройство относится к
Plug and Play.
Свойства — Ресурсы.
Если в списке ресурсов есть ресурс с знаком?, выбираем его, чтобы назначить выбранному устройству. Если ресурс не возможно изменить, жмём
Изменить параметры
, если эта функция недоступна, снимаем галочку с
Автоматическая настройка
Код 18
Переустановите драйвер для устройства.
Пробуем обновить драйвер или удалить и сделать, как в примере с
кодом 3.
Код 19
Недостаточные сведения в реестре о настройках устройства, либо настройки повреждены.
Запустите
Мастер устранения неполадок
и следуйте его указаниям, не поможет — переустановите устройство, как было сказано выше. (код 3). Либо, если не поможет, загрузите
Последнюю удачную конфигурацию.
Если и это не поможет — вам нужна помощь специалиста, так, как необходимо редактировать системный реестр. Неимея знаний и опыта, самостоятельно, там вам делать нечего, любой сисадмин вам это подтвердит. Знающий и умеющий, сам знает, как это сделать, без меня. А неопытному, лучше и не пробовать. Реестр — сердце операционной системы и проводить операции на нём должен только опытный специалист, или под его руководством. Ни в коей мере не хочу ни кого обидеть, но если вы не работали с системным реестром и если вам дорог ваш компьютер, мой совет — забудьте туда дорогу. Я пишу не для профессионалов, им это не нужно, а для среднего пользователя. Конечно, я могу написать, как и что там делать, но это будет объяснение на пальцах и если вы, в результате малейшей ошибки, повредите свой компьютер, буду виноват я. Мне это совсем не нужно, да и вам то же.
Код 21 Устройство удаляется из системы, то есть операционная система пытается удалить устройство, но процесс ещё не завершён.
Выдержите паузу в несколько секунд и нажмите клавишу
Код 22 Устройство отключено.
Необходимо включить устройство.
Действие — Включить
и следуем дальнейшим инструкциям.
Код 24 Устройства нет или неправильно установлено, сбой в работе драйвера, может быть устройство было подготовлено к удалению.
Удалите устройство и установите заново.
Код 28 Нет драйвера.
Установите драйвер. Для этого нужно Обновить драйвер, действия, как в инструкции к Коду 1.
Код 29
Отключено устройство
. Необходимо разрешить работу устройства в
настройках
BIOS,
изучите инструкции к использованию устройства.
Код 31
Системе не удалось загрузить драйверы к этому устройству
. Обновите драйверы, как описывалось выше.
Код 32
Драйвер к этому устройству отключен в системном реестре
. Удалите и по-новой установите драйвер (описывалось выше)
Код 33
Операционная система не может определить ресурсы для данного
устройства
. Настройте устройство или замените его.
Код 34
Операционная система не может определить настройки
устройства
. Изучите прилагаемую документацию к оборудованию и настройте конфигурацию вручную на вкладке Ресурсы.
Код 35
Микропрограмма ПК неимеет нужных сведений для правильной
работы устройства
. Необходимо обновить
BIOS.
За инструкциями, как это сделать обратитесь к поставщику, а лучше воспользоваться услугами опытного мастера.
Код 36
Для работы устройства требуется прерывание
PCI,
а устройство настроено на прерывание
ISA,
или наоборот
. Необходимо изменить настройки
BIOS,
обратитесь к опытному мастеру.
Код 37
Операционная система неопознаёт драйвер к этому устройству
. Переустановите драйвер (описывалось выше).
Код 38
ОС не может загрузить драйвер для устройства, так как,
предыдущая версия драйвера осталась в памяти
. Необходимо перезагрузить ПК. Запустите мастер Устранения неполадок, если он не запустился (Свойства — Общие — Устранение неполадок) и следуйте указаниям мастера. После обязательная перезагрузка.
Код 39
ОС не может загрузить драйвер устройства. Драйвер повреждён
или его нет вовсе
. Переустановите драйвер, как было описано выше.
Код 40
Нет доступа к оборудованию, так, как нет информации в системном реестре или информация содержит ошибку
. Переустановите драйвер.
Код 41
Необнаружено устройство
. Запустите мастер Устранения неполадок (описано выше), если не помогло обновите конфигурацию оборудования (см. выше) или обновите драйвер. Если нет, установите более новую версию драйвера.
Код 42
В системе уже имеется такой драйвер. То есть имеются два разных устройства с одинаковым именем, возможно из-за ошибки
. Перезагрузите ПК.
Код 43
Остановка работы устройства из-за возникших проблем в его работе
. Запустите мастер Устранения неполадок и следуйте его указаниям.
Код 44
Приложение или служба остановили работу устройства
. Перезагрузите ПК.
Код 45
Устройство не подключено
. Подключите устройство.
Код 46
Такая ошибка появляется, если операционная система завершает свою работу. Ни чего не нужно делать, при следующем запуске ОС всё будет работать.
Код 47 Устройство было подготовлено для безопасного удаления, но ещё не удалено (например флеш)
. Извлеките устройство, затем подключите снова, перезагрузите ПК.
Код 48
Устройство, вернее его програмное обеспечение, заблокировано
. Обновите драйвер, или установите новый.
Код 49
Устройство не может быть запущено, так, как имеет большой объём системного куста реестра, который превышает допустимые параметры реестра
. Удалите из реестра устройства которые не используются. Можно сделать так: Диспетчер устройств — Вид — Показать скрытые устройства. Здесь вы увидите скрытые устройства, которые не подключены к вашему ПК. Выберите те устройства которые хотите удалить, кликнете Свойства для устройства — Драйвер — Удалить, далее следуйте указаниям мастера и в завершении перезагрузка ПК.
Пособие по удалению любых вирусов с ПК собственноручно. Все способы удаления вирусов реально работающие и проверенные на практике, пошаговая инструкция с илюстрациями — просто и доступно даже для школьника + видеоуроки + программа ultraiso
для создания загрузчиков+ полезные ссылки на инструменты в борьбе с вирусами. Скачать архив
Многие вычислительные
системы имеют в своем составе тот или
иной вариант диспетчера памяти (другое
название — устройство управления памятью
— УУП), с помощью которого многозадачная
операционная система выделяет память
каждой задаче и обеспечивает защиту от
программ пользователей. Например,
типичная проблема возникает в том
случае, когда прикладная программа
делает ошибку при вычислении адреса,
возможно используя слишком большое или
слишком маленькое значение индекса.
Если в системе нет защиты, такого рода
ошибка может привести к изменению кодов,
входящих в программы операционной
системы, или к модификации таблиц
устройств и даже вызвать незапланированный
запуск устройства с фатальными
последствиями, такими как несанкционированная
запись в фалл с данными.
Помимо защиты
операционной системы от неумышленного
разрушения диспетчер памяти обеспечивает
автоматическое перемещение программы.
С помощью диспетчера памяти логические
или программные адреса программ
пользователей преобразуются в физические,
или аппаратные адреса. Эти адреса могут
располагаться в памяти совершенно не
там, куда указывают логические адреса.
Преобразование адресов приводит к
полному выводу операционной системы и
защищенных устройств ввода-вывода из
адресного пространства пользователя.
Любая попытка чтения или записи в память
вне пространства адресов, отведенных
пользователю, заставляет процессор
аварийно завершить программу пользователя.
Информация обычно
передается порциями, состоящими из
фиксированного числа битов; МП 80386
использует порции размером 32 бит, если
только он не получил указаний об
уменьшении размеров порции до 16 бит.
Эти порции носят названия слов. Процесс
записи слова в запоминающую систему
называется записью в память,
процесс
получения слова из памяти —чтением
из памяти.
Существуют два
метода доступа к памяти: произвольный
и последовательный. Последовательный
доступ используется в тех запоминающих
системах, где обращение к словам
осуществляется в некотором определенном
заранее порядке. Произвольный доступ,
с другой стороны, предполагает возможность
обращения к словам запоминающей системы
в любом порядке и приблизительно за то
же время.
Каким бы совершенным
ни было ЗУ, при прохождении сигнала
между устройствами возникают задержки
в его распространении. Задержка
распространения определяется как время,
требуемое для прохождения логического
сигнала через устройство или
последовательность устройств, образующих
логическую цепочку. Эта задержка также
учитывает прохождение сигнала по всем
соединительным линиям между микросхемами.
Прямой доступ к
памяти (ПДП)
Прямой доступ к
памяти предоставляет возможность
внешним устройствам и памяти непосредственно
обмениваться данными без вмешательства
программы. ПДП обеспечивает максимальную
скорость ввода-вывода и максимальный
параллелизм процессов. В то время как
ввод-вывод по прерываниям и
программно-управляемый ввод-вывод
пересылают данные через процессор, в
случае ПДП данные передаются непосредственно
между устройством ввода-вывода и памятью.
Чтобы свести к
минимуму число шин данных, принимаются
специальные меры, позволяющие использовать
обычную магистраль для ПДП. Меры эти
заключаются в том, что процессор
освобождает магистраль, а внешнее
устройство захватывает ее и использует
для передачи данных.
На время ПДП выполнение
программы обычно приостанавливается.
Магистраль освобождается, как только
возбуждается управляющая линия запроса
ПДП. Процессор завершает текущую
операцию, освобождает линии адреса и
данных и устанавливает сигнал на одной
из линий управления, чтобы предотвратить
непреднамеренную расшифровку
неопределенных сигналов управления.
Интерфейс ввода-вывода
пересылает данные непосредственно в
память с помощью специального регистра.
Когда возникает необходимость в передаче
данных, интерфейс запрашивает у процессора
цикл памяти. Получив подтверждение,
интерфейс пересылает данные непосредственно
в память, в то время как процессор
останавливается на один цикл памяти.
Логика, выполняющая эту пересылку,
называется каналом.
Канал содержит
регистр для хранения адреса ячейки
памяти, в которую или из которой
осуществляется пересылка данных, В
большинстве случаев в канал входит
также счетчик слов для отсчета числа
выполненных прямых пересылок. Кроме
того, канал должен содержать схему,
обеспечивающую обмен управляющими
сигналами, синхронизацию и другие
вспомогательные операции. На рис. 13.4
показаны логические связи между ЦП и
контроллером ПДП.
Компоненты ПДП
.
Основными компонентами ПДП являются
триггер запроса, регистр адреса, счетчик
и регистр данных, который используется
периферийным устройством. Пересылка
данных по каналу ПДП включает несколько
этапов: 1) инициализация логики ПДП для
выполнения ПДП в течение повторяющихся
циклов занятия магистрали; 2) асинхронная
по отношению к операциям программы
активизация ПДП; 3) оповещение об окончании
пересылок (по сигналу от счетчика или
в результате изменении состояния
устройства); 4) вызов программы «очистки»
при окончании пересылок; 5) завершение
ПДП с помощью программы обработки
прерываний, которая возвращает управление
в основную программу.
Блочная пересылка
данных
. Процедура ПДП для высокоскоростных
устройств использует пересылку данных
блоками. Выполняя текущую программу,
процессор инициирует пересылку блока
данных и определяет число слов,
составляющих блок. Однако фактическая
передача слов выполняется под управлением
отдельного устройства — контроллера
ПДП. Максимальная скорость блочной
передачи по каналу ПДП ограничивается
только длительностью цикла памяти
(чтения или записи) и скоростью работы
контроллера ПДП.
ПДП с занятием цикла
памяти. Программа инициирует пересылку
блока, помещая стартовый адрес в адресный
счетчик, а число слов — в счетчик слов.
и выдавая команду запуска. Этот тип ПДП
часто называют ПДП с занятием цикла
памяти,
поскольку он приостанавливает
выполнение программы каждый раз
приблизительно на один машинный цикл.
При использовании
ПДП с занятием цикла памяти пересылка
данных осуществляется параллельно с
другими процессами, выполняемыми ЦП.
Последовательность действий здесь
такая же, как и при блочной передаче, за
тем исключением, что контроллер ПДП
занимает циклы памяти у процессора и,
следовательно, замедляет его работу
(блочная передача данных по каналу ПДП
также занимает
циклы памяти, если
только не используется ПДП по отдельной
шине).
Когда в Windows запускается процесс, многие из отображающих образы файлов EXE и DLL страниц могут уже находиться в памяти, поскольку они используются другими процессами. Пригодные для записи страницы образов помечены как «копирование при записи», чтобы их можно было совместно использовать до того момента, когда их понадобится модифицировать. Если операционная система узнает уже выполнявшийся ЕХЕ, то она может записать шаблон страничных ссылок (при помощи технологии, которую компания Microsoft называет Super-Fetch). Эта технология старается заблаговременно подкачать много нужных страниц (хотя процесс еще не получил по ним страничные ошибки). Это снижает латентность запуска приложений (чтение страниц с диска накладывается на выполнение инициализационного кода образов). Эта технология повышает производительность вывода на диск, поскольку дисковым драйверам легче организовать операции чтения (чтобы уменьшить необходимое время поиска). Этот процесс упреждающей подкачки страниц используется и во время загрузки системы, а также когда фоновое приложение выходит на передний план и при выходе системы из гибернации.
Упреждающая подкачка страниц поддерживается диспетчером памяти, но реализована она как отдельный компонент системы. Подкачиваемые страницы не вставляются в таблицу страниц процесса, вместо этого они вставляются в резервный список, из которого могут быть быстро вставлены в процесс (без обращения к диску).
Неотображенные страницы несколько отличаются — они не инициализируются путем чтения из файла. Вместо этого при первом обращении к неотображенной странице диспетчер памяти предоставляет новую физическую страницу (убедившись, что ее содержимое заполнено нулями, — из соображений безопасности). При последующих страничных ошибках неотображенную страницу может понадобиться найти в памяти или ее придется прочитать из файла подкачки.
Подкачка по требованию в диспетчере памяти управляется страничными ошибками. При каждой ошибке происходит прерывание в ядро. Затем ядро строит машинно независимый дескриптор (который сообщает о происшедшем) и передает его в диспетчер памяти исполнительного уровня. Диспетчер памяти затем проверяет обращение на действительность. Если давшая сбой страница попадает в зафиксированную область, то он ищет адрес в списке VAD и находит (или создает) элемент таблицы страниц процесса. В случае совместно используемой страницы диспетчер памяти использует элемент таблицы страниц прототипов (связанный с объектом сегмента) для заполнения нового элемента таблицы страниц процесса.
Формат элемента таблицы страниц различается в зависимости от архитектуры процессора. Для процессоров х86 и х64 элементы отображаемой страницы показаны на рис. 11.17. Если элемент помечен как действительный, то его содержимое интерпретируется аппаратным обеспечением (чтобы виртуальный адрес можно было преобразовать в правильную физическую страницу). Неотображенные страницы также имеют свои элементы, но они помечены как недействительные (invalid), и аппаратное обеспечение игнорирует остальную часть элемента. Программный формат несколько отличается от аппаратного и определяется диспетчером памяти. Например, для неотображенной страницы (которая должна быть размещена и обнулена до использования) этот факт отмечен в элементе таблицы страниц.
Два важных бита элемента таблицы страниц обновляются непосредственно аппаратным обеспечением. Это бит доступа (А) и бит «измененная» (D). Эти биты отслеживают использование данного отображения страницы для доступа к странице и возможность модифицирования страницы при этом доступе. Это реально повышает производительность системы, поскольку диспетчер памяти может использовать бит доступа для реализации подкачки по схеме наиболее давнего использования (Least- Recently Used (LRU)). Принцип LRU состоит в том, что те страницы, которые дольше всех не используются, имеют самую низкую вероятность повторного использования в ближайшее время. Бит доступа позволяет диспетчеру памяти определить, что к странице был произведен доступ. Бит «измененная» говорит диспетчеру памяти о том, что страница, возможно, была модифицирована (или, что более важно, она не была модифицирована). Если страница не была модифицирована с момента считывания с диска, то диспетчеру памяти не нужно записывать ее содержимое на диск (перед тем, как использовать ее для чего-то другого).
В обеих архитектурах, х86 и x64, используется элемент таблицы страниц размером 64 бита (см. рис. 11.17).
Каждая страничная ошибка может быть отнесена к одной из пяти категорий:
1. Страница не зафиксирована.
2. Попытка обращения к странице с нарушением разрешений.
3. Попытка модификации страницы типа «копирование при записи».
1. Необходимо увеличение стека.
2. Страница зафиксирована, но в данное время не отображена.
Первый и второй случаи — это ошибки программирования. Если программа пытается использовать адрес, который не имеет действительного отображения, или пытается выполнить недопустимую операцию (наподобие попытки записи в страницу «только для чтения»), это называется нарушением доступа (access violation) и обычно приводит к завершению процесса. Нарушение доступа часто является результатом недопустимых значений указателей, в том числе результатом обращения к памяти, которая была освобождена и откреплена от процесса.
Третий случай имеет такие же симптомы, что и второй (попытка записи в страницу «только для чтения»), но его обработка иная. Поскольку страница была помечена как «копирование при записи», то диспетчер памяти не выдает нарушение доступа. Вместо этого он создает закрытую копию страницы для текущего процесса, а затем возвращает управление тому потоку, который пытался выполнить запись в страницу. Поток повторяет операцию записи, которая теперь завершится без страничной ошибки.
Четвертый случай происходит тогда, когда поток помещает значение в свой стек и попадает на страницу, которая еще не была выделена. Диспетчер памяти распознает это как особый случай. Пока есть место в зарезервированных под стек виртуальных страницах, диспетчер памяти будет поставлять новые страницы, обнулять их и отображать в процесс. Когда поток возобновит выполнение, он повторит попытку доступа, и на этот раз она будет успешной.
И наконец, пятый случай — это нормальная страничная ошибка. Однако она имеет несколько подвариантов. Если страница отображена на файл, то диспетчер памяти должен просмотреть ее структуры данных (такие, как таблица страниц прототипов, связанная с объектом сегмента), чтобы быть уверенным в том, что в памяти нет ее копии. Если копия есть (например, в другом процессе, в резервном списке либо в списке модифицированных страниц), то он просто сделает ее совместно используемой (возможно, что для этого ему придется пометить ее как страницу «копирование при записи», если изменения совместно использовать не предполагается). Если копии еще нет, то диспетчер памяти выделит свободную физическую страницу и подготовит ее для копирования в нее страницы файла с диска, если только в этот момент не осуществляется перенос с диска другой страницы (тогда нужно лишь подождать, пока этот перенос не завершится).
Если диспетчер памяти может обработать страничную ошибку, находя нужную страницу в памяти (а не считывая ее с диска), то такая ошибка называется мягкой ошибкой (soft fault). Если нужна копия с диска, то это жесткая ошибка (hard fault). Мягкие ошибки гораздо дешевле, они мало влияют на производительность приложения (по сравнению с жесткими ошибками). Мягкие ошибки могут происходить потому, что совместно используемая страница уже была отображена на другой процесс, либо нужна просто новая обнуленная страница, либо нужная страница была удалена из рабочего набора процесса, но запрашивается повторно до того, как ее повторно использовали. Мягкие ошибки могут возникать также из-за того, что страницы были сжаты для эффективного увеличения размера физической памяти. Для большинства конфигураций центрального процессора память и ввод-вывод в текущих системах эффективнее сжимать, вместо того чтобы тратиться на дорогостоящий ввод-вывод (с точки зрения производительности и энергозатрат), требующий чтения страницы с диска.
Когда физическая страница больше не отображается таблицей страниц ни одного из процессов, она попадает в один из трех списков: свободных, модифицированных или резервных. Те страницы, которые никогда больше не понадобятся (такие, как страницы стека завершающегося процесса), освобождаются немедленно. Те страницы, которые могут снова дать страничную ошибку, попадают либо в список модифицированных, либо в список резервных (в зависимости от того, был ли бит «измененная» установлен для какого-либо элемента таблицы страниц, который отображал эту страницу с момента ее последнего считывания с диска). Страницы из модифицированного списка будут в конечном итоге записаны на диск, а затем перемещены в список резервных.
Диспетчер памяти может выделять страницы по мере необходимости (используя список либо свободных, либо резервных страниц). Перед размещением страницы и копированием с диска диспетчер памяти всегда проверяет списки резервных и модифицированных страниц, чтобы проверить, нет ли уже этой страницы в памяти. Схема опережающей подкачки в Windows преобразует будущие жесткие ошибки в мягкие (путем чтения страниц, которые могут понадобиться, и помещения их в список резервных страниц). Диспетчер памяти и сам выполняет небольшой объем опережающей подкачки — он обращается к группам последовательных страниц (а не к отдельным страницам). Дополнительные страницы немедленно размещаются в списке резервных страниц. Это не является расточительством, поскольку издержки диспетчера памяти гораздо меньше, чем стоимость выполнения операций ввода-вывода. Чтение целого кластера страниц чуть дороже, чем чтение одной страницы.
Элементы таблицы страниц на рис. 11.17 относятся к номерам физических (а не виртуальных) страниц. Для обновления элемента таблицы страниц (и каталога страниц) ядру нужно использовать виртуальные адреса. Windows отображает таблицы страниц и каталоги страниц для текущего процесса на виртуальное адресное пространство ядра при помощи элемента self-map в каталоге страниц (рис. 11.18). Отображая элемент каталога страниц на каталог страниц (карта self-map), мы получаем виртуальные адреса, которые можно использовать для ссылки на элементы каталога страниц (рис. 11.18, а) и на элементы таблицы страниц (рис. 11.18, б). Карта self-map занимает 8 Мбайт виртуальных адресов ядра для каждого процесса (на процессорах х86). Для простоты на рисунке показан элемент x86 self-map для 32-разрядных PTE-записей (Page-Table Entries). На самом деле Windows использует 64-разрядные PTE-записи, поэтому система может воспользоваться более чем 4 Гбайт физической памяти. С 32-разрядными PTE-записями элемент self-map использует в каталоге страниц только одну PDE- запись (Page-Directory Entry) и поэтому занимает только 4 Мбайт адресов, а не 8 Мбайт.
Процессор Intel
80386. Учебный курс.
Часть 1.6. Прерывания и исключения. |
Прерывания и исключения (исключительные
ситуации) изменяют нормальное выполнение задачи,
чтобы обработать внешние условия, сообщить об
ошибках или исключительных обстоятельствах.
Различия между прерываниями и исключениями
состоят в том, что прерывания обрабатывают
асинхронные внешние условия, в то время как
исключения обрабатывают ошибки команд. Хотя
прерывание n программа может выполнить
посредством команды INT n, процессор рассматривает
прерывание за счет программного обеспечения как
исключение.
Прерывания, произведенные машинным
оборудованием, происходят в результате внешних
событий и бывают двух видов: маскируемые и
немаскируемые, и выполняются после выполнения
текущей команды. После того, как программа
обработки прерываний заканчивает обслуживание
прерывания, выполнение продолжается с команды,
которая следует сразу за командой прерывания.
Исключения классифицируются как ошибки, ловушки
или (преждевременные) прекращения в зависимости
от способа их сообщения и от того, поддерживается
ли перезапуск команды, вызывающей исключение.
ОШИБКИ — это исключения, которые обнаруживаются и
выполняются до выполнения команды с ошибкой.
ОШИБКА будет происходить в системе виртуальной
памяти, когда процессор ссылается на страницу
или сегмент, которые отсутствуют. Операционная
система выберет страницу или сегмент с диска,
после чего 80386 перезапустит команду. ЛОВУШКИ —
исключения, о которых сообщается немедленно
после выполнения той программы, которая вызывает
исключение. ПРЕКРАЩЕНИЯ — исключения, которые не
позволяют определить точно местоположение
команды, вызывающий исключение. ПРЕКРАЩЕНИЯ
используются для сообщения о грубых ошибках,
таких как аппаратная ошибка, неправильные
значения в системных таблицах.
Таким образом, когда программа обслуживания
прерывания заканчивается, выполнение
продолжается с команды, следующей сразу за
командой вызвавшей прервание. С другой стороны,
адрес возврата из программы ОШИБКИ исключения
всегда укажет на команду, которая вызывает
исключение, и будет содержать любой из префиксов
ведущей программы. В таблицу сведены все
возможные прерывания для 80386 и показано, куда
указывает адрес возврата.
80386 способен обрабатывать до 256 различных
прерываний/исключений. Для обслуживания
прерываний необходимо определить (составить)
таблицу с 256 векторами прерываний. Векторы
прерываний — это указатели на соответствующие
программы обслуживания; в РЕАЛЬНОМ РЕЖИМЕ
векторы представляют собой 4-х байтные величины:
сегмент кода плюс 16 бит смещения; в ЗАЩИЩЕННОМ
РЕЖИМЕ векторы прерываний являются 8-ми
байтовыми величинами, которые помещены в ТАБЛИЦУ
ДЕСКРИПТОРОВ ПРЕРЫВАНИЙ.
Из 256 возможных прерываний, 32 зарезервированы для
использования INTEL, оставшиеся 224 свободны для
использования пользователем.
Функция | Номер прерывания | Команда, которая может вызвать исключение |
Адрес возврата указывает на ошибочную команду |
Тип |
---|---|---|---|---|
Ошибка деления | 0 | DIV, IDIV | Да | Ошибка |
Исключение отладки | 1 | Любая команда | Да | Ловушка |
NMI прерывание | 2 | INT2 или NMI | Нет | NMI |
Однобайтное прерывание |
3 | INT | Нет | Ловушка |
Переполнение | 4 | INT0 | Нет | Ловушка |
Контроль границ массива |
5 | Граница | Да | Ловушка |
Неверный операционный код |
6 | Любая запрещенная команда | Да | Ловушка |
Отсутствие устройства |
7 | ESC, WAIT | Да | Ловушка |
Двойная ошибка | 8 | Любая команда, способная вызвать исключение |
Да | Прекращение |
Перегрузка сегмента сопроцессора |
9 | |||
Неверный TSS | 10 | JMP, CALL, IRET, INT | Да | Ошибка |
Отсутствие сегмента | 11 | Команды с сегментными регистрами |
Да | Ошибка |
Ошибка стека | 12 | Ссылки на стек | Да | Ошибка |
Общая ошибка защиты | 13 | Любое обращение к памяти | Да | Ошибка |
Отсутствие страницы | 14 | Любой доступ к памяти при выборе кода |
Да | Ошибка |
Ошибка сопроцессора | 16 | ESC, WAIT | Да | Ошибка |
Зарезервированно | 17-32 | |||
Двухбайтовое прерывание |
0-255 | INT n | Да | Ловушка |
ОБРАБОТКА ПРЕРЫВАНИЙ.
Когда происходит прерывание, происходят
следующие действия. Во-первых, адрес текущей
команды и регистр флагов EFLAGS сохраняются в стеке,
что позволяет возобновить прерванную программу.
Затем, 80386 снабжается 8-ми битовым вектором,
который определяет соответствующий элемент в
таблице прерываний. В таблице содержится
начальный адрес программы обработки прерываний.
После этого выполняется вызываемая программа
обработки. И наконец, после команды IRET,
восстанавливается старое состояние процессора и
по адресу возврата (т.е. по адресу сохраненному в
стеке) возобновляется выполнение программы.
8-ми битовый вектор прерывания подается на 80386
несколькими различными способами: исключения
«поставляют» вектор прерывания внутренне;
команды INT содержат или включают в себя вектор;
прерывания маскируемые аппаратурой
«поставляют» 8-ми битовый вектор через
последовательность шины подтверждения
прерываний. Прерывания немаскируемые
аппаратурой присвоены к вектору прерывания 2.
МАСКИРУЕМЫЕ ПРЕРЫВАНИЯ.
Маскируемые прерывания — наиболее общий способ
используемый 80386 для ответа на асинхронные
внешние события аппаратуры. Аппаратное
прерывание происходит, когда бит IF флага
прерываний разблокирован (установлен в 1) и INTR
выталкивается высоко. Процессор реагирует на
маскируемые прерывания только между выполнением
команд. Строковые команды имеют «окна
прерываний» между перемещениями памяти, что
делает возможным прерывание во время обработки
длинной строки. Когда происходит прерывание,
процессор считывает 8-ми битовый вектор,
присылаемый аппаратурой, который определяет
источник прерывания (один из 224 определяемых
пользователем прерываний).
Бит IF в регистре EFLAGS сбрасывается, когда
обслуживается прерывание. Это позволяет
эффективно предотвратить дополнительные
прерывания во время обработки прерываний.
Однако, IF может быть установлен обработчиком
прерываний, чтобы позволить вложение прерываний.
Когда команда IRET выполнена, восстанавливается
начальное состояние флагов, а значит, и бита IF.
НЕМАСКИРУЕМЫЕ ПРЕРЫВАНИЯ.
Немаскируемые прерывания обеспечивают
обслуживание прерываний очень высокого уровня.
Одним из общих примеров немаскируемых (NMI)
прерываний может служить прерывание по сбою
питания. Когда активизируется контакт NMI,
происходит прерывание по вектору 2. В отличие от
обычных прерываний, для NMI не выполняется
последовательность подтверждения приема
прерывания.
Во время процедуры обслуживания NMI, 80386 не будет
обслуживать ни дальнейший запрос NMI, ни запросы INT
до тех пор, пока не будет выполнена команда
возврата из прерывания (IRET) или пока процессор не
будет сброшен. Если NMI произойдет во время
обслуживания NMI, его (прерывания) присутствие
будет сохранено для обработки после обработки
текущего NMI, т.е. после первой же команды IRET. Бит IF
очищается в начале NMI дла блокировки дальнейших
INTR команд.
ПРОГРАММНЫЕ ПРЕРЫВАНИЯ.
Третьим типом прерывыаний/исключений для 80386
являются программные прерывания. Команда INT n
заставляет процессор выполнять программу
обслуживания, на которую указывает вектор n в
таблице прерываний.
Особым случаем двухбайтового программного
прерывания INT с номером n является однобайтовое
прерывание INT 3, или прерывание останова. Путем
ввода данной однобайтовой команды в программу,
пользователь имеет возможность устанавливать
точки останова в свою программу, как инструмент
отладки.
Последним типом программного прерывания
является прерывание пошагового режима. Оно
обсуждается в разделе «ОТЛАДКА».
ПРИОРИТЕТНОСТЬ ПРЕРЫВАНИЙ.
Поскольку прерывания распознаются только на
границах команд, возможно, что больше чем одно
прерывание может быть активным в одно и тоже
время. В случае одновременных прерываний, они
будут обрабатываться согласно приоритету,
представленному в таблице:
Приоритет обработки | Прерывание / исключение |
---|---|
1 (высший) | Ошибка исключения |
2 | Команда TRAP |
3 | Ловушка отладки для данной команды |
4 | Ошибка отладки для следующей команды |
5 | NMI прерывание |
6 | INTR прерывание |
ПРИМЕР: заданная команда вызывает
системное прерывание отладки и исключение
«сегмент отсутствует». 80386 первоначально
отреагирует на исключение «сегмент
отсутствует» (11), предпринимая попытку
активизировать обработчик исключения 11.
Программа обработки исключения 11 будет прервана,
в результате чего адрес обработчика исключения 11
будет сохранен в стеке. После этого будет вызван
обработчик отлатдки и управление снова
возвратится оброботчику исключения 11. Это
позволяет системотехнику отлаживать свои
обработчики исключений.
ПОВТОРНЫЙ ЗАПУСК.
80386 полностью поддерживает возобновление всех
команд после ошибок. Операционная система не
участвует в процессе перезапуска, поскольку
процессор сообщит об ошибке сегмента или
страницы при таком состоянии машины, которое
позволяет перезапуск ошибочной команды после
того, как обработчик ошибки исправил ошибочное
условие (например, когда вырабатывается ошибка
страницы, обработчик дает правильную страницу).
Повторный запуск команды гарантируется за
исключением двух условий:
- Если команды вызывают включение задачи в
СЕГМЕНТ СОСТОЯНИЯ ТЕКУЩЕЙ ЗАДАЧИ, который
расположен в отсутствующей странице. - Если один из операндов расположен ниже любого
из текущих указателей стека, т.е. по адресу памяти
меньшем, чем вершина стека. Или операнд в форме
сплавающей точкой совершает циклический переход
в памяти.
ДВОЙНЫЕ ОШИБКИ.
Двойная ошибка происходит, когда процессор
пытается обработать исключение и получает
другое исключение во время программы обработки.
Двойная ошибка вызывает исключение 8.
Большинство исключений в 80386 не считают в
направлении условия двойной ошибки, т.е. при их
обработке не возникают двойные ошибки. Это
следующие исключения (типы 1, 2, 3, 4, 5, 6, 7, 9, 14 и 16).
Только ошибки из-за деления (прерывание 0) и
сегментные исключения (10, 11, 12, 13) считают в
направлении двойной ошибки. Таким образом,
получение исключения «сегмент отсутствует»
во время обработки исключения отладки не
приведет к двойной ошибке, в то время, как ошибка
сегмента, происходящая во время обработки ошибки
из-за деления на нуль, приведет к двойной ошибке.
Прерывание из-за отсутствия страницы (в
оперативной памяти) не считает в направлении
двойных ошибок. Например, если команда вызывает и
исключение «сегмент отсутствует» (11), и
прерывание из-за отсутствия страницы (прерывание
14), оба прерывания будут правильно обработаны.
Обработчик исключения «сегмент
отсутствует» будет активизирован, в
результате чего с диска будет загружен
правильный сегмент. Затем команда будет повторно
запущена, и вызовет прерывание из-за отсутствия
страницы. Тогда обработчик прерывания из-за
отсутствия страницы подаст правильную страницу
и выполнение программы будет продолжено. Это
поддерживает концепцию нахождения страничной
организации «под» сегментацией.
Последней причиной двойных ошибок являются
рекурсивные ошибки (например отсутствует
обработчик прерывания из-за отсутствия
страницы). Это приводит к исключению 8.
Вернуться к началу страницы. |