Перечень тем, рассмотренных в лекциях icon

Перечень тем, рассмотренных в лекциях



НазваниеПеречень тем, рассмотренных в лекциях
страница1/4
Дата конвертации31.08.2012
Размер0.61 Mb.
ТипЛекция
  1   2   3   4

Перечень тем, рассмотренных в лекциях

Лекция N1: 1. Первоначальные сведения о курсе ОВП: структура общего программного обеспечения, понятие об ОС, терминология, ресурсы.

2. Эволюция аппаратных средств поддержки ОС и режимов работы в ЭВМ 1-го - 4-го поколений.

Лекция N2: 1. Система прерывания программ.

2. Таймер, интервальный таймер.

Лекция N3. 1. Концепции процесса.

2. Ядро ОС.

3. Планирование загрузки процессоров.

Лекция N4. Управление памятью. Организация памяти.

Лекция N5. Управление вводом-выводом данных в ЭВМ.

Лекция N6. Система управления данными (файловая система).

Лекция N7. Оценка производительности вычислительных систем.

Лекция N8. Локальные вычислительные сети.

Лекция N9. Локальные вычислительные сети (окончание).

Лекция N10. Базы и банки данных.

Лекция N11. 1. Общие принципы функционирования MS DOS.

2. Резидентные программы.

3. Проблема реентерабельности программ в MS DOS.

Лекция N12. 1.Режимы работы ЭВМ с ЦП 80х86 (х > 2). Эмуляция MS DOS в режиме V86.

2.Принципы обеспечения в ОС многозадачного и многопользовательского режимов.

Лекция N 1


Предмет курса "Организация вычислительного процесса"


В этом курсе изучаются:

- принципы организации вычислительного процесса (ОВП) в электронных вычислительных машинах (ЭВМ), вычислительных комплексах (ВК)и вычислительных системах (ВС);

- функции различных аппаратных и программных средств, используемых для ОВП;

- средства организации больших об'емов данных.


Все программное обеспечение(ПО) может быть разделено на 2 части:

- общее ПО (ОПО),

- прикладное ПО (ППО).

К ОПО относят совокупность программных средств, не связанных непосредственно с решением введенных пользователем конкретных вычислительных задач, однако эти средства существенно влияют на эффективность функционирования ЭВМ и процесса разработки ПО.



Структура ОПО:

В состав ОПО входят следующие основные компоненты:

  • операционные системы (ОС);

  • комплекс программ для системы технического обслуживания ЭВМ, ВК и ВС (программы контроля работоспособности аппаратуры, программы диагностического контроля аппаратуры, программы обеспечения живучести ЭВМ, ВК и ВС);

  • средства подготовки программ ППО к исполнению на ЭВМ (загрузчики, трансляторы с исходных текстов, записанных на каком-либо языке программирования, в последовательность машинных кодов для исполнения на ЭВМ, компоновщики, отладчики программ, написанных на языке ассемблера или языке высокого уровня);

  • средства измерения параметров вычислительного процесса и комплексной отладки сложных программных систем, средства моделировании работы специализированных ЭВМ и ВС.

В курсе ОВП будут изучаться главным образом ОС; некоторое внимание будет также уделено средствам 2-й и 4-й групп.


^ Определение термина "ОС" и перечень функций, выполняемых ОС


Существует достаточно большое число определений этого термина, например: ОС - это комплекс программ, обеспечивающий в ЭВМ, ВК или ВС выполнение других программ, распределение ресурсов, планирование прохождения заданий, ввод-вывод данных и управление данными.

Перечислим основные функции ОС:

  • выполнение действий при начальном пуске ЭВМ после ее включения;

  • ввод-вывод данных;

  • прием команд от пользователя;

  • запуск, выполнение и завершение программ ППО;

  • запись и чтение файлов, т.е. поименованных наборов данных, размещенных во внешней памяти;

  • ликвидация последствий сбоев аппаратуры или оповещение пользователя о них;

  • отсчет текущего времени.

Можно сказать, что ОС - это программная надстройка над аппаратурой ЭВМ, ВК или ВС, служащая для повышения эффективности и упрощения процесса выполнения программ ППО на ЭВМ, ВК или ВС (далее там, где это не будет специально оговариваться, вместо перечисления "ЭВМ, ВК, ВС" будет упоминаться только термин "ЭВМ").

