TSS (операционная система) - TSS (operating system)

TSS
РазработчикIBM
Рабочее состояниеСнято с производства
изначальный выпуск1967; 53 года назад (1967)
Доступно ванглийский
ПлатформыСистема / 360 Модель 67, Система / 370 модели с DAT
Дефолт пользовательский интерфейсИнтерфейс командной строки
История операционных систем мэйнфреймов IBM
IBM System / 360 Модель 67-2. Это компьютерная модель, на которой работал бы TSS / 360.

В IBM Система разделения времени TSS / 360 прекращается досрочно совместное времяпровождение Операционная система разработан исключительно для специальной модели Система / 360 линейка мэйнфреймов, Модель 67. Сделанный доступным на пробной основе ограниченному кругу клиентов в 1967 году, он никогда официально не выпускался в качестве поддерживаемого продукта IBM. TSS ввела ряд новых функций, некоторые из которых позже появились в более популярных системах, таких как MVS. TSS был перенесен на Система / системы 370 и 303x, но, несмотря на многочисленные достижения и новые возможности, TSS не оправдал ожиданий и в конечном итоге был отменен. TSS / 370 использовался в качестве основы для переноса UNIX на мэйнфрейм IBM.[1] TSS / 360 также вдохновил на разработку ТСС-8 Операционная система.[2]

Новые характеристики

TSS / 360 был одной из первых реализаций тесно связанных симметричная многопроцессорная обработка. Пара мэйнфреймов Model 67 совместно использовала общее пространство физической памяти и выполняла единственную копию кода ядра (и приложения). An Ввод / вывод операция, запущенная одним процессором, может закончиться и вызвать прерывать в другом. Модель 67 использовала стандартную инструкцию 360 под названием Test and Set для реализации замки по коду критические разделы.

Он также реализовал Виртуальная память и Виртуальные машины с помощью позиционно-независимый код.[3]

TSS / 360 включал раннюю реализацию «Table Driven Scheduler» - настраиваемой пользователем таблицы, столбцы которой были такими параметрами, как текущий приоритет, рабочий набор размер и количество временные рамки используется до настоящего времени. Ядро будет обращаться к этой таблице при вычислении нового приоритета нить. Позже это появилось в таких разнообразных системах, как Honeywell CP-V и IBM z / OS.

Как это было в то время стандартным программным обеспечением для операционных систем, клиенты TSS / 360 (например, Исследовательские лаборатории General Motors ) получили полный доступ ко всему исходному коду кода операционной системы и средствам разработки. В официальный исходный код часто включались пользовательские улучшения и исправления.

Пользовательский интерфейс

