Архитектура операционной системы UNIX   ::   Бах Морис Дж.

Страница: 197 из 715

»)  continue; /* цикл с условием продолжения */

поиск компоненты:

  считать каталог (рабочий индекс), повторяя алгоритмы bmap,bread и brelse;

  if (компонента соответствует записи в каталоге (рабочем индексе))  {

   получить номер индекса для совпавшей компоненты;

   if (найденный индекс является индексом корня и рабочий индекс является индексом корня и имя компоненты «..»)  {

    /* пересечение точки монтирования */

    получить запись в таблице монтирования для рабочего индекса;

    освободить рабочий индекс (алгоритм iput);

    рабочий индекс = индексу точки монтирования;

    заблокировать индекс точки монтирования;

    увеличить значение счетчика ссылок на рабочий индекс;

    перейти к поиску компоненты (для «..»);

   }

   освободить рабочий индекс (алгоритм iput);

   рабочий индекс = индексу с новым номером (алгоритм iget);

  }

  else /* компонента отсутствует в каталоге */  return (нет индекса);

 }

 return (рабочий индекс);

}

Рисунок 5.26. Модификация алгоритма синтаксического анализа имени файла

В вышеприведенном примере (cd «../../..») предполагается, что в начале процесс имеет текущий каталог с именем «/usr/src/uts». Когда имя пути поиска подвергается анализу в алгоритме namei, начальным рабочим индексом является индекс текущего каталога. Ядро меняет текущий рабочий индекс на индекс каталога с именем «/usr/src» в результате расшифровки первой компоненты «..» в имени пути поиска. Затем ядро анализирует вторую компоненту «..

|< Пред. 195 196 197 198 199 След. >|

Java книги

Контакты: [email protected]