^ Терминология, принятая при рассмотрении ОС


Перечислим некоторые из наиболее часто используемых терминов.

Пользователь - любой желающий выполнить какую-то работу на ЭВМ.

Процесс - это некоторая деятельность, связанная с выполнением программы задачи на ЭВМ.

Мультипрограммирование - термин, относящийся к системе, которая может иметь несколько процессов в состоянии выполнения одновременно.

Привилегированные команды - их выполнение доступно только ОС, но не программам пользователей.

Состояния ЭВМ - состояние задачи и состояние супервизора, причем каждое из этих состояний соответствует одному из двух состояний соответствующего триггера; в ряде современных ЭВМ, например, в ЭВМ типа IBM PC с центральным процессором (ЦП) типа 80х86, где х > 2, вместо двух состояний ЭВМ используется большее их число (4 в указанных ЭВМ) и каждое из таких состояний определяет свой уровень привилегий.

Аппаратные средства защиты памяти используются для управления доступом к соответствующим областям памяти.

Ресурс - аппаратные, программные и информационные компоненты системы, предоставляемые в распоряжение процесса для его реализации.


Типы ОС:

  • Однопользовательская однозадачная ОС, например MS DOS для ЭВМ с ЦП типа 80х86.

  • Однопользовательская многозадачная ОС - запускается с одного терминала; примером ОС с ограниченным типом многозадачности является ОС Windows 3.1; для ЭВМ 2-го - 3-го поколений к этому типу ОС можно было отнести те из них, в которых была организована так называемая пакетная обработка заданий.

  • Многопользовательская ОС - осуществляет одновременную работу нескольких пользователей на каждом из их терминалов, например, UNIX, Windows NT и т.д.

  • Многопроцессорная ОС, организующая работу в многопроцессорных ВК.

  • Операционная система реального масштаба времени, организующая работу в вычислительных системах реального времени, например VxWorks.


^ Основные принципы построения ОС


ОС различаются по назначению, выполняемым функциям, формам реализации. В этом смысле каждая ОС - это уникальная сложная программная система. Однако существуют и общие принципы, реализованные большинстве ОС:

  • модульность, при которой каждый модуль выполняет определенную функцию и может быть относительно легко заменен на другой;

  • функциональная избирательность, состоящая в выделении наиболее важных и часто используемых модулей в ядро ОС, которое размещается в оперативной памяти (ОП) ЭВМ для постоянного хранения (это так называемые резидентные программы);

  • генерируемость ОС, т.е. настройка на требуемую конфигурацию вычислительной системы, осуществляемая в процессе загрузки или корректировки ОС;

  • выполнение некоторых действий по умолчанию, т.е. при отсутствии указаний со стороны пользователей или главного оператора используются значения параметров, заложенные в ОС;

  • перемещаемость модулей ОС (и прикладных программ), обеспечивается аппаратурными и программными средствами;

  • защита модулей ОС и программ пользователей, находящихся как в ОП, так и во внешней памяти, размещаемой во внешних запоминающих устройствах (ВЗУ), от искажений или неправильных действий со стороны пользователей и их программ;

  • независимость программ от внешних устройств; наиболее последовательно этот принцип реализован в ОС UNIX;

  • открытость ОС и возможность ее наращивания.


Общие принципы управления ресурсами


Обычно полагают, что ОС является набором программ, созданных для управления ресурсами системы, а именно:

  • внутренней оперативной и виртуальной памятью;

  • центральными процессорами (одним процессором в однопроцессорной системе);

  • периферийными устройствами (ПУ);

  • информацией (программой и данными).

Эти ресурсы во многих случаях являются весьма дефицитными, поэтому задача ОС состоит в том, чтобы эффективно использовать их и разрешать конфликты, возникающие в результате конкуренции между процессами различных пользователей или различных ЦП. ОС должна хранить информацию о состоянии любого ресурса, решать, какой процесс должен полуить ресурс (в каком количестве и когда), выделять его и в конце концов освобождать его.


^ Эволюция аппаратных средств поддержки ОС и режимов работы

в ЭВМ первого - четвертого поколений


К основным аппаратным средствам поддержки ОС можно отнести:

- систему прерывания программ (СПП);

- таймер;

- средства управления работой ПУ;

