Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Шпори СПОС.docx
Скачиваний:
1
Добавлен:
01.04.2025
Размер:
145.46 Кб
Скачать
  1. Порядок запуску програм засобами базового інтерфейсу управління процесами.

Запуск нових програм в UNIX відокремлений від створення процесів і реалізований

за допомогою системних викликів сімейства ехес(). На практиці звичайно

реалізують один виклик (у Linux це — execveO). Послідовность кроків виконання execveO у Linux. Вхідними параметрами цього виклику є рядок з ім'ям виконуваного файла програми, масив аргументів командного рядка (до яких у коді процесу можна буде дістати доступ за допомогою масиву argv) і масив змінних оточення (що є парами ім'я=значення). Виклик execveO відбувається так.

1. Відкривають виконуваний файл програми.

2. Використовуючи вміст цього файла, ініціалізують спеціальну структуру даних

bprm, що містить інформацію, необхідну для виконання файла, зокрема відомості

про його двійковий формат.

3. Виконують дії для забезпечення безпеки виконання коду.

4. На базі параметрів виклику формують командний рядок і набір змінних оточення

програми (це спеціальні поля структури bprm).

5. Для кожного зареєстрованого оброблювача бінарного формату викликають

процедуру завантаження виконуваного файла через покажчик 1 oad_bi nary і перевіряють

результат цього виклику:

а) у разі коректного завантаження оброблювач починає виконувати код нової

програми;

б) якщо жоден з оброблювачів не зміг коректно завантажити код, повертають

помилку.

  1. Основні можливості та функції базового інтерфейсу управління процесами.

Основу інтерфейсу управління процесами Unix складають наступні функції (перелік містить тільки ті функції, що визначені стандартом Single Unix Specification 3): _exit(), abort(), execl(), execle(), execlp(), execv(), execve(), execvp(), exit(), fork(), getegid(), geteuid(), getgid(), getpgid(), getpid(), getppid(), getrlimit(2), getrusage(2), getsid(), getuid(), setegid(), seteuid(), setgid(), setpgid(), setrlimit(2), setsid(), setuid(), wait(), waitid(), waitpid().

  1. Ідентифікатор процесу. Основні атрибути процесу. Оперування атрибутами процесу.

Із кожним процесом у системі пов’язана ідентифікаційна інформація. PID - ідентифікатор процесу багатозадачного операційної системи. В операційних системах сімейства Windows є цілочисловим типом. В операційних системах стандарту POSIX тип ідентифікатора визначається в кожній операційній системі індивідуально. Наприклад, в операційній системі Linux ідентифікатор процесу є цілим типом.

До основних атрибутів процесу належить:

PID – ідентифікатор процесу

PPID – Ідентифікатор батьківського процесу

NI – Поправка пріорітету

TTY - Термінальна лінія

UID & EUID - Реальний і ефективний ідентифікатори користувача

GID & EGID - Реальний і ефективний ідентифікатори групи

  1. Організація взаємодії між батьківським та дочірніми процесами.

Неіменовані канал є засобом взаємодії між пов'язаними процесами - батьківським і дочірнім. Батьківський процес створює канал за допомогою системного виклику:

int pipe(int fd[2]);

Масив з двох цілих чисел є вихідним параметром цього системного виклику. Якщо виклик виконався нормально, то цей масив містить два файлових дескриптора. fd[0] є дескриптором для читання з каналу, fd[1] - дескриптором для запису у канал. Коли процес породжує інший процес, дескриптори батьківського процесу успадковуються дочірнім процесом, і, таким чином, прокладається трубопровід між двома процесами. Природно, що один з процесів використовує канал лише для читання, а інший - тільки для запису (самі уявіть собі, що станеться, якщо це правило буде порушуватися). Тому, якщо, наприклад, через канал повинні передаватися дані з батьківського процесу в дочірній, батьківський процес відразу після запуску дочірнього процесу закриває дескриптор каналу для читання, а дочірній процес закриває дескриптор для запису. Якщо потрібен двосторонній обмін даними між процесами, то батьківський процес створює два канали, один з яких використовується для передачі даних до одну сторону, а інший - в іншу. Після отримання процесами дескрипторів каналу для роботи з каналом використовуються файлові системні виклики:

int read(int pipe_fd, void *area, int cnt);

int write(int pipe_fd, void *area, int cnt);

Перший аргумент цих викликів - дескриптор каналу, другий - вказівник на область пам'яті, з якої відбувається обмін, третій - кількість байт. Обидва виклику повертають кількість переданих байт (або -1 - при помилку).

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

При завершенні використання каналу процес виконує системний виклик:

int close(int pipe_fd);

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