- •Основні концепції операційних систем. Поняття операційної системи, її призначення та функції.
- •Керування процесами і потоками. Базові поняття процесів і потоків. Процеси і потоки в сучасних ос. Моделі процесів і потоків. Складові елементи процесів і потоків.
- •3.Системний реєстр Windows xp. Логічна структура реєстру. Фізична організація реєстру. Програмний інтерфейс доступу до реєстру.
- •Основні концепції операційних систем. Операційна система як розширена машина. Операційна система як розподілювач ресурсів.
- •Логічна організація файлових систем. Загальні відомості про файлові операції. Файлові операції posix.
- •Основні концепції операційних систем. Історія розвитку операційних систем. Класифікація сучасних операційних систем.
- •Керування процесами і потоками. Створення процесів. Ієрархія процесів. Керування адресним простором під час створення процесів. Створення процесів
- •Логічна організація файлових систем. Загальні відомості про файлові операції. Файлові операції WinApi.
- •Основні концепції операційних систем. Функціональні компоненти операційних систем.
- •Керування процесами і потоками. Синхронне й асинхронне виконання процесів.
- •Логічна організація файлових систем. Організація інформації у файловій системі. Розділи. Каталоги. Зв'язок розділів і структури каталогів.
- •Архітектура операційних систем. Механізми і політика.
- •Керування процесами і потоками. Створення і завершення потоків. Особливості створення потоків
- •Міжпроцесова взаємодія на основі інтерфейсу файлової системи. Файлові блокування.
- •Архітектура операційних систем. Ядро системи. Привілейований режим і режим користувача.
- •Керування процесами і потоками. Керування процесами в unix і Linux.
- •Міжпроцесова взаємодія на основі інтерфейсу файлової системи. Файли, що відображаються у пам'ять.
- •Архітектура операційних систем. Реалізація архітектури операційних систем. Монолітні системи.
- •Керування процесами і потоками. Програмний інтерфейс керування потоками posix.
- •Міжпроцесова взаємодія на основі інтерфейсу файлової системи. Поіменовані канали
- •Архітектура операційних систем. Реалізація архітектури операційних систем. Багаторівневі системи.
- •Керування процесами і потоками. Керування процесами у Windows. Складові елементи процесу. Структури даних процесу.
- •Реалізація файлових систем. Інтерфейс віртуальної файлової системи vfs.
- •Архітектура операційних систем. Реалізація архітектури операційних систем. Системи з мікроядром.
- •Керування процесами і потоками. Керування процесами у Windows. Створення процесів. Завершення процесів.
- •Реалізація файлових систем. Файлові системи ext2fs і ext3fs.
- •Архітектура операційних систем. Реалізація архітектури операційних систем. Концепція віртуальних машин
- •Керування процесами і потоками. Програмний інтерфейс керування процесами WinАрі.
- •Реалізація файлових систем. Файлова система /ргос.
- •Архітектура операційних систем. Операційна система та її оточення. Взаємодія ос і апаратного забезпечення
- •Керування процесами і потоками. Керування потоками у Windows. Складові елементи потоку.
- •Динамічний розподіл пам'яті. Послідовний пошук підходящого блоку. Порівняння алгоритмів послідовного пошуку підходящого блоку.
- •Архітектура операційних систем. Взаємодія ос і апаратного забезпечення. Взаємодія ос і апаратного забезпечення
- •Керування процесами і потоками. Керування потоками у Windows. Створення потоків.
- •Динамічний розподіл пам'яті. Алгоритм найкращого підходящого. Алгоритм найкращого підходящого.
- •1)Архітектура операційних систем. Взаємодія ос і виконуваного програмного коду.
- •2).Керування процесами і потоками. Керування потоками у Windows.Особливості програмного інтерфейсу потоків
- •3) Динамічний розподіл пам'яті. Алгоритм першого підходящого.
- •Архітектура операційних систем. Особливості архітектури unix.
- •2.Взаємодія потоків. Основні принципи взаємодії потоків. Основні проблеми взаємодії потоків. Проблема змагання. Критичні секції та блокування. Базові механізми синхронізації потоків.
- •3.Динамічний розподіл пам'яті. Ізольовані списки вільних блоків. Проста ізольована пам'ять.
- •2.Взаємодія потоків. Семафори.
- •3.Основи технології віртуальної пам'яті
- •Взаємодія потоків. М'ютекси.
- •Основи технології віртуальної пам'яті. Фрагментація пам'яті. Логічна і фізична адресація пам'яті. Підхід базового і межового регістрів.
- •Міжпроцесова взаємодія. Види міжпроцесової взаємодії.
- •Взаємодія потоків. Умовні змінні.
- •Основи технології віртуальної пам'яті. Сегментація пам'яті. Особливості сегментації пам'яті. Реалізація сегментації в архітектурі іа-32.
- •Міжпроцесова взаємодія. Методи розподілюваної пам'яті. Методи передавання повідомлень.
- •Взаємодія потоків. Концепція монітора.
- •Основи технології віртуальної пам'яті. Сторінкова організація пам'яті. Базові принципи сторінкової організації пам'яті. Порівняльний аналіз сторінкової організації пам'яті та сегментації.
- •Міжпроцесова взаємодія. Технологія відображуваної пам'яті
- •Взаємодія потоків. Блокування читання-записування. Синхронізація за принципом бар'єра.
- •Основи технології віртуальної пам'яті. Багаторівневі таблиці сторінок. Реалізація таблиць сторінок в архітектурі іа-32
- •Взаємодія з диском підчас керування пам'яттю. Поняття підкачування. Проблеми реалізації підкачування сторінок.
- •Взаємодія з диском підчас керування пам'яттю. Заміщення сторінок. Оцінка алгоритмів заміщення сторінок.
- •Взаємодія потоків. Синхронізація процесів користувача у Linux. Ф'ютекси.
- •Керування процесами і потоками. Програмний інтерфейс керування потоками posix
- •Взаємодія з диском підчас керування пам'яттю. Алгоритм fifo. Оптимальний алгоритм.
- •Взаємодія потоків.Програмний інтерфейс взаємодії WinАрі.
- •Взаємодія з диском підчас керування пам'яттю. Годинниковий алгоритм.
- •Взаємодія потоків.Взаємодія потоків у Linux.
- •1.Взаємодія з диском підчас керування пам'яттю. Блокування сторінок у пам'яті. Фонове заміщення сторінок. Блокування сторінок у пам'яті
- •Взаємодія потоків.Взаємодія потоків у Linux.
- •Планування процесів і потоків. Види планування. Довготермінове планування. Середньотермінове планування. Короткотермінове планування. Стратегії планування.
- •Короткотермінове планування
- •Міжпроцесова взаємодія на основі інтерфейсу файлової системи. Файли, що відображаються у пам'ять.
- •Взаємодія потоків.Базові механізми синхронізації потоків.
1.Взаємодія з диском підчас керування пам'яттю. Блокування сторінок у пам'яті. Фонове заміщення сторінок. Блокування сторінок у пам'яті
Для організації блокування сторінок у пам'яті в Linux використовують системні
виклики mlock() і munlock(), прототипи яких визначені в заголовному файліsys/mman.h. Системний виклик mlock() блокує у пам'яті набір сторінок,munlock()знімає це блокування. Обидва ці виклики приймають два параметри: адресу, зякої починається блокований набір сторінок, і розмір пам'яті, яку потрібнозаблокувати або розблокувати.Приклад блокування однієї сторінки із використанням цих викликів:
#include <sys/mman.h>
#include <stdlib.h> // для malloc()
size_t pagesize = getpagesize();
// виділення пам'яті під сторінку
char* page = (char *)malloc(pagesize);
// сторінка заблокована у пам'яті й не може бути вивантажена на диск
mlock(page, pagesize);
// ...
// розблокування сторінки
munlock(page, pagesize);
Системний виклик mlockall() блокує у пам'яті всі сторінки поточного процесу.
Заблоковану пам'ять не можна використовувати під час розподілу пам'яті доти,
поки вона не буде розблокована (або поки процес не завершиться).
Використовують функції Win32 API VirtualLock() і Vi rtualUnlock(). Відповідні
сторінки мають бути до цього часу підтверджені.
SYSTEM_INFO info;
GetSystemInfo(&info);
DWORD pagesize = info.dwPageSize;
// резервування і підтвердження сторінки
char *pageaddr = (char *)VirtualAlloc(NULL,pagesize,
MEM_RESERVE | MEM_COMMIT, PAGE_READWRITE);
// блокування сторінки у пам'яті
VirtualLock(pageaddr, pagesize);
//... розблокування
VirtualUnlock(pageaddr, pagesize);
Оскільки блокування сторінок призводить до того, що відповідна фізичнапам'ятьвиявляється втраченою для інших застосувань і системи, обсяг пам'яті,
дозволеної для блокування, не може перевищувати нижньої межі робочогонабору процесу.
Фонове заміщення сторінок.
У Linux реалізоване фонове заміщення сторінок, за яке відповідає потік ядраkswapd. Необхідність його запуску визначає наявність вільних сторінок пам'яті усистемі.Організація заміщення сторінок у Linux ґрунтується на їхбуферизації.Організовують два списки сторінок: список активних (active_list) — міститьсторінки, які використовують процеси і визначає робочий набір процесів; списокнеактивних (inactive_list) — містить сторінки, які не так важливі для процесів (невикористовуються в цей момент часу). Модифікована сторінка перебуває всписку неактивних якийсь час, перш ніж її збережуть на диску.Нові сторінки додають у початок списку неактивних сторінок. За нестачі пам'ятічастину сторінок переміщують з кінця списку активних сторінок у початоксписку неактивних, а потім починають вивільнення сторінок із кінця спискунеактивних сторінок.
Взаємодія потоків.Взаємодія потоків у Linux.
Бібліотеки підтримки потоків Linux (LinuxThreads і NPTL) надають програмам
користувача набір синхронізаційних примітивів, визначених стандартом POSIX
(м'ютекси, умовні змінні, семафори, блокування читання-записування, бар'єри).
Крім того, у NPTL допускають використання цих примітивів у поєднанні з відображуваною або розподілюваною пам'яттю для реалізації міжпроцесової синхронізації. Описані примітиви реалізовані на основі базових механізмів синхронізації, доступних через системні виклики (у ядрі версії 2.6 до них належать ф'ютекси). Крім того, код ядра може використовувати спеціальні механізми синхронізації, доступні тільки у ядрі. Далі розглянемо базові механізми синхронізації ядра і застосувань користувача.
5.4.1. Механізми синхронізації ядра Linux
Ядро Linux є реентерабельним. Це означає, що одночасно в режимі ядра може виконуватися код кількох процесів. В однопроцесорних системах процесор у конкретний момент виконує код тільки одного процесу, інші перебувають у стані очікування. У багатопроцесорних системах код різних процесів може виконуватися паралельно. Для досягнення реентерабельності всередині ядра повинна бути реалізована така сама синхронізація, що і між потоками одного процесу. Для цього у ядрі передбачені механізми взаємного виключення, які забезпечують безпечний доступ до спільно використовуваних даних ядра.
Аналогом потоків у ядрі виступають шляхи передачі керування ядра (kernel
control paths). Таким шляхом є послідовність інструкцій, виконуваних ядром для реалізації реакції на системний виклик або обробку переривання. Така послідовність звичайно зводиться до виконання кількох функцій ядра. Наприклад, для обробки системного виклику шлях передачі керування починають з виклику функції system_cal ІО і завершують викликом ret_system_call О. Надалі іноді говоритимемо не про шляхи керування, а про процеси в режимі ядра, маючи на увазі шляхи передачі керування, що відповідають системним викликам, виконаним процесами.
