Linux Kernel (Ядро линукса) (часть 3)


Функция ll_rw_block

Иногда ядро должно запустить пересылку сразу нескольких блоков данных, которые необязательно являются физически смежными. Функция ii_rw_biock принимает в качестве параметров направление движения данных (read или write), количество блоков, подлежащих пересылке, и массив указателей на головы соответствующих буферов блоков. Функция перебирает все головы буферов и для каждой выполняет следующие действия:
1. Проверяет и устанавливает флаг вн ьоск головы буфера. Если буфер уже был заблокирован, значит, пересылка данных была активизирована другим управляющим трактом ядра. В этом случае функция пропускает буфер, переходя к шагу 9.
2. Увеличивает на единицу счетчик обращений b count головы буфера.
3. Если направлением движения данных является write, функция настраивает метод b end io головы буфера так, чтобы он указывал на адрес функции end buffer write sync . В противном случае она настраивает этот метод так, чтобы ОН указывал на адрес функции end_buffer_read_sync .
4. Если направлением движения данных является write, функция проверяет и сбрасывает флаг BH Dirty головы буфера. Если флаг не был установлен, нет необходимости записывать блок на диск, и функция переходит к шагу 7.
5. Если направлением движения данных является read или reada (опережающее чтение), функция проверяет, установлен ли флаг BH Uptodate головы буфера. Если установлен, нет необходимости читать блок с диска, и функция переходит к шагу 7.
6. На этом шаге блок должен быть прочитан или записан. Функция вызывает submit bh , чтобы передать голову буфера общему слою работы с блочными устройствами, и переходит к шагу 9.
7. Снимает блокировку с головы буфера, сбросив флаг вн ьоск, и возобновляет работу каждого процесса, ждущего разблокирования блока.
8. Уменьшает значение поля b count головы буфера.
9. Если в массиве есть еще головы буферов, функция выбирает следующую и возвращается к шагу 1; в противном случае она завершает работу.
Обратите внимание, что если функция ii_rw_biock передает голову буфера общему слою работы с блочными устройствами, она оставляет буфер заблокированным, а его счетчик ссылок увеличенным, чтобы буфер оставался недоступным и не мог быть освобожден, пока не завершится пересылка данных. Ядро выполняет завершающий метод b end io головы буфера, когда окончится пересылка блока. Если не было ошибки ввода/вывода, функции end_buffer_write_sync И end_buf fer_read_sync ПрОСТО устанавливают флаг в поле BH Uptodate головы буфера, снимают с буфера блокировку и уменьшают его счетчик обращений.

Заметка:
Не редко люди теряются в выборе хороших и стоящих подарков. Так за наиболее оригинальными бизнес сувенирами вполне можно обратиться в специализированный магазин, где представлен широкий ассортимент такого рода товара.


Предыдущая страница | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 | Следующая страница




Возможно, Вас также заинтересует:

ОС Knoppix - это Linux без про...

ВведениеЕсли вы цените свое время, умеете считать деньги и знаете стоимость информации, то эта книга...

Linux Kernel (Ядро линукса) (ч...

Спин-блокировкаСпин-блокировка необходима в многопроцессорной системе, потому что могут возникнуть...

Linux Kernel (Ядро линукса) (ч...

Копирование при записи В системах Unix первых поколений создание процесса было реализовано довольно...

Linux Kernel (Ядро линукса) (ч...

Буферы блоков и головы буферовУ каждого буфера есть дескриптор голова буфера, имеющий тип buffer...