|
0 / 0 / 0
Регистрация: 06.11.2011
Сообщений: 6
|
|
Подгрузка страниц в Linux19.11.2011, 18:42. Показов 1277. Ответов 6
Метки нет (Все метки)
Здравствуйте,
необходимо написать программу на си, которая бы измеряла время, которое потребуется на подгрузку страницы из внешней памяти. В качестве внешней памяти выступает жесткий диск. Операционная система – Linux. Не могу найти никакой информации насчет функций, отвечающих за подгрузку страниц. Подскажите, кто знает. Спасибо большое.
0
|
|
| 19.11.2011, 18:42 | |
|
Ответы с готовыми решениями:
6
Автоматическая подгрузка страниц Подгрузка-Выгрузка страниц Подгрузка контента из других страниц |
|
|
||
| 22.11.2011, 17:07 | ||
|
Формулировка задачи слишком расплывчатая. Ну суть сводится к следующему. Нужно выделить памяти больше, чем объём физической памяти. После чего какой-то фрагмент памяти будет откачан на диск. Наверняка этого скорее всего знать нельзя, только догадаться экспериментальны путём. Хотя может в потаённых местах типа /proc и есть информация о том, какие страницы из памяти свалены на диск. Итого, исходная позиция - есть память, доступная программе, а какие-то страницы откачены на диск. Вычисляем текущий тик, делаем обращение к памяти, вычисляем текущий тик. Разница между двумя тиками и есть интервал времени, который операционка затратила на то, чтобы переместить страницу с диска в память До кучи можешь почитать про функцию mmap. Эта функция работает через системный вызов mmap, который собственно и занимается плясками с бубном. Т.е. читать нужно не стандартную пользовательскую документацию, а документацию для разработчиков, где описано, как это безобразие работает изнутри
0
|
||
|
Заблокирован
|
|
| 27.11.2011, 15:48 | |
|
Studentus, стандартным хендлером обрабатывающим #PF в линуксе является do_page_fault(http://lxr.linux.no/linux+*/ar... ult.c#L988). Логика её работы довольно сложная, но есть описания на инглише как она приблизительно работает. Все #PF делятся на "плохие" и "хорошие", если исключение "хорошее", то управление передаётся сюда http://lxr.linux.no/linux+*/ar... lt.c#L1151, наиболее интересную работу выполняет там fault = handle_mm_fault(mm, vma, address, flags); всё остальное не особо интересно. Значит переходим сюда http://lxr.linux.no/linux+*/mm/memory.c#L3442 и смотрим дальше. Впринципе кроме последней строки ничего интересного(и понятного!) для тебе нет http://lxr.linux.no/linux+*/mm/memory.c#L3503, значит смотрим теперь http://lxr.linux.no/linux+*/mm/memory.c#L3386.... Вобщем в handle_pte_fault тебя интересует только вызов do_swap_page, я так полагаю именно её время и нужно померять. Правда ты не сказал какое время среднее или общее, но в любом случае результаты сохрани в глобальной переменной, а получать их будешь например с помощью системного вызова который ты добавишь
На всякий случай нужно уточнить у того кто дал тебе такое задание это ли он имел ввиду, потому что формулировка мутная, складывается впечатление что от тебя ожидают что ты как то из пользовательского пространства получишь эту инфу. Но ни одна ос думаю такого глубокого интерфейса не представляет, ну мб микроядерные, можно посмотреть как в МИНИКС 3 реализованно всё это дело, в той версии которую я видел в последний раз виртуальная память не поддерживалась, но вроде её добавили в 3.1.6. В линукс, как было замеченно выше, твоё задание нереализуемо из юзерспейса
0
|
|
|
0 / 0 / 0
Регистрация: 06.11.2011
Сообщений: 6
|
|
| 03.12.2011, 16:02 [ТС] | |
|
Вот точная формулировка задания:
Рассчитать среднее время, которое потребуется на подгрузку страницы из внешней памяти. Результат представить в виде таблицы с разным размером страницы, например: 2 Кб, 4 Кб, 8 Кб. В качестве внешней памяти выступает жесткий диск. По идее это должно быть несложным заданием, так как в других вариантах есть задания типа Напишите программу, которая будет подсчитывать среднее время доступа к информации на жестком диске по чтению.
0
|
|
|
0 / 0 / 0
Регистрация: 06.11.2011
Сообщений: 6
|
|
| 03.12.2011, 19:13 [ТС] | |
|
а может тут и программу писать не надо? можно ли это как то подсчитать вручную?
0
|
|
|
|
|
| 03.12.2011, 22:35 | |
|
Может и можно. Только, насколько я понимаю, никто до сих пор не въехал, что же именно считать надо
0
|
|
| 03.12.2011, 22:35 | |
|
Помогаю со студенческими работами здесь
7
Подгрузка контента из других страниц Подгрузка страниц через JS и AJAX AJAX динамическая подгрузка страниц (7стр), сильно скажется на поисковой оптимизации? Разбиение на страницы с переходом по номерам страниц, с отображением полного количества страниц
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|