Бакалавриат
2025/2026





Архитектура компьютера и системное программирование
Статус:
Курс обязательный (Информационная безопасность)
Когда читается:
3-й курс, 1-4 модуль
Охват аудитории:
для своего кампуса
Язык:
русский
Кредиты:
9
Контактные часы:
132
Программа дисциплины
Аннотация
Архитектура компьютера и системное программирование является областью знаний о цифровых электронных блоках компьютера (включая схемы с комбинационной и последовательной логикой), а также об архитектуре компьютера и разработке системного программного обеспечения (например, загрузчики, трансляторы программ, операционные системы, средства контейнерной оркестрации и т.д). В данной дисциплине рассматриваются таксономии программ и языков программирования, а также устройство основных компонентов вычислительных систем (аппаратные и программные) различных архитектур (архитектуры фон Неймана и Гарвардская). В ходе изучения дисциплины студенты познакомятся с машинным представлением программ (ассемблер) и данных и аспектами трансляции программ.
Особое место в дисциплине занимает внутреннее устройство операционных систем: объекты и файловые системы, представление памяти, процессы и потоки, прерывания и подсистема ввода-вывода, средства межпроцессного взаимодействия и синхронизации, а также механизмы конфигурации. Также в курсе представлены основы архитектуры контейнерной оркестрации: подход «Infrastructure-as-a-Code» (IaC), интерфейсы и среды выполнения контейнеров, изоляция, планирование и балансировка нагрузки между приложениями.
При обучении предусмотрен контроль знаний студентов в виде практических работ и учета активности студентов на семинарах.
Цель освоения дисциплины
- Ознакомление с внутренним устройством основных компонентов вычислительных систем
- Ознакомление с машинным представлением программ и аспектами трансляции программ
- Ознакомление с внутренним устройством операционных систем
- Ознакомление с принципами разработки многопоточных и асинхронных программ с множественным доступом к разделяемым ресурсам и сетевым взаимодействием
- Ознакомление с основами архитектуры систем контейнерной оркестрации
- Формирование навыков разработки системного программного обеспечения
- Формирования навыков обратной разработки и отладки программ на уровне машинного представления
Планируемые результаты обучения
- Знает режимы работы процессора, в том числе, в защищённом режиме.
- Знает классификацию языков программирования
- Знает системные возможности BIOS для организации ввода/вывода
- Умеет организовывать программные проекты с помощью системы сборки cmake.
- Знает классификацию ПО (системное и прикладное)
- Знает устройство основных компонентов вычислительных систем различных архитектур (фон Неймана и Гарвардской)
- Знает основы машинного представления программ (ассемблер) и данных в памяти компьютера
- Знает особенности сегментного и страничного устройства памяти
- Знает назначение и таксономию операционных систем
- Знает основы архитектуры операционных систем с разделением времени
- Знает устройство памяти, процессов и потоков ОС
- Знает устройство объектов ОС и виртуальной файловой системы
- Знает основы диспетчеризации прерываний, устройство подсистемы ввода-вывода и основных файловых систем
- Знает механизмы конфигурации ОС
- Знает основы виртуализации и контейнеризации
- Знает основы архитектуры контейнерных сред
- Знает основы архитектуры систем контейнерной оркестрации
- Знает механизмы планирования систем контейнерной оркестрации
- Знает механизмы обеспечения безопасности систем контейнерной оркестрации
- Знает лучшие практики по внедрению и эксплуатации систем контейнерной оркестрации
- Умеет развертывать и настраивать операционные системы и отдельные подсистемы
- Умеет разрабатывать системные программы на языках Ассемблер/C/Rust с использованием низкоуровневых API операционных систем или аппаратных модулей
- Умеет проводить обратную разработку и отладку программ на уровне машинного представления (ассемблер)
- Умеет проводить анализ слепков оперативной памяти различных операционных систем
- Умеет развертывать и настраивать системы контейнерной оркестрации
- Знает принципы разработки многопоточных и асинхронных программ с множественным доступом к разделяемым ресурсам и сетевым взаимодействием
- Умеет разрабатывать многопоточные и асинхронные программы на языках C/Rust с множественным доступом к разделяемым ресурсам и сетевым взаимодействием (мультиплексирование ввода-вывода)
- Знает основные отличия аналоговой и цифровой схемотехники
- Знает основные термины и определения цифровой схемотехники
- Знает основные схемы, обозначения, таблицы истинности и временные диаграммы
- Знает основы булевой алгебры
- Знает основные полупроводниковые элементы: диоды, транзисторы (МОП), а также передаточные характеристики
- Знает основные комбинационные блоки
- Знает назначение языков описания аппаратуры в части симуляции и синтеза цифровых схем
- Умеет работать со средой моделирования
- Знает особенности представления данных в цифровых блоках
- Знает основные арифметические схемы
- Знает основные функциональные узлы последовательной логики
- Знает устройство защелок и триггеров
- Знает особенности построения последовательных схем
- Знает устройство конечных автоматов (автоматы Мура и Мили)
- Знает устройство регистров различных типов
- Знает схемотехнику матриц (PLM, FPGA): логические элементы (LE) и таблицы преобразования (LUT)
- Знает основные запоминающие элементы
- Знает иерархию памяти
- Знает аппаратную организацию прерываний
- Знает основные последовательные интерфейсы передачи данных (UART/USART, SPI, I2C)
- Знает системные шины данных (AMBA, USB, SATA, PCI/PCI-E)
- Знает основы технологий построения проводных (Ethernet) и беспроводных (Wi-Fi) сетей
- Знает основы технологий проектирования и производства печатных плат
- Знает особенности микроархитектуры процессора (конвейеры, порядок исполнения)
- Знает основные типы архитектур: фон Неймана (Принстонская) и Гарвардская
- Знает основные типы архитектур по набору команд: RISC, CISC, MIPS, VLIW
- Знает особенности устройства программных процессоров
- Знает устройство памяти компьютера
- Знает системные возможности UEFI для организации ввода/вывода
- Знает особенности размещения устройств на материнской плате
Содержание учебной дисциплины
- Введение в цифровую схемотехнику, архитектуру компьютера и системное программирование
- Комбинационная логика, введение в цифровые схемы и языки описания аппаратуры
- Арифметические операции
- Последовательная логика и матрицы логических элементов
- Полупроводниковая память
- Основные последовательные коммуникационные интерфейсы
- Микроархитектура и архитектура процессора
- Устройство процессора и программирование на ассемблере
- Режимы работы процессора, устройство памяти компьютера и программные процессоры
- Устройства ввода-вывода
- Архитектура программного обеспечения и основные этапы трансляции программы на примере языка C
- Многозадачность, многопоточность и планирование задач
- Введение в операционные системы (ОС). Операционные системы реального времени (ОСРВ)
- Операционные системы с разделением времени
- Устройство памяти, процессов и потоков ОС
- Диспетчеризация прерываний, подсистема ввода-вывода и файловые системы ОС
- Подходы к синхронизации, межпроцессное взаимодействие и сетевая подсистема ОС
- Системные механизмы и основы безопасности ОС
- Основы виртуализации и контейнеризации
- Архитектура контейнерных сред
- Архитектура систем контейнерной оркестрации
- Механизмы планирования систем контейнерной оркестрации
- Механизмы обеспечения безопасности систем контейнерной оркестрации
- Дополнительные главы архитектуры систем контейнерной оркестрации
Элементы контроля
- Практическая работа 1.1
- Практическая работа 1.2
- Практическая работа 1.3
- Практическая работа 2.1
- Практическая работа 2.2
- Практическая работа 2.3
- Экзамен
- Практическая работа 3.1
- Практическая работа 3.2
- Практическая работа 3.3
- Практическая работа 3.4
- Практическая работа 4.1
- Практическая работа 4.2
- Практическая работа 4.3
- Практическая работа 4.4
- Экзамен
Промежуточная аттестация
- 2025/2026 2nd module0.13 * Практическая работа 1.1 + 0.13 * Практическая работа 1.2 + 0.13 * Практическая работа 1.3 + 0.13 * Практическая работа 2.1 + 0.13 * Практическая работа 2.2 + 0.13 * Практическая работа 2.3 + 0.22 * Экзамен
- 2025/2026 4th module0.15 * Практическая работа 3.1 + 0.15 * Практическая работа 3.2 + 0.05 * Практическая работа 3.3 + 0.05 * Практическая работа 3.4 + 0.05 * Практическая работа 4.1 + 0.05 * Практическая работа 4.2 + 0.15 * Практическая работа 4.3 + 0.15 * Практическая работа 4.4 + 0.2 * Экзамен
Список литературы
Рекомендуемая основная литература
- Linux API. Исчерпывающее руководство - 978-5-496-02689-5 - Керриск М. - 2018 - Санкт-Петербург: Питер - https://ibooks.ru/bookshelf/356956 - 356956 - iBOOKS
- Архитектура компьютера, Таненбаум, Э., 2014
- Внутреннее устройство Linux - 978-5-4461-0938-8 - Б. Уорд - 2021 - Санкт-Петербург: Питер - https://ibooks.ru/bookshelf/374451 - 374451 - iBOOKS
- Внутреннее устройство Microsoft Windows. 6-е изд. - 978-5-496-00434-3 - Руссинович М., Соломон Д. - 2013 - Санкт-Петербург: Питер - https://ibooks.ru/bookshelf/338561 - 338561 - iBOOKS
- Внутреннее устройство Microsoft Windows. 6-е изд. Основные подсистемы ОС - 978-5-496-00791-7 - Руссинович М., Соломон Д. ., Ионеску Алекс - 2014 - Санкт-Петербург: Питер - https://ibooks.ru/bookshelf/341181 - 341181 - iBOOKS
- Вскрытие покажет! Практический анализ вредоносного ПО - 978-5-4461-0641-7 - Сикорски М., Хониг Э. - 2018 - Санкт-Петербург: Питер - https://ibooks.ru/bookshelf/358154 - 358154 - iBOOKS
- Монаппа, К. А. Анализ вредоносных программ / К. А. Монаппа , перевод с английского Д. А. Беликова. — Москва : ДМК Пресс, 2019. — 452 с. — ISBN 978-5-97060-700-8. — Текст : электронный // Лань : электронно-библиотечная система. — URL: https://e.lanbook.com/book/123709 (дата обращения: 00.00.0000). — Режим доступа: для авториз. пользователей.
- Работа с ядром Windows. - 978-5-4461-1680-5 - Иосифович Павел - 2021 - Санкт-Петербург: Питер - https://ibooks.ru/bookshelf/377032 - 377032 - iBOOKS
- Современные операционные системы, Таненбаум, Э., 2018
- Цифровая схемотехника и архитектура компьютера : пер. с англ., Харрис, Д. М., 2018
- Цифровая схемотехника и архитектура компьютера: RISC-V, Харрис, С. Л., 2022