TSS предоставляет пользователям Интерфейс командной строки.[4] Пользователи взаимодействуют с система команд. Формат команды состоит из Имя_команды [операнды]. Имя команды может содержать от одного до восьми символов без пробелов. Операнды являются необязательными в зависимости от команды и должны отделяться от имени команды как минимум одним пробелом. Несколько операндов следует разделять TAB символы или запятые. Командные строки можно продолжить, набрав дефис («-») в конце строки, которую нужно продолжить, и набрав продолжение в начале следующей строки. Несколько команд можно написать в строке, разделив их точкой с запятой («;»). Комментарии разрешены в командных строках, отделены от команды точкой с запятой и заключены в одинарные кавычки («'»). Операнды могут быть позиционными или ключевыми в формате «ключевое слово = значение».

Системные команды делятся на семь категорий:

  • Управление задачами - LOGON, LOGOFF, ABEND и т. Д.
  • Управление данными - КАТАЛОГ, DDEF, УДАЛИТЬ и т. Д.
  • Управление программой - LOAD, DUMP, DISPLAY, TRAP и др.
  • Создание команды - PROCDEF, BUILTIN
  • Обработка сообщений
  • Профиль пользователя - СИНОНИМ, ПО УМОЛЧАНИЮ, ПРОФИЛЬ и т. Д.
  • Языковой интерфейс программного продукта - ASM (Ассемблер (F) ), КОБОЛ, HASM (Ассемблер (H) ), PLI (PL / I (F) ), ПЛИОПТ (Оптимизирующий компилятор PL / I ), FTNH (ФОРТРАН (H)), так далее.

Независимый от позиции код

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

Каждая процедура может иметь общедоступный CSECT только для чтения, частную секцию прототипа с возможностью записи (PSECT) и область сохранения с возможностью записи, обычно расположенную в PSECT. Константы адреса внешних процедур и точек входа должны быть расположены в PSECT, так как динамический загрузчик[5] не поместит рутину в то же самое виртуальный адрес в каждом процессе. Программа, которая следует соглашениям о связывании типа I, обычно отвечает при входе за сохранение своих регистров в области сохранения, на которую указывает регистр 13, извлечение адреса своего PSECT из слова 19 области сохранения, связывание области сохранения с новой областью сохранения. и помещает адрес новой области сохранения в регистр 13. Вызывающий, который следует соглашениям о связывании типа I, загружает V-константу для подпрограммы в общий регистр 15 (GR15) и копирует R-константу для PSECT подпрограммы в 19-е слово. области сохранения указывала на GR13 до вызова этой подпрограммы.[6][7]

Когда динамический загрузчик загружает программу, он создает копию PSECT и перемещает adcons для отражения виртуальных адресов, назначенных в текущем процессе, поэтому каждый пользователь программы имеет уникальную копию PSECT.

Динамический загрузчик не загружает страницы программы и не разрешает адресные константы до отказа первой страницы.

Критика

TSS / 360 страдал от проблем с производительностью и надежностью и несовместимостью с OS / 360, хотя в конечном итоге эти проблемы были решены. IBM попыталась разработать TSS по очень агрессивному графику с большим штатом программистов, чтобы конкурировать с Мультики. К 1967 году стало очевидно, что TSS / 360 страдает от тех же задержек, что и OS / 360. В феврале 1968 г. во время ПОДЕЛИТЬСЯ 30, восемнадцать сайтов S / 360-67 пытались запустить TSS. Во время конференции IBM объявила «синим письмом», что TSS / 360 выводится из эксплуатации, что стало большим ударом для сообщества разделения времени. Это решение было временно отменено, и TSS / 360 не был официально отменен до 1971 года. Тем не менее, TSS / 360 продолжал оставаться доступным некоторое время существующим клиентам TSS / 360 в качестве временной меры.

После отмены TSS / 360 IBM вложила свои основные усилия в Вариант разделения времени (TSO), монитор с разделением времени для OS / 360. Несколько других групп разработали менее амбициозные и более успешные системы разделения времени для S / 360-67, в частности CP-67 в IBM Кембриджский научный центр, ранний монитор виртуальных машин, который превратился в VM / 370, МТС на университет Мичигана, и ОРВИЛ в Стэндфордский Университет. IBM также предоставила TSS / 370 PRPQ в качестве пути миграции для существующих клиентов TSS / 360, которые прошли через несколько выпусков.

Смотрите также

Рекомендации

  1. ^ Felton, W.A .; Miller, G.L .; Милнер, Дж. М. (октябрь 1984 г.). «Система UNIX: реализация системы UNIX для System / 370». Технический журнал AT&T Bell Laboratories. 63 (8): 1751–1767. Дои:10.1002 / j.1538-7305.1984.tb00063.x.
  2. ^ К. Гордон Белл; Дж. Крэйг Мадж; Джон Э. Макнамара (12 мая 2014 г.). Компьютерная инженерия: взгляд DEC на проектирование аппаратных систем. Elsevier Science. п. 180. ISBN  978-1-4832-2110-6. TSS / 8 был разработан в Университете Карнеги-Меллона с аспирантом Адрианом ван де Гуром в ответ на стоимость, производительность, надежность и сложность IBM TSS / 360 (для их модели 67). Хотя TSS / 360 не продавался, в конечном итоге он сработал, внес в него несколько идей и тысячи человек обученных для IBM. В Карнеги-Меллон (CMU) TSS / 8 работал до 1974 года, когда истек срок действия специального сменного диска. Стоимость на пользователя или на задание, как правило, составляла около 1/20 стоимости CMU системы TSS / 360.
  3. ^ Левин, Джон Р. (2000) [октябрь 1999]. «Глава 8: Загрузка и наложения». Линкеры и загрузчики. Серия Морган Кауфманн в программной инженерии и программировании (1-е изд.). Сан-Франциско, США: Морган Кауфманн. ISBN  1-55860-496-0. OCLC  42413382. ISBN  978-1-55860-496-4. Код: [1] Опечатки: [2]
  4. ^ Корпорация IBM (август 1976 г.). Руководство пользователя системы команд системы разделения времени (GC28-2001-9) (PDF). Получено 2 мая, 2015.
  5. ^ Динамический загрузчик системы разделения времени IBM System / 360 (PDF) (Четвертое изд.). Сентябрь 1971 г. GY28-2031-3.
  6. ^ Корпорация IBM (апрель 1976 г.). Руководство программиста IBM Time Sharing System Assembler (GC28-2032-6) (PDF). стр. 132–147. Получено 2 мая, 2015.
  7. ^ Корпорация IBM (1966 г.). IBM System / 360 Model 67 Предварительное техническое описание системы разделения времени (C20-1647-0) (PDF). стр. 47–50. Получено 2 мая, 2015.

дальнейшее чтение

  • Пью, Эмерсон; Лайл Р. Джонсон; Джон Х. Палмер (1991). Системы IBM 360 и Early 370. Кембридж, Массачусетс: MIT Press. стр.362 –265, 596. ISBN  0-262-16123-0. Описывает происхождение и проблемы с расписанием TSS.
  • Брукс, Фредерик П. (1995). Мифический человеко-месяц. Читающий Массачусетс: Эддисон-Уэсли. ISBN  0-201-83595-9. Описывает «синдром второй системы», повлиявший на СТШ.

внешняя ссылка