Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекція № 4_МЗКІТ (10 ТП).docx
Скачиваний:
0
Добавлен:
01.07.2025
Размер:
2.44 Mб
Скачать

6.3. Керування адресним простором під час створення процесів

Оскільки основним елементом процесу є захищений адресний простір, дуже важливо вирішити проблему його розподілу під час створення нового процесу. Розглянемо два різні підходи.

Системні виклики fork() і ехес()

У першому підході адресний простір нащадка створюють як точну копію адресного простору предка. Така операція реалізована системним викликом, який у POSIX- системах називають fork ( ).

У цьому разі копіюється не тільки адресний простір, а й лічильник команд головного потоку процесу, тому після виклику fork( ) предок і нащадок виконуватимуть ту саму інструкцію. Розробник має визначити, у якому з двох процесів перебуває керування. Це можна зробити на підставі відмінностей між кодами повернення fork ( ) для предка і нащадка.

Коли створення нового процесу відбувається шляхом дублювання адресного простору предка, виникає потреба у спеціальних засобах для завантаження програмного коду в адресний простір процесу. Такі засоби реалізує системний виклик, який у POSIX-системах називають ехес( ). Як параметр для виклику ехес( ) треба вказувати весь шлях до виконуваного файла програми, який буде завантажено у пам’ять.

У системах із підтримкою fork ( ) для того щоб запускати на виконання програми, після виклику fork ( ) потрібно негайно викликати ефес ( ) (це називають технологією fork+exec).

Запуск застосування одним системним викликом

Другий підхід не розділяє дублювання адресного простору і завантаження коду — ці етапи тут поєднані в один. У даному разі системний виклик запускає на виконання задане застосування (зазвичай для цього йому потрібно вказати весь шлях до виконуваного файлу цього застосування).

Можна виділити два етапи виконання такого системного виклику:

♦ виділення пам’яті під адресний простір нового процесу (жодна інформація при цьому з адресного простору предка не копіюється);

♦ завантаження виконуваного коду із зазначеного файлу у виділений адресний простір.

Підхід із використанням fork( ) і ехес( ) є гнучкішим, бо він дає змогу в разі необхідності обмежитись якимось одним етапом запуску застосування. Сучасні ОС переважно реалізують деяку комбінацію першого та другого підходів.

Технологія копіювання під час запису

Якщо під час створення процесу за допомогою виклику fork ( ) щоразу завчасно виділяти пам’ять і копіювати в неї дані адресного простору предка (стек, область глобальних змінних, програмний код), то це буде доволі трудомістким завданням, особливо для процесів, що займають багато місця в пам’яті.

Для розв’язання цієї проблеми в сучасних ОС використовують технологію копіювання під час запису (copy-on-write). При цьому під час виклику fork ( ) дані з пам’яті предка у пам’ять нащадка не копіюють, натомість відповідні ділянки пам’яті відображають в адресний простір — як нащадка, так і предка, але при цьому позначають їх як захищені від запису.

Рис.4 Копіювання під час запису: пам’ять відразу після створення процесу

Як тільки нащадок або предок спробує змінити якусь із названих вище ділянок пам'яті, тобто щось записати у неї, виникає апаратне переривання. Система реагує на нього, виділяє пам’ять під нову область, відкриту для запису відповідному процесу, і змінює адресний простір для обох процесів (наприклад, для другого процесу відповідна ділянка пам’яті відкривається для запису). Слід зазначити, що в разі використання цієї технології ділянки пам’яті, які не змінюються (наприклад, ті, що містять код програми), можуть взагалі ніколи не копіюватися.

Рис. 5. Копіювання під час запису: пам’ять після спроби запису в неї

У багатьох сучасних системах копіювання під час запису є основного технологією керування адресним простором у разі створення процесів.