- средства формирования адресов внутренней памяти, обеспечивающие перемещаемость программ и данных;

- триггер система-пользователь или заменяющее его устройство выработки уровня привилегий;

- средства выполнения привилегированных команд ЭВМ;

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

- систему защиты памяти.


В ЭВМ 1-го поколения из всех перечисленных средств существовали только средства прямого управления работой ПУ, с помощью которых обмен с ПУ производился через регистры арифметического устройства (АУ), в результате этого имели место простои центрального процессора при обменах с ПУ. Организация вычислительного процесса возлагалась на самих пользователей, так как ОС в этих ЭВМ отсутствовали. Следствием такой организации являлась крайне низкая эффективность использования машинного времени в ЭВМ 1-го поколения, так как до 90% от него расходовалось на поиск и устранение ошибок в программах, выполняемых на ЭВМ, а центральный процессор при этом в основном простаивал.


Для устранения рассмотренных недостатков в ЭВМ 2-го поколения были реализованы некоторые аппаратные средства, повышающие эффективность вычислительного процесса:

- введена аппаратура преобразования адресов;

- в составе ЦП появились средства для выполнения привилегированных операций;

- для обмена информации с ПУ появились средства косвенного управления работой этих ПУ (так называемые каналы), с помощью которых АУ было освобождено от необходимости участвовать в процессе обмена с ПУ;

- в составе ЭВМ появилась СПП, одной из функций которой стала обработка сигналов, поступающих от каналов;

- в составе некоторых ЭВМ появились таймеры.

Внедрение перечисленных средств в ЭВМ 2-го поколения позволило начать использование ОС в этих ЭВМ, причем с целью уменьшения простоев ЦП в этих ОС был реализован так называемый пакетный режим рабо-ты. Суть его сводилась к следующему:

  • задания программистов-пользователей, набитые на перфокартах, сдавались в группу главного оператора ЭВМ для последующего использования их в пакете заданий на выполнение в ЭВМ;

  • результаты, полученные при выполнении каждого задания из такого пакета, выводились на бумажные носители для последующей передачи их пользователям;

  • пользователь, получивший в группе главного оператора результаты выполнения своей программы на ЭВМ, анализировал за своим рабочим столом эти результаты и при необходимости готовил новое задание для сдачи его в группу главного оператора и последующего выполнения на ЭВМ;

  • если в процессе выполнения на ЭВМ какого-либо задания из пакета проявлялась программная ошибка, в результате чего выполнение этого задания на ЭВМ становилось невозможным (например, имело мест деление на ноль), то это задание автоматически исключалось из обработки, а для пользователя могли выдаваться на печать некоторые данные о прохождении его задания, например, так называемый посмертный дамп.

Очевидно, что при такой организации вычислительного процесса на ЭВМ простои ЦП были сведены к минимуму, однако и программисты-пользователи оказались отлученными от ЭВМ, что не могло не сказаться отрицательным образом на суммарном времени прохождения задания каждого из этих пользователей на ЭВМ, т.е. от момента первой сдачи задания для исполнения на ЭВМ до окончательного завершения работы над этим заданием.


При создании ЭВМ 3-го поколения был продолжен процесс совершенствования в них аппаратных средств, используемых для организации вычислительного процесса с целью повышения эффективности последнего.

Перечислим эти аппаратные средства:

  • средства формирования адресов, обеспечивающие перемещаемость программ и данных;

  • таймеры, которые появились теперь во всех ЭВМ;

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

  • система защиты памяти;

  • видеотерминалы с клавиатурой.

Основным режимом, используемым в ЭВМ 3-го поколения, стал режим разделения времени, при котором у каждого пользователя, находящегося за видеотерминалом, появилась возможность непосредственного взаимо-

действия с ЭВМ в режиме диалога. Это позволило устранить главный недостаток, характерный для использования ЭВМ 2-го поколения - отчужденность программиста-пользователя от общения с ЭВМ.


Лекция N 2

Cистема прерывания программ (СПП)


^ 1. Понятие о состоянии программы. Вектор (слово) состояния


Вектор состояния, или слово состояния программы (ССП), в любой момент времени должен содержать информацию, достаточную для продолжения выполнения программы с точки, соответствующей моменту формирования данного вектора состояния. При этом предполагается, что остальная информация, характеризующая состояние программы, например, содержимое всех или части программно-адресуемых регистров, может при необходимости быть сохранена программным путем в оперативной памяти ЭВМ.

ССП формируется в соответствующих регистрах центрального процессора (ЦП), изменяясь после выполнения каждой команды. Разные ЭВМ имеют разные наборы информационных элементов, образующих ССП. Например, в реальном режиме работы микропроцессора 80х86 ССП, сохраняемое в стеке, содержит следующие составляющие:

  • значение регистра сегмента команд CS (в ячейках памяти этого сегмента содержатся команды выполняемой программы);

  • значение регистра указателя команд IP;

  • значение регистра флагов FLAGS.


^ 2. Принципы организации СПП


При функционировании ЭВМ в ней самой и связанной с ней внешней среде могут возникать события, требующие немедленной реакции на них со стороны ЭВМ. Эта реакция состоит в том, что ЭВМ прерывает обработку текущей программы, которая является прерываемой, и переходит к выполнению другой программы, называемой прерывающей и специально предназначенной для обработки данного события. Рассматриваемый процесс называется прерыванием программ. Моменты возникновения некоторой части событий, требующих прерывания программ, заранее неизвестны и поэтому не могут быть учтены при программировании.

Любое событие, требующее прерывания, сопровождается сигналом, оповещающим ЭВМ. Эти сигналы называются запросами прерывания и генерируются несколькими выполняющимися параллельно во времени процессами, например:

  • процессом выполнения текущей программы в ЦП и внутренней памяти ЭВМ;

  • процессом аппаратного контроля правильности работы ЭВМ, каналов и периферийных устройств (ПУ);

  • процессом функционирования каналов и ПУ;

  • процессом функционирования таймера;

  • процессом функционирования ЭВМ, сопряженной с данной ЭВМ, и т.д.


Прерывания от устройства аппаратного контроля возникают при обнаружении этим устройством неисправности в ЭВМ, канале или ПУ.

Прерывания ввода-вывода происходят при завершении работы канала или ПУ.

Прерывания от таймера происходят при переполнении таймера.


^ Возможность прерывания программ - важное свойство ЭВМ, позволяющее существенно повысить эффективность использования ее ресурсов, а также использовать ЭВМ для управления в системах реального времени. Для реализации прерывания в ЭВМ должны существовать соответствующие программные и аппаратные средства, называемые системой прерывания программ (СПП), или контроллером прерываний. Основные функции СПП состоят в запоминании ССП и переходе к прерывающей программе, при этом для запоминания ССП используется фиксированная зона оперативной памяти (например, в ЭВМ типа IBM/360 и IBM/370 и соответственно в ЕС ЭВМ) или же стековая память (например, в ЭВМ типа IBM PC с МП типа 80х86).

При наличии нескольких источников запросов прерывания должен быть установлен определенный порядок (дисциплина) в обслуживании поступающих запросов. Другими словами, должны быть установлены приоритетные соотношения, определяющие, какой из нескольких поступивших запросов должен быть обработан в первую очередь и имеет ли он право прервать текущую программу. Приоритетный выбор запроса входит в процедуру перехода к прерывающей программе.


Важную роль играет регистр масок прерываний, разряды которого могут программно и аппаратно устанавливаться в "1" или "0". Этим достигается программно-управляемый приоритет прерываний. Установленный в "1" триггер регистра масок запрещает соответствующее прерывание, а в положении "0" разрешает его. Некоторые причины прерывания в каких-то конкретных типах ЭВМ не могут быть программно замаскированы.


^ 3. Векторное прерывание


В современных ЭВМ обычно реализуется так называемое векторное прерывание, при котором источник прерывания выставляет запрос прерывания и одновременно выставляет на шины интерфейса с центральным процессором код адреса своего вектора прерывания в памяти ЭВМ, т.е.для разных причин сразу же включаются аппаратно соответствующие им прерывающие программы, называемые обработчиками прерываний. В некоторых ЭВМ источник прерывания вместо кода адреса своего вектора выставляет номер своего прерывания, по которому СПП формирует адрес внутренней памяти с новым ССП.


^ 4. Обработчик прерывания


Перечислим основные действия, который должен выполнить обработчик прерываний:

  1. Сохранять при необходимости содержимое всех или части программно-доступных регистров (эту процедуру иногда называют переключением контекста);

  2. Заблокировать все прерывания, возникновение которых в процессе выполнения обработчика может привести к конфликту (часто это выполняется аппаратурой ЭВМ без участия программы);

  3. Разрешить все прерывания, которые имеют право возникать во время обработки данного прерывания;

  4. Определить источник прерывания;

  5. Выполнить запланированную обработку прерывания;

  6. Восстановить ССП;

  7. Разрешить все прерывания, которые были запрещены при обработке данного прерывания.

  8. Возобновлять выполнение прерванного процесса; вместо этого обработчик прерывания может заканчивать свою работу переводом ЭВМ в состояние ожидания (например, при машинных сбоях) или передачей управления ОС.


Основные типы прерываний в ЭВМ типа IBM PC с МП 80х86

Прерывания в этой ЭВМ могут быть разбиты на следующие группы:

  • Немаскируемое аппаратное прерывание, возникающее в результате серьезного аппаратного сбоя в работе МП и внутренней памяти.

  • Внешние аппаратные прерывания, возникающие при возникновении сигналов прерывания от таймера, клавиатуры и различных ПУ;

  • Внутренние события, называемые исключениями и возникающие в том случае, если процессор не может выполнить очередную команду, например, вследствие равенства делителя нулю при выполнении операции деления, недопустимом коде команды и т.д.; к этой же группе относится прерывание, называемое исключением отладки и возникающее в том случае, если по заданию программиста в команде при трансляции ???? был установлен признак так называемой ловушки;

  • Программные прерывания, возникающие при выполнении процессором команды int с числовым аргументом.


^ Таймер. Интервальный таймер


Другим аппаратным устройством, имеющим важнейшее значение для организации вычислительного процесса, является таймер. Его использование позволяет программно-аппаратным способом задавать программные события, наступающие по истечении заданного промежутка времени, считая от момента задания этих событий. Эти события реализуются путем выработки сигнала прерывания от таймера и включения оответствующего обработчика прерывания. Рассмотрим более подробно работу таймера на примере его устройства в ЭВМ типа IBM PC с МП типа 80х86.

Этот таймер состоит из трех почти одинаковых каналов – каналов "0", "1" и "2". При работе программ главным образом используется канал "0", поэтому он и будет рассмотрен; на рис.1 приведена его схема. Генератор импульсов (ГИ) вырабатывает с частотой f=1193180 Гц непрерывную последовательность импульсов, поступающих на импульсные входы всех трех каналов. При каждом поступлении импульса на вход 16-разрядного счетчика из содержимого последнего вычитается "1" и при переходе этого счетчика из состояния 000...01 в состояние 000...00 вырабатывается сигнал прерывания, поступающий в СПП для включения последним программы-обработчика прерывания от таймера. Если исходно состояние счетчика таймера равно 00...0, то при поступлении очередного импульса из ГИ состояние счетчика становится равным 11...1 и далее уменьшается на "1" при каждом поступлении импульса из ГИ. В этом случае сигнал прерывания будет выработан таймером после поступления на его вход 65536 импульсов, т.е. по прошествии интервала времени, примерно равного 55 мсек, что соответствует частоте срабатывания таймера, примерно равной 18,2 Гц. В случае, если интервал времени срабатывания таймера должен иметь меньшее значение, чем 55 мсек, то в счетчик таймера необходимо занести код, соответствующий числу импульсов N, вычисляемому по формуле

где F - требуемое значение частоты срабатывания таймера, причем долно выполняться неравенство F > 18,2 Гц. Например, для F = 72,8 Гц получим, что N = 16389,8; округляя, получим, что в счетчик таймера должен быть занесен двоичный код 0 100 000 000 000 110.


^ Занесение требуемого кода в счетчик таймера производится следующим образом. Сначала МП х86 должен выполнить команду программы, которая производит передачу в порт таймера с шестнадцатеричным номером

40h требуемый двоичный код. Затем МП х86 должен выполнить команду программы, которая производит передачу в порт таймера с шестнадцатеричным номером 43h байта, в котором указывается номер программируемого канала таймера, режим работы этого канала и количество передаваемых в счетчик таймера байтов - 1 или 2. После этого в запрограммированном канале таймера немедленно начинает функционировать сначала схема управления занесением кода в счетчик таймера и затем сам счетчик таймера в соответствии с полученным заданием.




Рис.1. Схема таймера в ПЭВМ IBM PC для канала "0"


Рассмотрим теперь работу программы, которую обычно называют интервальным таймером. Необходимость использования этой программы определяется тем обстоятельством, что в большинстве типов ЭВМ, в том числе и в ЭВМ типа IBM PC, используется только один таймер, хотя во многих случаях при функционировании достаточно сложных программ возникает необходимость организации нескольких параллельно существующих программ, которые должны быть включены в различные заранее опре деленные моменты времени. Один из возможных способов организации интервального таймера состоит в следующем. Этой программой, для управления процессом параллельного выполнения нескольких программ, в оперативной памяти составляется таблица, в которой для каждой из этих программ выделяется несколько строк, содержащих следующие параметры:

  • адрес начала i-й программы;

  • значение Т(i) интервала времени, по истечении которого должна быть включена эта программа, причем отсчет этого интервала начинается с момента организации интервальным таймером этой программы;

  • текущее значение интервала времени t(i), по истечении которого должна быть включена эта программа;

  • признак c(i) режима включения этой программы - циклический или разовый (пусть, например, с(i)=0 для разового режима).

Кроме того, в этой таблице должна быть еще одна строка, общая для всех программ, в которой содержится значение интервала времени Т, которое задано для текущего включения таймера. Тогда при каждом включении программы-обработчика прерывания от таймера в этой таблице корректируются все интервалы времени, величина которых больше нуля, путем уменьшения их значений на величину Т. Если после корректировки окажется, что для каких-то программ величина t(i)=0 или t(i)<0, то должно быть организовано последовательное включение этих программ. Если для каких-то программ с(i)=1, то должно быть выполнено присвоение t(i)=T(i) и затем организовано очередное включение этих программ по истечении соответствующих им интервалов времени, равных t(i).

  1   2   3   4




Похожие:

Перечень тем, рассмотренных в лекциях iconУчебно-методическое пособие по курсу «культурология» для самостоятельной подготовки к семинарским занятиям студентов угма
Данное Учебно-методическое пособие включает тематический план лекций и семинарских занятий, перечень рекомендуемой литературы, основной...
Перечень тем, рассмотренных в лекциях iconПримерный перечень тем контрольных работ. (на вечернем отделении мкф сдается в виде реферата)
Основные направления и школы психологического знания, используемые для построения моделей поведения человека
Перечень тем, рассмотренных в лекциях iconУважаемые руководители школ!
В связи с тем, что вчера ( 24. 09. 08 в 16. 33) поступил новый измененный перечень документов на поощрение победителей лучших классных...
Перечень тем, рассмотренных в лекциях iconИсходя из рассмотренных данных по Невельскому району, можно сделать следующие выводы
...
Перечень тем, рассмотренных в лекциях iconВзяв операцию
Теперь покажем, что рассмотренных уравнений, которые были получены только из анализа полей рассеянных частицами сферических волн,...
Перечень тем, рассмотренных в лекциях iconРоман Вершилло
В лекциях профессора Московской Духовной Академии А. И. Осипова, распространяемых в виде магнитофонных записей, им излагается учение,...
Перечень тем, рассмотренных в лекциях iconФормирование профессиональной компетенции педагогов Павловского района
Чем больше знает учитель, тем легче усваивать его ученикам элементарные знания, тем больше авторитетом и доверием пользуется он среди...
Перечень тем, рассмотренных в лекциях iconЛекция 10. Информационные системы
Информационные процессы, которые мы рассматривали в предыдущих лекциях, происходят в рамках информационных систем. Теперь мы приступаем...
Перечень тем, рассмотренных в лекциях iconПеречень документов, представляемых соискателем для проведения защиты диссертации в Диссертационный совет при мгсу
Перечень документов установлен Положением вак минобразования РФ о диссертационном совете1 и включает в себя
Перечень тем, рассмотренных в лекциях iconДокументы
1. /Перечень локальных актов/Приказ ь11 от 11.01.2012г О переименовании учреждения.doc
Разместите кнопку на своём сайте:
Документы


База данных защищена авторским правом ©podelise.ru 2000-2014
При копировании материала обязательно указание активной ссылки открытой для индексации.
обратиться к администрации
Документы

Разработка сайта — Веб студия Адаманов